/* ═══════════════════════════════════════════════════════════
   TURGRUPPE — STYLESHEET
   Seksjoner:
   1. Reset & Design tokens
   2. Typografi & Layout
   3. Navigasjon
   4. Knapper
   5. Skjema & feltgrupper
   6. Meldinger & badges
   7. Offentlig — turoversikt
   8. Offentlig — turdetalj
   9. Admin — tabell & sidehode
  10. Admin — dashboard
  11. Admin — sesong & statistikk
  12. Admin — titler & historikk
  13. Kart
  14. Markdown
  15. Footer
  16. Mobil (max-width: 640px)
═══════════════════════════════════════════════════════════ */

/* ───────────────────────────────────────
   1. RESET & DESIGN TOKENS
─────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* Farger */
  --bg:         #f8f7f4;
  --kort:       #ffffff;
  --tekst:      #1a1a1a;
  --dempet:     #6b6b6b;
  --kant:       #e0ddd8;
  --blaa:       #2563eb;
  --blaa-hover: #1d4ed8;
  --gronn:      #16a34a;
  --roed:       #dc2626;

  /* Størrelser */
  --radius:   10px;
  --input-h:  2.6rem;
  --btn-pad:  0.55rem 1.1rem;

  /* Typografi */
  --font-sm: 0.875rem;
  --font-xs: 0.8rem;
}

