/* KOED Værktøjsudlån – designprofil §2A */
:root {
  --guld: #BF9C5A;
  --guld-lys: #E9B770;
  --sort: #252322;
  --creme: #FAF8F3;
  --hvid: #FFFFFF;
  --header-baand: #A9936F;
  --terrakotta: #BC977E;
  --roed: #D37B7D;
  --graabrun: #988572;
  --linje: #E8E6E2;
  --groen: #4F9D69;
  --skygge: 0 2px 10px rgba(37,35,34,.10);
  --radius: 16px;
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body { margin: 0; height: 100%; }
body {
  font-family: "Segoe UI", system-ui, -apple-system, Arial, sans-serif;
  background: var(--creme);
  color: var(--sort);
  overflow-x: hidden;
  user-select: none;
}
button { font-family: inherit; cursor: pointer; }

/* ---------- Topbar ---------- */
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 18px; background: #DEDEDE;
  border-bottom: 2px solid var(--guld);
  position: sticky; top: 0; z-index: 50;
}
.topbar-left { display: flex; align-items: center; gap: 12px; }
.topbar-left img { height: 46px; }
.topbar-right { display: flex; align-items: center; gap: 14px; }
.bruger-navn { font-weight: 700; color: var(--guld); font-size: 18px; }
.ikon-knap {
  border: none; background: var(--creme); border-radius: 12px;
  width: 46px; height: 46px; font-size: 22px; display: grid; place-items: center;
  border: 1px solid var(--linje);
}
.ikon-knap:active { background: var(--linje); }
.logaf-knap {
  border: none; background: var(--roed); color: #fff; font-weight: 700;
  border-radius: 12px; padding: 0 16px; height: 46px; font-size: 15px;
}
.hidden { display: none !important; }

/* ---------- Rullende header ---------- */
.marquee {
  background: var(--header-baand); color: #fff; overflow: hidden;
  white-space: nowrap; padding: 7px 0; font-weight: 600;
}
.marquee span { display: inline-block; padding-left: 100%; animation: scroll 18s linear infinite; }
@keyframes scroll { to { transform: translateX(-100%); } }

/* ---------- Layout ---------- */
.view { padding: 22px; max-width: 1100px; margin: 0 auto; }
.view-titel { font-size: 26px; font-weight: 800; color: var(--guld); margin: 6px 0 20px; }
.sub { color: var(--graabrun); margin-top: -12px; margin-bottom: 18px; }

/* ---------- Hovedmenu ---------- */
.menu-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px;
  max-width: 640px; margin: 30px auto;
}
.menu-kort {
  background: var(--hvid); border: 2px solid var(--linje); border-radius: var(--radius);
  padding: 34px 18px; text-align: center; box-shadow: var(--skygge);
  display: flex; flex-direction: column; gap: 14px; align-items: center;
}
.menu-kort:active { transform: scale(.98); border-color: var(--guld); }
.menu-kort .emoji { font-size: 52px; }
.menu-kort .label { font-size: 20px; font-weight: 800; }

/* ---------- Kategori/ikon-grid ---------- */
.kat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 16px; }
.kat-kort {
  background: var(--hvid); border: 2px solid var(--linje); border-radius: var(--radius);
  padding: 22px 10px; text-align: center; box-shadow: var(--skygge);
}
.kat-kort:active { border-color: var(--guld); transform: scale(.98); }
.kat-kort .emoji { font-size: 40px; }
.kat-kort .label { margin-top: 8px; font-weight: 700; font-size: 15px; }

/* ---------- Personer ---------- */
.faner { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px; }
.fane {
  border: 2px solid var(--linje); background: var(--hvid); border-radius: 999px;
  padding: 9px 18px; font-weight: 700; color: var(--graabrun);
}
.fane.aktiv { background: var(--guld); border-color: var(--guld); color: #fff; }
.person-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 16px; }
.person-kort {
  background: var(--hvid); border: 2px solid var(--linje); border-radius: var(--radius);
  padding: 12px; text-align: center; box-shadow: var(--skygge);
}
.person-kort:active { border-color: var(--guld); }
.person-kort img {
  width: 84px; height: 84px; border-radius: 50%; object-fit: cover;
  border: 3px solid var(--guld); background: var(--creme);
}
.person-kort .navn { margin-top: 8px; font-weight: 700; font-size: 14px; }

/* ---------- Rulleliste / fritekst ---------- */
.felt-rk { max-width: 520px; margin: 0 auto; }
.felt-rk label { display: block; font-weight: 700; margin: 16px 0 6px; }
.felt-rk input, .felt-rk select, .felt-rk textarea {
  width: 100%; padding: 14px; font-size: 17px; border: 2px solid var(--linje);
  border-radius: 12px; background: var(--hvid); color: var(--sort);
}
.autocomplete-liste {
  border: 2px solid var(--linje); border-top: none; border-radius: 0 0 12px 12px;
  background: var(--hvid); max-height: 220px; overflow-y: auto;
}
.autocomplete-liste div { padding: 12px 14px; border-bottom: 1px solid var(--linje); }
.autocomplete-liste div:active { background: var(--creme); }

