:root {
  --bg: #f6f7f9;
  --kort: #ffffff;
  --tekst: #1f2933;
  --primaer: #2563eb;
  --kant: #e3e8ef;
  --skygge: 0 1px 3px rgba(0, 0, 0, 0.08);
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  background: var(--bg);
  color: var(--tekst);
}
.topp {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.75rem 1.25rem;
  background: var(--kort);
  border-bottom: 1px solid var(--kant);
}
.topp h1 { font-size: 1.1rem; margin: 0; }
.topp nav { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.topp nav a {
  text-decoration: none;
  color: var(--tekst);
  padding: 0.35rem 0.7rem;
  border-radius: 6px;
  font-size: 0.9rem;
}
.topp nav a.aktiv { background: var(--primaer); color: #fff; }
.topp .hoyre { margin-left: auto; display: flex; gap: 0.75rem; align-items: center; }
main { padding: 1.5rem; max-width: 1000px; margin: 0 auto; }
.kort {
  background: var(--kort);
  border: 1px solid var(--kant);
  border-radius: 10px;
  padding: 1rem 1.25rem;
  box-shadow: var(--skygge);
}
.rutenett {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1rem;
}
.tall { font-size: 1.6rem; font-weight: 700; }
.etikett { color: #647084; font-size: 0.85rem; }
.innlogging {
  max-width: 340px;
  margin: 8vh auto;
}
.innlogging h1 { text-align: center; }
.felt { display: block; margin-bottom: 0.75rem; }
.felt span { display: block; font-size: 0.85rem; margin-bottom: 0.25rem; }
input {
  width: 100%;
  padding: 0.55rem 0.7rem;
  border: 1px solid var(--kant);
  border-radius: 6px;
  font-size: 1rem;
}
button {
  width: 100%;
  padding: 0.6rem;
  border: none;
  border-radius: 6px;
  background: var(--primaer);
  color: #fff;
  font-size: 1rem;
  cursor: pointer;
}
button.lenke { width: auto; background: none; color: var(--primaer); padding: 0; }
.feil { color: #b42318; font-size: 0.9rem; margin: 0.5rem 0; }

/* Tabeller */
.tabell { width: 100%; border-collapse: collapse; margin-top: 0.5rem; }
.tabell th, .tabell td {
  text-align: left;
  padding: 0.5rem 0.6rem;
  border-bottom: 1px solid var(--kant);
  font-size: 0.92rem;
}
.tabell th { color: #647084; font-weight: 600; }

/* Skjema-rad */
.skjema-rad { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; }
.skjema-rad input, .skjema-rad select { width: auto; flex: 1 1 130px; }
.skjema-rad input[type="number"] { flex: 0 1 90px; }
.skjema-rad button { width: auto; flex: 0 0 auto; }
.kort h2 { margin-top: 0; font-size: 1.05rem; }
.kort + .kort { margin-top: 1rem; }

/* Duplikat-farge-merker */
.badge { font-size: 0.85rem; padding: 0.2rem 0.45rem; border-radius: 6px; white-space: nowrap; }
.farge-gronn { background: #e7f6ec; color: #1a7f37; }
.farge-gul { background: #fff8e1; color: #8a6d00; }
.farge-oransje { background: #fff1e6; color: #b35309; }
.farge-rod { background: #fdecea; color: #b42318; }

/* Bilder-side */
.bilde-liste {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
  gap: 1rem;
}
.bilde-kort { display: flex; flex-direction: column; gap: 0.5rem; }
.miniatyr {
  width: 100%;
  height: 150px;
  object-fit: cover;
  border-radius: 8px;
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
}
.bilde-info { font-size: 0.9rem; line-height: 1.4; }

/* Topp-rad med tittel + handling */
.topp-rad { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.knapp-lenke {
  display: inline-block;
  text-decoration: none;
  background: var(--primaer);
  color: #fff;
  padding: 0.45rem 0.9rem;
  border-radius: 6px;
  font-size: 0.9rem;
}

/* Vipps-status på godkjente kjøp */
.status-ok { color: #067647; font-size: 0.85rem; }
.status-rod { color: #b42318; font-size: 0.85rem; font-weight: 600; }

.bok-merke { font-weight: 600; font-size: 0.9rem; }

/* Bilder: kjøper-godkjenning og manuell kjøper */
.kjoper-godkjenn table td { padding: 0.25rem; }
.kjoper-godkjenn table td input { width: 100%; padding: 0.55rem 0.6rem; font-size: 1rem; }
.kjoper-godkjenn .k-navn, .kjoper-godkjenn .k-tlf { min-width: 8.5rem; }
.kjoper-godkjenn .k-antall { max-width: 5rem; }
.kjoper-godkjenn .bok-input { width: 6rem; }
.manuell-kjoper { margin-top: 0.75rem; padding-top: 0.6rem; border-top: 1px dashed var(--kant); }
.manuell-felt { display: grid; grid-template-columns: 1fr 1fr; gap: 0.5rem; margin: 0.45rem 0 0.2rem; }
.manuell-felt input { padding: 0.55rem 0.6rem; font-size: 1rem; }
.manuell-felt .m-navn { grid-column: 1 / -1; }
.manuell-felt .legg-til-kjoper {
  grid-column: 1 / -1;
  padding: 0.45rem; border: none; border-radius: 6px;
  background: var(--primaer); color: #fff; font-size: 0.9rem; cursor: pointer;
}
.m-status { display: block; margin-top: 0.3rem; }

/* Selgere: bok-chips */
.bok-chips { display: flex; flex-wrap: wrap; gap: 0.3rem; margin-bottom: 0.4rem; }
.bok-chip {
  display: inline-flex; align-items: center; gap: 0.2rem;
  background: var(--bg); border: 1px solid var(--kant);
  border-radius: 999px; padding: 0.15rem 0.55rem; font-size: 0.85rem;
}
.legg-bok { display: flex; gap: 0.3rem; }
.legg-bok input { width: 7rem; }
.legg-bok button { width: auto; padding: 0.3rem 0.6rem; font-size: 0.85rem; }

/* Kamera: gjennomsiktig fil-input oppå en synlig knapp (trykk treffer inputen
   direkte → åpner kamera på mobil, uten JS). */
.kamera-wrap { position: relative; display: inline-block; }
.kamera-knapp {
  display: inline-flex; align-items: center; gap: 0.3rem;
  background: var(--primaer); color: #fff;
  padding: 0.6rem 0.9rem; border-radius: 6px;
  font-size: 1rem; cursor: pointer; white-space: nowrap; width: auto;
}
.kamera-overlay {
  position: absolute; inset: 0; width: 100%; height: 100%;
  opacity: 0; cursor: pointer; font-size: 16px;
}

/* Live-kamera-modal */
.kamera-modal {
  position: fixed; inset: 0; z-index: 1000;
  background: #000; display: flex; flex-direction: column;
}
.kamera-modal video { flex: 1; width: 100%; height: 100%; object-fit: contain; background: #000; }
.kamera-kontroller {
  display: flex; gap: 1rem; justify-content: center; align-items: center;
  padding: 1rem; background: #000;
}
.kamera-snap { width: auto; padding: 0.8rem 1.4rem; font-size: 1.1rem; }
.kamera-lukk { width: auto; padding: 0.8rem 1.2rem; background: #444; }