body {
  font-family: system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--tekst);
  font-size: 16px;
  line-height: 1.6;
}
.admin-body { background: #f1f0ed; }

/* ───────────────────────────────────────
   2. TYPOGRAFI & LAYOUT
─────────────────────────────────────── */
h1 { font-size: 1.75rem; font-weight: 700; margin-bottom: 1.5rem; }
h2 { font-size: 1.15rem; font-weight: 600; margin-bottom: 1rem; }

.container { max-width: 860px; margin: 0 auto; padding: 2rem 1.5rem; }
.smal      { max-width: 520px; }

.tilbake { display: inline-block; color: var(--dempet); text-decoration: none; margin-bottom: 1rem; font-size: var(--font-sm); }
.tilbake:hover { color: var(--tekst); }

.tom { color: var(--dempet); font-style: italic; }

/* ───────────────────────────────────────
   3. NAVIGASJON
─────────────────────────────────────── */
nav {
  background: var(--kort);
  border-bottom: 1px solid var(--kant);
  padding: 0 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 56px;
  position: sticky;
  top: 0;
  z-index: 50;
}

.logo { font-weight: 700; font-size: 1.1rem; text-decoration: none; color: var(--tekst); }

.nav-links { display: flex; gap: 1.5rem; align-items: center; }
.nav-links a { text-decoration: none; color: var(--dempet); font-size: 0.95rem; white-space: nowrap; }
.nav-links a:hover { color: var(--tekst); }

/* Admin-nav */
.admin-nav { background: #1e293b; border-bottom: none; position: relative; }
.admin-nav .logo { color: #f8fafc; }
.admin-nav .nav-links a { color: #cbd5e1; }
.admin-nav .nav-links a:hover { color: #f8fafc; }
.admin-nav .nav-links .btn-liten { color: #cbd5e1; border-color: #334155; background: transparent; }
.admin-nav .nav-links .btn-liten:hover { background: #334155; color: #f8fafc; }

.burger { display: none; background: none; border: none; color: #f8fafc; font-size: 1.5rem; cursor: pointer; padding: 0.25rem; line-height: 1; }

/* ───────────────────────────────────────
   4. KNAPPER
─────────────────────────────────────── */
.btn, .btn-liten, button.btn, button.btn-liten {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: var(--input-h);
  padding: var(--btn-pad);
  font-size: var(--font-sm);
  font-family: inherit;
  font-weight: 500;
  border-radius: 8px;
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: background .15s, border-color .15s;
  line-height: 1;
}

.btn               { background: var(--blaa); color: #fff; border-color: var(--blaa); }
.btn:hover         { background: var(--blaa-hover); border-color: var(--blaa-hover); }
.btn-fare,
.btn.btn-fare      { background: var(--roed); color: #fff; border-color: var(--roed); }
.btn-fare:hover    { background: #b91c1c; border-color: #b91c1c; }
.btn-liten         { background: var(--kort); color: var(--tekst); border-color: var(--kant); }
.btn-liten:hover   { background: var(--bg); }
.btn-liten.fare    { background: #fef2f2; color: var(--roed); border-color: #fca5a5; }
.btn-liten.fare:hover { background: #fee2e2; }

.skjema-knapper { display: flex; gap: 0.75rem; margin-top: 1.5rem; }
.skjema-knapper .btn { flex: 1; }
.btn-sekundær { background: var(--kort); color: var(--tekst); border-color: var(--kant); }
.btn-sekundær:hover { background: var(--bg); }

/* ───────────────────────────────────────
   5. SKJEMA & FELTGRUPPER
─────────────────────────────────────── */
.skjema-kort {
  background: var(--kort);
  border: 1px solid var(--kant);
  border-radius: var(--radius);
  padding: 1.5rem;
}

.skjema-kort label {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-size: var(--font-sm);
  font-weight: 500;
  margin-bottom: 1rem;
}
.skjema-kort label:last-of-type { margin-bottom: 0; }
.skjema-kort small { font-weight: 400; color: var(--dempet); font-size: var(--font-xs); }
.skjema-kort .btn  { margin-top: 0.5rem; width: 100%; }

.skjema-kort input,
.skjema-kort textarea,
.skjema-kort select {
  height: var(--input-h);
  padding: 0 0.75rem;
  border: 1px solid var(--kant);
  border-radius: 8px;
  font-size: 1rem;
  font-family: inherit;
  background: var(--bg);
  color: var(--tekst);
  width: 100%;
  transition: border-color .15s;
  -webkit-appearance: none;
  box-sizing: border-box;
}
.skjema-kort textarea { height: auto; padding: 0.6rem 0.75rem; resize: vertical; }
.skjema-kort input:focus,
.skjema-kort textarea:focus,
.skjema-kort select:focus { outline: none; border-color: var(--blaa); box-shadow: 0 0 0 3px rgba(37,99,235,.1); }

/* To-felt grid */
.to-felt { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

/* Checkbox */
.checkbox-label { flex-direction: row !important; align-items: center !important; gap: 0.5rem !important; cursor: pointer; height: auto !important; }
.checkbox-label input { width: auto !important; height: auto !important; accent-color: var(--blaa); -webkit-appearance: checkbox; }

/* Feltgruppe — iOS-stil gruppert skjema */
.felt-gruppe {
  border: 1px solid var(--kant);
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 1rem;
}
.felt-gruppe:focus-within { border-color: var(--blaa); box-shadow: 0 0 0 3px rgba(37,99,235,.1); }

.felt-gruppe-rad {
  display: grid;
  border-bottom: 1px solid var(--kant);
}
.felt-gruppe-rad:last-child { border-bottom: none; }
.felt-gruppe-rad.to { grid-template-columns: 1fr 1fr; }
.felt-gruppe-rad.to .felt-gruppe-felt:first-child { border-right: 1px solid var(--kant); }
.felt-gruppe-rad.tre { grid-template-columns: 1fr 1fr 1fr; }
.felt-gruppe-rad.tre .felt-gruppe-felt:not(:last-child) { border-right: 1px solid var(--kant); }

.felt-gruppe-felt {
  display: flex;
  flex-direction: column;
  padding: 0.5rem 0.75rem;
  background: var(--bg);
}
.felt-gruppe-felt > span {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--dempet);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 0.15rem;
}
.felt-gruppe-felt input,
.felt-gruppe-felt select {
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  height: auto !important;
  font-size: 0.95rem !important;
  font-weight: 500;
  color: var(--tekst);
  width: 100% !important;
  box-shadow: none !important;
  outline: none !important;
  -webkit-appearance: none;
  min-width: 0;
}

/* Seksjonsoverskrift i skjema */
.seksjon-label {
  font-size: var(--font-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--dempet);
  margin: 1.25rem 0 0.5rem;
}
.seksjon-label:first-child { margin-top: 0; }

/* Skjul/vis felt (overnattingstur) */
.slutt-felt { display: none; }
.slutt-felt.vis { display: grid; }

/* Avmeld-seksjon */
.avmeld-detaljer { margin-top: 1.25rem; border-top: 1px solid var(--kant); padding-top: 1rem; }
.avmeld-detaljer summary { cursor: pointer; color: var(--dempet); font-size: var(--font-sm); margin-bottom: 1rem; }

/* Faresone */
.fare-sone { border-color: #fecaca !important; }
.fare-sone h2 { color: var(--roed); }

/* Inline-form (legg til tittel) */
.inline-form { display: flex; gap: 0.5rem; align-items: center; flex-wrap: wrap; margin-top: 0.75rem; }
.inline-form input {
  min-height: var(--input-h);
  padding: 0.55rem 0.75rem;
  border: 1px solid var(--kant);
  border-radius: 8px;
  font-size: var(--font-sm);
  font-family: inherit;
  background: var(--bg);
  color: var(--tekst);
  flex: 1;
  min-width: 100px;
  -webkit-appearance: none;
  box-sizing: border-box;
}

/* Identitet-rad (påmelding) */
.identitet-rad { display: flex; gap: 0.5rem; align-items: center; }
.identitet-rad input { flex: 1; }

/* ───────────────────────────────────────
   6. MELDINGER & BADGES
─────────────────────────────────────── */
.melding { padding: 0.75rem 1rem; border-radius: var(--radius); margin-bottom: 1rem; font-size: 0.95rem; }
.suksess { background: #f0fdf4; color: #15803d; border: 1px solid #bbf7d0; }
.feil    { background: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; }

.rank {
  display: inline-block;
  background: #eff6ff;
  color: #1e40af;
  padding: 0.15rem 0.5rem;
  border-radius: 4px;
  font-size: var(--font-xs);
  font-weight: 700;
  white-space: nowrap;
}
.overnatting-badge {
  display: inline-block;
  background: #fef3c7;
  color: #92400e;
  padding: 0.15rem 0.5rem;
  border-radius: 4px;
  font-size: var(--font-xs);
  font-weight: 600;
  white-space: nowrap;
}

/* ───────────────────────────────────────
   7. OFFENTLIG — TUROVERSIKT
─────────────────────────────────────── */
.tur-liste { display: flex; flex-direction: column; gap: 0.75rem; }

.tur-kort {
  background: var(--kort);
  border: 1px solid var(--kant);
  border-radius: var(--radius);
  padding: 1.2rem 1.4rem;
  text-decoration: none;
  color: inherit;
  display: block;
  transition: border-color .15s, box-shadow .15s;
}
.tur-kort:hover { border-color: var(--blaa); box-shadow: 0 2px 8px rgba(37,99,235,.08); }
.tur-dato        { font-size: var(--font-sm); color: var(--dempet); margin-bottom: 0.2rem; text-transform: capitalize; }
.tur-tittel      { font-weight: 600; font-size: 1.05rem; margin-bottom: 0.3rem; }
.tur-beskrivelse { color: var(--dempet); font-size: var(--font-sm); margin-bottom: 0.4rem; }
.tur-paameldte   { font-size: var(--font-xs); color: var(--gronn); font-weight: 600; }

.kalender-boks {
  margin-top: 2rem;
  background: var(--kort);
  border: 1px solid var(--kant);
  border-radius: var(--radius);
  padding: 1.2rem 1.4rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.kalender-boks code { background: var(--bg); padding: 0.2rem 0.5rem; border-radius: 4px; font-size: var(--font-sm); }

/* ───────────────────────────────────────
   8. OFFENTLIG — TURDETALJ
─────────────────────────────────────── */
.tur-meta-rad {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
  color: var(--dempet);
  margin-bottom: 1rem;
  font-size: var(--font-sm);
  text-transform: capitalize;
}

.oppmote-boks {
  background: var(--kort);
  border: 1px solid var(--kant);
  border-radius: var(--radius);
  padding: 1rem 1.2rem;
  margin-bottom: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.oppmote-boks strong { font-size: var(--font-xs); text-transform: uppercase; letter-spacing: 0.06em; color: var(--dempet); }
.kart-knapper { display: flex; gap: 0.5rem; margin-top: 0.5rem; flex-wrap: wrap; }

.beskrivelse { margin-bottom: 1.5rem; }

.to-kolonner { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin-top: 1.5rem; }

.paameldte-kort { background: var(--kort); border: 1px solid var(--kant); border-radius: var(--radius); padding: 1.5rem; }
.paameldt-liste { list-style: none; }
.paameldt-liste li { display: flex; align-items: center; gap: 0.5rem; padding: 0.45rem 0; border-bottom: 1px solid var(--kant); font-size: var(--font-sm); }
.paameldt-liste li:last-child { border-bottom: none; }

/* ───────────────────────────────────────
   9. ADMIN — TABELL & SIDEHODE
─────────────────────────────────────── */
.side-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.side-header h1 { margin-bottom: 0; }
.side-header-actions { display: flex; gap: 0.5rem; align-items: center; flex-wrap: wrap; }

.tabell { width: 100%; border-collapse: collapse; background: var(--kort); border-radius: var(--radius); overflow: hidden; border: 1px solid var(--kant); }
.tabell th { text-align: left; padding: 0.75rem 1rem; font-size: var(--font-xs); font-weight: 600; color: var(--dempet); border-bottom: 1px solid var(--kant); background: var(--bg); white-space: nowrap; }
.tabell td { padding: 0.75rem 1rem; border-bottom: 1px solid var(--kant); font-size: var(--font-sm); vertical-align: middle; }
.tabell tr:last-child td { border-bottom: none; }
.tabell tr:hover td { background: #fafaf9; }
.handlinger { display: flex; gap: 0.5rem; white-space: nowrap; }
.titler { font-size: var(--font-xs); color: var(--dempet); }

/* ───────────────────────────────────────
   10. ADMIN — DASHBOARD
─────────────────────────────────────── */
.stat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1.5rem; }
.stat-kort { background: var(--kort); border: 1px solid var(--kant); border-radius: var(--radius); padding: 1.5rem; text-align: center; text-decoration: none; color: inherit; transition: border-color .15s; }
.stat-kort:hover { border-color: var(--blaa); }
.stat-tall  { font-size: 2.5rem; font-weight: 700; color: var(--blaa); line-height: 1.1; }
.stat-label { color: var(--dempet); font-size: var(--font-sm); margin-top: 0.25rem; }
.hurtiglenker { display: flex; gap: 0.75rem; flex-wrap: wrap; }

/* ───────────────────────────────────────
   11. ADMIN — SESONG & STATISTIKK
─────────────────────────────────────── */
.sesong-badge { font-size: var(--font-sm); color: var(--dempet); }
.sesong-badge.ingen { font-style: italic; }

.sesong-select { height: var(--input-h); padding: 0 0.75rem; border: 1px solid var(--kant); border-radius: 8px; background: var(--kort); font-size: var(--font-sm); font-family: inherit; cursor: pointer; }

.prosent-bar-wrap { display: flex; align-items: center; gap: 0.75rem; }
.prosent-bar { height: 6px; background: var(--blaa); border-radius: 3px; min-width: 2px; max-width: 120px; }
.prosent-tall { font-size: var(--font-sm); color: var(--dempet); min-width: 38px; }

/* ───────────────────────────────────────
   12. ADMIN — TITLER & HISTORIKK
─────────────────────────────────────── */
.tittel-liste { list-style: none; margin-bottom: 1rem; }
.tittel-liste li { display: flex; justify-content: space-between; align-items: center; padding: 0.4rem 0; border-bottom: 1px solid var(--kant); font-size: var(--font-sm); }
.tittel-liste li:last-child { border-bottom: none; }

.aar-seksjon { margin-bottom: 2.5rem; }
.aar-overskrift { font-size: 1.3rem; font-weight: 700; margin-bottom: 1rem; padding-bottom: 0.5rem; border-bottom: 2px solid var(--kant); }
.tittel-kort-liste { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 0.75rem; }
.tittel-kort { background: var(--kort); border: 1px solid var(--kant); border-radius: var(--radius); padding: 1rem 1.2rem; }
.tittel-navn { font-weight: 600; margin-bottom: 0.4rem; font-size: var(--font-sm); }
.tittel-vinner { display: flex; align-items: center; gap: 0.4rem; text-decoration: none; color: var(--dempet); font-size: var(--font-sm); }
.tittel-vinner:hover { color: var(--blaa); }

.historikk-header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 1rem; gap: 1rem; }
.historikk-header h2 { margin-bottom: 0; }
.deltakelse-prosent { font-size: var(--font-sm); font-weight: 600; color: var(--gronn); white-space: nowrap; }

.tur-historikk { list-style: none; }
.tur-historikk li { display: flex; align-items: baseline; gap: 0.75rem; padding: 0.45rem 0; border-bottom: 1px solid var(--kant); font-size: var(--font-sm); }
.tur-historikk li:last-child { border-bottom: none; }
.historikk-dato { color: var(--dempet); min-width: 100px; white-space: nowrap; }
.tur-historikk a { color: var(--tekst); text-decoration: none; }
.tur-historikk a:hover { color: var(--blaa); }

/* ───────────────────────────────────────
   13. KART
─────────────────────────────────────── */
.kart-seksjon { margin-top: 1rem; }
.kart-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.5rem; font-size: var(--font-sm); font-weight: 500; }
.kart-hint { font-size: var(--font-xs); color: var(--dempet); margin-top: 0.4rem; }

/* ───────────────────────────────────────
   14. MARKDOWN
─────────────────────────────────────── */
.markdown h1, .markdown h2, .markdown h3 { margin: 1.5rem 0 0.5rem; font-weight: 700; }
.markdown h1 { font-size: 1.5rem; }
.markdown h2 { font-size: 1.25rem; }
.markdown h3 { font-size: 1.05rem; }
.markdown p  { margin-bottom: 1rem; }
.markdown ul, .markdown ol { margin: 0.5rem 0 1rem 1.5rem; }
.markdown li { margin-bottom: 0.25rem; }
.markdown strong { font-weight: 700; }
.markdown em { font-style: italic; }
.markdown a  { color: var(--blaa); }
.markdown hr { border: none; border-top: 1px solid var(--kant); margin: 1.5rem 0; }
.markdown blockquote { border-left: 3px solid var(--kant); padding-left: 1rem; color: var(--dempet); margin: 1rem 0; }
.markdown code { background: var(--bg); padding: 0.1rem 0.4rem; border-radius: 4px; font-size: 0.9em; }
.markdown pre  { background: var(--bg); padding: 1rem; border-radius: var(--radius); overflow-x: auto; margin-bottom: 1rem; }

/* ───────────────────────────────────────
   15. FOOTER
─────────────────────────────────────── */
footer { text-align: center; padding: 2rem; color: var(--dempet); font-size: var(--font-sm); }
footer a { color: var(--dempet); text-decoration: none; margin: 0 0.5rem; }

/* ───────────────────────────────────────
   16. MOBIL (max-width: 640px)
─────────────────────────────────────── */
@media (max-width: 640px) {
  /* Layout */
  .container { padding: 1.25rem 1rem; }
  h1 { font-size: 1.4rem; }

  /* Burgermeny */
  .burger { display: block; }
  .admin-nav .nav-links {
    display: none;
    flex-direction: column;
    position: absolute;
    top: 56px; left: 0; right: 0;
    background: #1e293b;
    padding: 1rem 1.5rem 1.5rem;
    gap: 0;
    z-index: 99;
    border-bottom: 1px solid #334155;
  }
  .admin-nav .nav-links.open { display: flex; }
  .admin-nav .nav-links a { padding: 0.75rem 0; border-bottom: 1px solid #334155; font-size: 1rem; width: 100%; }
  .admin-nav .nav-links a:last-child { border-bottom: none; }
  .admin-nav .nav-links .btn-liten { height: auto; justify-content: flex-start; background: transparent; border: none; border-radius: 0; border-bottom: 1px solid #334155; padding: 0.75rem 0; font-size: 1rem; }

  /* Offentlig nav */
  nav:not(.admin-nav) .nav-links { gap: 0.75rem; }
  nav:not(.admin-nav) .nav-links a { font-size: var(--font-sm); }

  /* Skjema */
  .skjema-kort { padding: 1.25rem; }
  .to-felt { grid-template-columns: 1fr; }
  .skjema-kort input,
  .skjema-kort select { max-width: 100%; -webkit-appearance: none; }
  .checkbox-label input[type="checkbox"] { -webkit-appearance: checkbox; width: 1.1rem; height: 1.1rem; flex-shrink: 0; }

  /* Inline-form */
  .inline-form { flex-direction: column; align-items: stretch; }
  .inline-form input { width: 100%; }

  /* Turdetalj */
  .to-kolonner { grid-template-columns: 1fr; gap: 1rem; }

  /* Tabeller */
  .tabell th, .tabell td { padding: 0.6rem 0.75rem; }
  .handlinger { flex-wrap: wrap; }

  /* Side-header */
  .side-header { flex-direction: column; align-items: flex-start; }
  .side-header-actions { width: 100%; }

  /* Div. */
  .hurtiglenker { flex-direction: column; }
  .hurtiglenker .btn { width: 100%; }
  .kalender-boks { flex-direction: column; align-items: flex-start; gap: 0.75rem; }
  .stat-tall { font-size: 2rem; }
  .prosent-bar { max-width: 60px; }
}

/* Lagt til: leaflet og kartsøk-regler fra tur-form */
.leaflet-tile { filter: saturate(0.7) brightness(1.05); }
.custom-pin { background: #2563eb; border: 3px solid #fff; border-radius: 50%; width: 16px; height: 16px; box-shadow: 0 2px 6px rgba(0,0,0,0.35); }

#kart { height: 280px; border-radius: var(--radius); border: 1px solid var(--kant); z-index: 1;}

#kart-sok-wrap { position: relative; margin-bottom: 0.5rem; }
#kart-sok { width: 100%; padding: 0.5rem 0.75rem 0.5rem 2.2rem; border: 1px solid var(--kant); border-radius: 6px; font-size: 0.9rem; background: var(--bg); color: var(--tekst); height: var(--input-h); box-sizing: border-box; }
#kart-sok:focus { outline: none; border-color: var(--blaa); box-shadow: 0 0 0 3px rgba(37,99,235,.1); }
.kart-sok-ikon { position: absolute; left: 0.6rem; top: 50%; transform: translateY(-50%); color: var(--dempet); font-size: 0.9rem; pointer-events: none; }
#kart-laster { position: absolute; right: 0.6rem; top: 50%; transform: translateY(-50%); color: var(--dempet); font-size: 0.8rem; display: none; }

#kart-forslag { position: absolute; top: 100%; left: 0; right: 0; background: var(--kort); border: 1px solid var(--kant); border-radius: 6px; margin-top: 2px; z-index: 20; max-height: 220px; overflow-y: auto; display: none; box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
#kart-forslag li { padding: 0.5rem 0.75rem; cursor: pointer; font-size: 0.85rem; list-style: none; border-bottom: 1px solid var(--kant); display: flex; align-items: center; gap: 0.5rem; }
#kart-forslag li:last-child { border-bottom: none; }
#kart-forslag li:hover { background: var(--bg); }
#kart-forslag li .forslag-ikon { font-size: 1rem; min-width: 1.2rem; text-align: center; }
#kart-forslag li .forslag-navn { font-weight: 500; }
#kart-forslag li .forslag-detalj { font-size: 0.78rem; color: var(--dempet); }
#kart-forslag .forslag-gruppe { padding: 0.3rem 0.75rem; font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--dempet); background: var(--bg); border-bottom: 1px solid var(--kant); }

.felt-gruppe-felt input[type="date"]::-webkit-calendar-picker-indicator,
.felt-gruppe-felt input[type="time"]::-webkit-calendar-picker-indicator { opacity: 0.5; }


.tittel-seksjon { margin-bottom: 2.5rem; }
.tittel-overskrift { font-size: 1.3rem; font-weight: 700; margin-bottom: 0.75rem; padding-bottom: 0.5rem; border-bottom: 2px solid var(--kant); }