/* ---------- Store handlingsknapper ---------- */
.handling-rk { display: flex; gap: 14px; max-width: 520px; margin: 26px auto 0; }
.btn { flex: 1; border: none; border-radius: 14px; padding: 18px; font-size: 19px; font-weight: 800; }
.btn-laan { background: var(--groen); color: #fff; }
.btn-aflever { background: var(--guld-lys); color: var(--sort); }
.btn-tilbage { background: var(--hvid); border: 2px solid var(--linje); color: var(--sort); flex: 0 0 130px; }
.btn-primaer { background: var(--guld-lys); color: var(--sort); }
.btn-sekundaer { background: var(--hvid); border: 2px solid var(--linje); color: var(--sort); }
.btn:active { transform: scale(.98); }

/* ---------- Tabeller (Min Status / admin) ---------- */
.tabel-titel { font-weight: 800; font-size: 18px; margin: 20px 0 10px; }
table.data { width: 100%; border-collapse: collapse; background: var(--hvid); border-radius: 12px; overflow: hidden; box-shadow: var(--skygge); }
table.data th, table.data td { text-align: left; padding: 12px 14px; border-bottom: 1px solid var(--linje); font-size: 15px; }
table.data th { background: var(--creme); color: var(--graabrun); }
.rk-aktiv { background: rgba(211,123,125,.12); }
.spacer { height: 26px; }
.bem-ikon { font-size: 18px; cursor: pointer; }
.badge { display: inline-block; padding: 3px 10px; border-radius: 999px; font-size: 13px; font-weight: 700; }
.badge-ledig { background: rgba(79,157,105,.18); color: var(--groen); }
.badge-udlaant { background: rgba(211,123,125,.18); color: var(--roed); }
.badge-gul { background: rgba(233,183,112,.3); color: #8a6d2b; }
.badge-roed { background: rgba(211,123,125,.25); color: var(--roed); }
.skjult-raekke { opacity: .45; }

/* ---------- Beskedboks / modal ---------- */
.overlay {
  position: fixed; inset: 0; background: rgba(37,35,34,.55); backdrop-filter: blur(3px);
  display: grid; place-items: center; z-index: 100; padding: 20px;
}
.modal {
  background: var(--hvid); border-radius: 20px; padding: 28px; max-width: 440px; width: 100%;
  box-shadow: 0 20px 50px rgba(0,0,0,.3); text-align: center;
}
.modal h3 { margin: 0 0 12px; font-size: 22px; color: var(--guld); }
.modal p { font-size: 17px; line-height: 1.5; }
.modal-knapper { display: flex; flex-direction: column; gap: 10px; margin-top: 22px; }
.modal-knapper .btn { width: 100%; }
.nedtael { font-size: 46px; font-weight: 800; color: var(--guld); margin: 10px 0; }
.modal.groen h3 { color: var(--groen); }
.modal.roed h3 { color: var(--roed); }

/* ---------- PIN-pad ---------- */
.pin-visning { display: flex; gap: 12px; justify-content: center; margin: 18px 0; }
.pin-prik { width: 18px; height: 18px; border-radius: 50%; border: 2px solid var(--guld); }
.pin-prik.fyldt { background: var(--guld); }
.pin-pad { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; max-width: 280px; margin: 0 auto; }
.pin-tast { padding: 18px; font-size: 24px; font-weight: 700; border: 2px solid var(--linje); border-radius: 14px; background: var(--hvid); }
.pin-tast:active { background: var(--creme); }
.pin-fejl { color: var(--roed); font-weight: 700; min-height: 22px; }

/* ---------- Admin ---------- */
.admin-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 20px; }
.admin-tab { border: 2px solid var(--linje); background: var(--hvid); border-radius: 10px; padding: 10px 16px; font-weight: 700; color: var(--graabrun); }
.admin-tab.aktiv { background: var(--sort); color: #fff; border-color: var(--sort); }
.kort-panel { background: var(--hvid); border: 2px solid var(--linje); border-radius: var(--radius); padding: 20px; box-shadow: var(--skygge); margin-bottom: 18px; }
.kort-panel h4 { margin: 0 0 14px; color: var(--guld); }

@media (max-width: 560px) {
  .menu-grid { grid-template-columns: 1fr; }
  .handling-rk { flex-direction: column; }
  .btn-tilbage { flex: 1; }
}

/* ============================================================
   v2 – Galaxy Tab A 2016 liggende (1024×600) + mockup-layout
   ============================================================ */

/* Lås app-højde til viewport så alt er synligt uden scroll på tablet */
html, body { height: 100%; }
body { display: flex; flex-direction: column; min-height: 100%; }
#app { flex: 1 1 auto; overflow-y: auto; }

/* ---------- Topbar (3 zoner) ---------- */
.topbar { padding: 8px 16px; }
.topbar-left img { height: 42px; }
.topbar-midt { flex: 1; text-align: center; }
.bruger-navn { font-size: 22px; }
.bruger-navn.klikbar { cursor: pointer; text-decoration: underline dotted; }
.topbar-right { gap: 10px; }
.ikon-knap {
  width: 52px; height: 52px; border-radius: 12px; color: var(--sort);
  background: var(--hvid); border: 2px solid var(--linje);
}
.ikon-knap.guld { background: var(--guld-lys); border-color: var(--guld); color: var(--sort); }
.ikon-knap svg { display: block; }

/* ---------- Footer ---------- */
.footer {
  flex: 0 0 auto; text-align: center; padding: 8px; font-size: 13px;
  color: var(--graabrun); background: #DEDEDE; border-top: 1px solid var(--linje);
}

/* ---------- Index / gate ---------- */
.index-skaerm { min-height: 100%; display: grid; place-items: center; padding: 24px; }
.index-kort {
  background: var(--hvid); border: 2px solid var(--guld); border-radius: 22px;
  padding: 36px 40px; max-width: 440px; width: 100%; text-align: center; box-shadow: var(--skygge);
}
.index-logo { height: 70px; margin-bottom: 8px; }
.index-kort h1 { margin: 6px 0 2px; color: var(--guld); font-size: 28px; }
.index-sub { color: var(--graabrun); margin: 0 0 18px; }
.index-kort input {
  width: 100%; padding: 16px; font-size: 20px; text-align: center;
  border: 2px solid var(--linje); border-radius: 12px; margin-bottom: 8px;
}
.index-fejl { color: var(--roed); font-weight: 700; min-height: 22px; margin-bottom: 6px; }
.index-kort .btn { width: 100%; }

/* ---------- Hovedmenu: 2×2 tan-fliser som mockup ---------- */
.hjem-view { height: 100%; display: flex; align-items: center; }
.menu-grid {
  grid-template-columns: repeat(2, 1fr); gap: 28px;
  max-width: 760px; margin: 0 auto; width: 100%;
}
.menu-kort {
  background: transparent; border: none; box-shadow: none;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  padding: 0; cursor: pointer;
}
.menu-ikon {
  width: 100%; max-width: 200px; aspect-ratio: 1/1;
  display: grid; place-items: center; transition: transform .08s;
}
.menu-kort:active .menu-ikon { transform: scale(.97); }
.menu-ikon img { width: 100%; height: 100%; object-fit: contain; display: block; }
.menu-ikon svg { width: 56%; height: 56%; }
.menu-kort .label { font-size: 26px; font-weight: 800; color: #555; letter-spacing: .5px; }

/* ---------- Tablet-tilpasning (kort skærmhøjde, liggende) ---------- */
@media (max-height: 640px) {
  .topbar-left img { height: 36px; }
  .ikon-knap { width: 46px; height: 46px; }
  .menu-grid { gap: 18px; max-width: 680px; }
  .menu-ikon { max-width: 200px; }
  .menu-kort .label { font-size: 22px; }
  .view { padding: 14px 20px; }
  .view-titel { font-size: 22px; margin: 2px 0 12px; }
}

/* På brede tablets: hold 2×2 (overstyr den gamle 1-kolonne under 560px) */
@media (max-width: 560px) and (min-aspect-ratio: 13/10) {
  .menu-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Klikbare tabeller (aflever-liste, aktive lån) */
.klikbar-tabel tbody tr { cursor: pointer; }
.klikbar-tabel tbody tr:active { background: rgba(191,156,90,.18); }
/* Trailer-dropdown (låst kategori) */
#laastSelect { width: 100%; padding: 10px; font-size: 17px; border: 2px solid var(--linje); border-radius: 12px; }
#laastSelect option { padding: 8px; }

/* ============================================================
   v4 – Alt indhold centreret
   ============================================================ */
.view { text-align: center; }
.view-titel, .sub, .tabel-titel { text-align: center; }
.faner { justify-content: center; }
.kat-grid, .person-grid { justify-content: center; }
.felt-rk { text-align: center; }
.felt-rk label { text-align: center; }

/* Tabeller centreret + indhold centreret */
table.data { margin-left: auto; margin-right: auto; }
table.data th, table.data td { text-align: center; }

/* Handlingsknapper centreret; tilbage-knap centreret når den står alene */
.handling-rk { justify-content: center; }
.handling-rk:has(> #rodTilbage:only-child),
.handling-rk:has(> .btn-tilbage:only-child) { justify-content: center; }
#rodTilbage, .handling-rk > .btn-tilbage:only-child {
  flex: 0 0 auto; min-width: 200px;
}

/* Admin-tabs centreret */
.admin-tabs { justify-content: center; }
.kort-panel { text-align: center; }
.kort-panel h4 { text-align: center; }
