/* ===== Filmsamlingen — design fra Lovable, ren CSS ===== */

:root {
  --bg: #000000;
  --surface: #0E0E0E;
  --card: #121212;
  --fg: #FFFFFF;
  --fg-soft: #F2F0EA;
  --muted: #A8A8A8;
  --primary: #F59E0B;
  --primary-fg: #0A0A0A;
  --gold: #D4A24E;
  --danger: #E5484D;
  --border: rgba(255, 255, 255, 0.08);
  --border-strong: rgba(255, 255, 255, 0.12);
  --radius: 0.5rem;
  --maxw: 28rem; /* max-w-md */
  --safe-top: env(safe-area-inset-top);
  --safe-bottom: env(safe-area-inset-bottom);
}

* { box-sizing: border-box; }

/* hidden-attribut skal altid skjule, også når en klasse sætter display */
[hidden] { display: none !important; }

html, body {
  margin: 0;
  padding: 0;
  overscroll-behavior-y: none;
}

body {
  background: var(--bg);
  color: var(--fg);
  font-family: "Inter", system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  padding-bottom: 6rem;
  min-height: 100vh;
}

*, button, a { -webkit-tap-highlight-color: transparent; }

.font-display {
  font-family: "Bebas Neue", "Inter", sans-serif;
  letter-spacing: 0.01em;
}

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
  border-radius: 4px;
}

/* ---------- Topbar ---------- */
.topbar {
  position: sticky; top: 0; z-index: 30;
  border-bottom: 1px solid var(--border);
  background: rgba(0,0,0,0.85);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
.topbar-inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: calc(var(--safe-top) + 0.75rem) 1rem 0.75rem;
}
.topbar-row { display: flex; align-items: baseline; justify-content: space-between; }
.brand {
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.875rem; line-height: 1; margin: 0;
  letter-spacing: 0.01em;
}
.count {
  font-size: 0.625rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.2em; color: var(--muted);
}
.searchrow { display: flex; align-items: center; gap: 0.5rem; margin-top: 0.75rem; }
.searchfield { position: relative; flex: 1; }
.searchicon {
  position: absolute; left: 0.75rem; top: 50%; transform: translateY(-50%);
  width: 1rem; height: 1rem; color: var(--muted); pointer-events: none;
}
.searchfield input {
  height: 2.75rem; width: 100%;
  border-radius: 9999px; border: 1px solid var(--border-strong);
  background: var(--surface); color: var(--fg);
  padding: 0 0.75rem 0 2.25rem; font-size: 0.875rem;
}
.searchfield input::placeholder { color: var(--muted); }
.searchfield input:focus { outline: none; border-color: rgba(245,158,11,0.5); }

.filterbtn {
  position: relative; display: grid; place-items: center;
  width: 2.75rem; height: 2.75rem; flex: 0 0 auto;
  border-radius: 9999px; border: 1px solid var(--border-strong);
  background: var(--surface); color: var(--fg);
}
.filterbtn svg { width: 1.25rem; height: 1.25rem; }
.filterbtn:active { background: rgba(255,255,255,0.05); }
.filterbadge[hidden] { display: none; }
.filterbadge {
  position: absolute; right: -2px; top: -2px;
  display: grid; place-items: center;
  width: 1.25rem; height: 1.25rem; border-radius: 9999px;
  background: var(--primary); color: var(--primary-fg);
  font-size: 0.625rem; font-weight: 700;
}

/* ---------- Container + grid ---------- */
.container { max-width: var(--maxw); margin: 0 auto; padding: 1.25rem 1rem 0; }
.grid {
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 1rem; row-gap: 1.75rem;
}

/* ---------- Poster card ---------- */
.card { display: block; }
.poster {
  position: relative; aspect-ratio: 2 / 3; overflow: hidden;
  border-radius: var(--radius); background: var(--surface);
  box-shadow: 0 20px 25px -5px rgba(0,0,0,0.4);
  outline: 1px solid rgba(255,255,255,0.05);
  transition: transform 0.3s cubic-bezier(0.16,1,0.3,1);
}
.card:active .poster { transform: scale(0.97); }
.poster img { width: 100%; height: 100%; object-fit: cover; display: block; }

.cover-fallback {
  width: 100%; height: 100%; display: flex; align-items: flex-end; padding: 0.75rem;
}
.cover-fallback .ctitle {
  font-family: "Bebas Neue", sans-serif; font-size: 1.5rem; line-height: 1;
  color: rgba(255,255,255,0.9);
}
.cover-fallback .cyear {
  margin-top: 0.25rem; font-size: 0.625rem; text-transform: uppercase;
  letter-spacing: 0.15em; color: rgba(255,255,255,0.5);
}
.cover-grad-1 { background: linear-gradient(135deg, #2D1B3D, #6B2B3F); }
.cover-grad-2 { background: linear-gradient(135deg, #1B2D3D, #2B5F6B); }
.cover-grad-3 { background: linear-gradient(135deg, #3D2D1B, #6B4F2B); }
.cover-grad-4 { background: linear-gradient(135deg, #1B3D2D, #2B6B4F); }
.cover-grad-5 { background: linear-gradient(135deg, #3D1B2D, #6B2B5F); }
.cover-grad-6 { background: linear-gradient(135deg, #2D2D1B, #5F6B2B); }

.badge-format {
  position: absolute; right: 0.375rem; top: 0.375rem;
  border-radius: 0.25rem; border: 1px solid rgba(255,255,255,0.15);
  background: rgba(0,0,0,0.7); backdrop-filter: blur(4px);
  padding: 0.125rem 0.375rem; font-size: 0.5625rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.15em; color: rgba(255,255,255,0.8);
}
.fav-dot {
  position: absolute; left: 0.375rem; top: 0.375rem;
  display: grid; place-items: center; width: 1.5rem; height: 1.5rem;
  border-radius: 9999px; background: rgba(0,0,0,0.7); backdrop-filter: blur(4px);
}
.fav-dot svg { width: 0.875rem; height: 0.875rem; fill: var(--primary); color: var(--primary); }

.card-meta { margin-top: 0.5rem; padding: 0 0.125rem; }
.card-title {
  font-size: 0.875rem; font-weight: 500; line-height: 1.2; margin: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--fg);
}
.card-sub {
  margin: 0.125rem 0 0; font-size: 0.6875rem; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--muted);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* ---------- Empty states ---------- */
.empty { text-align: center; margin-top: 6rem; }
.empty-title { font-family: "Bebas Neue", sans-serif; font-size: 1.5rem; margin: 0; }
.empty-sub { margin-top: 0.5rem; font-size: 0.875rem; color: var(--muted); }
.empty-icon {
  margin: 0 auto 1rem; display: grid; place-items: center;
  width: 3.5rem; height: 3.5rem; border-radius: 9999px;
  border: 1px solid var(--border-strong); background: var(--surface);
}
.empty-icon svg { width: 1.5rem; height: 1.5rem; color: var(--primary); }

/* ---------- Animation ---------- */
@keyframes fade-in-up { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.fade-in-up { animation: fade-in-up 0.5s cubic-bezier(0.16,1,0.3,1) both; }
@media (prefers-reduced-motion: reduce) {
  .fade-in-up { animation: none; }
  .poster, .card:active .poster { transition: none; transform: none; }
}

/* ---------- Bottom nav ---------- */
.bottomnav {
  position: fixed; inset: auto 0 0 0; z-index: 40;
  border-top: 1px solid var(--border);
  background: rgba(0,0,0,0.9);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  padding-bottom: var(--safe-bottom);
}
.bottomnav-inner { max-width: var(--maxw); margin: 0 auto; display: flex; }
.navitem {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  gap: 0.25rem; padding: 0.5rem 0;
  font-size: 0.625rem; text-transform: uppercase; letter-spacing: 0.15em;
  color: var(--muted); transition: color 0.15s;
}
.navitem.is-active { color: var(--primary); }
.navlabel { font-weight: 600; }
.navicon { display: grid; place-items: center; width: 1.5rem; height: 1.5rem; }
.navicon svg { width: 1.25rem; height: 1.25rem; }

/* ---------- Buttons ---------- */
.btn-primary {
  height: 3rem; width: 100%; border: none;
  border-radius: var(--radius); background: var(--primary); color: var(--primary-fg);
  font-size: 0.875rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.15em;
}
.btn-primary:disabled { opacity: 0.4; }

/* ---------- Filter sheet ---------- */
.sheet-overlay {
  position: fixed; inset: 0; z-index: 50;
  opacity: 0; pointer-events: none; transition: opacity 0.25s;
}
.sheet-overlay.is-open { opacity: 1; pointer-events: auto; }
.sheet-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.7); backdrop-filter: blur(2px); }
.sheet-panel {
  position: absolute; inset: auto 0 0 0; max-height: 88vh; overflow-y: auto;
  border-radius: 1rem 1rem 0 0; border-top: 1px solid var(--border-strong);
  background: var(--bg); box-shadow: 0 -10px 40px rgba(0,0,0,0.6);
  padding-bottom: calc(var(--safe-bottom) + 1rem);
  transform: translateY(100%); transition: transform 0.3s cubic-bezier(0.16,1,0.3,1);
}
.sheet-overlay.is-open .sheet-panel { transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  .sheet-overlay, .sheet-panel { transition: none; }
}
.sheet-head { position: sticky; top: 0; z-index: 10; background: var(--bg); padding: 0.5rem 0; }
.sheet-grip { width: 2.5rem; height: 0.25rem; border-radius: 9999px; background: rgba(255,255,255,0.15); margin: 0 auto; }
.sheet-head-row { display: flex; align-items: center; justify-content: space-between; padding: 0.75rem 1.25rem 0; }
.sheet-title { font-family: "Bebas Neue", sans-serif; font-size: 1.5rem; margin: 0; }
.sheet-reset, .sheet-done {
  background: none; border: none; font-size: 0.6875rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.15em;
}
.sheet-reset { color: var(--muted); }
.sheet-done { color: var(--primary); }
.sheet-body { padding: 0.75rem 1.25rem 0; display: flex; flex-direction: column; gap: 1.75rem; }
.flabel {
  margin: 0 0 0.75rem; font-size: 0.625rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.2em; color: var(--muted);
}
.chips { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.chip {
  min-height: 36px; border-radius: 9999px; border: 1px solid var(--border-strong);
  background: var(--surface); color: rgba(242,240,234,0.8);
  padding: 0.375rem 0.75rem; font-size: 0.75rem; font-weight: 500;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.chip:active { background: rgba(255,255,255,0.05); }
.chip.is-active { border-color: var(--primary); background: var(--primary); color: var(--primary-fg); }
.sheet-foot {
  position: sticky; bottom: 0; margin-top: 1.5rem;
  border-top: 1px solid var(--border); background: rgba(0,0,0,0.95);
  backdrop-filter: blur(8px); padding: 0.75rem 1.25rem 0.5rem;
}

/* ---------- Film detail ---------- */
.film-hero { position: relative; }
.film-hero-img { position: relative; height: 62vh; width: 100%; overflow: hidden; }
.film-hero-img img, .film-hero-img .cover-grad { width: 100%; height: 100%; object-fit: cover; }
.film-hero-img .cover-grad { display: block; }
.film-hero-fade {
  position: absolute; inset: 0;
  background: linear-gradient(to top, var(--bg), rgba(0,0,0,0.7) 45%, rgba(0,0,0,0.1));
}
.film-topbar {
  position: absolute; inset: 0 0 auto 0; display: flex; align-items: center;
  justify-content: space-between; padding: calc(var(--safe-top) + 0.75rem) 1rem 0;
}
.iconbtn {
  display: grid; place-items: center; width: 2.5rem; height: 2.5rem;
  border-radius: 9999px; border: 1px solid var(--border-strong);
  background: rgba(0,0,0,0.6); backdrop-filter: blur(8px); color: var(--fg);
}
.iconbtn svg { width: 1.25rem; height: 1.25rem; }
.iconbtn.is-fav { border-color: rgba(245,158,11,0.5); background: rgba(245,158,11,0.2); }
.iconbtn.is-fav svg { fill: var(--primary); color: var(--primary); }

.film-main { margin-top: -5rem; padding: 0 1.25rem; position: relative; z-index: 1; }
.film-inner { max-width: var(--maxw); margin: 0 auto; display: flex; flex-direction: column; gap: 1.5rem; }
.film-metaline {
  display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem; margin-bottom: 0.5rem;
  font-size: 0.625rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.2em;
  color: var(--muted);
}
.film-metaline .dot { color: rgba(255,255,255,0.2); }
.film-metaline .rating { color: var(--gold); }
.film-title { font-family: "Bebas Neue", sans-serif; font-size: 3rem; line-height: 1; margin: 0; }
.film-director { margin: 0.75rem 0 0; font-size: 1rem; color: var(--muted); }
.film-director strong { color: var(--fg); font-weight: 500; }

.tagrow { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.tag-format {
  border-radius: 0.25rem; border: 1px solid rgba(245,158,11,0.4);
  background: rgba(245,158,11,0.1); color: var(--primary);
  padding: 0.25rem 0.5rem; font-size: 0.625rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.15em;
}
.tag-genre {
  border-radius: 9999px; border: 1px solid var(--border-strong);
  background: var(--surface); color: rgba(242,240,234,0.8);
  padding: 0.25rem 0.75rem; font-size: 0.75rem;
}

.film-section h2 {
  margin: 0 0 0.5rem; font-size: 0.625rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.2em; color: var(--muted);
}
.film-desc { font-size: 0.9375rem; line-height: 1.6; color: rgba(242,240,234,0.9); margin: 0; }

.film-grid2 {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1rem;
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 1.25rem 0;
}
.meta-label { font-size: 0.625rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.2em; color: var(--muted); }
.meta-value { margin-top: 0.25rem; font-size: 0.875rem; color: var(--fg); }

/* Rating block */
.rating-block { display: flex; flex-direction: column; gap: 0.75rem; padding-bottom: 1.5rem; }
.rating-head { display: flex; align-items: center; justify-content: space-between; }
.rating-reset { background: none; border: none; font-size: 0.625rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.15em; color: var(--muted); }
.stars { display: flex; gap: 0.25rem; }
.star {
  display: grid; place-items: center; width: 3rem; height: 3rem;
  background: none; border: none; font-size: 1.875rem; line-height: 1;
  color: rgba(255,255,255,0.15);
}
.star.on { color: var(--gold); }
.rating-hint { font-size: 0.75rem; color: var(--muted); margin: 0; }

/* ---------- Tilføj ---------- */
.page-head {
  position: sticky; top: 0; z-index: 30; border-bottom: 1px solid var(--border);
  background: rgba(0,0,0,0.85); backdrop-filter: blur(16px);
}
.page-head-inner {
  max-width: var(--maxw); margin: 0 auto; display: flex; align-items: center; gap: 0.75rem;
  padding: calc(var(--safe-top) + 0.75rem) 1rem 1rem;
}
.page-title { font-family: "Bebas Neue", sans-serif; font-size: 1.875rem; margin: 0; }
.backbtn {
  display: grid; place-items: center; width: 2.25rem; height: 2.25rem; flex: 0 0 auto;
  border-radius: 9999px; border: 1px solid var(--border-strong); background: var(--surface); color: var(--fg);
}
.backbtn svg { width: 1.25rem; height: 1.25rem; }

.stack { max-width: var(--maxw); margin: 0 auto; padding: 1.5rem 1.25rem 0; display: flex; flex-direction: column; gap: 1rem; }
.bigchoice {
  display: flex; align-items: center; gap: 1rem; width: 100%; text-align: left;
  border-radius: 0.75rem; border: 1px solid var(--border-strong); background: var(--surface);
  padding: 1rem; color: var(--fg);
}
.bigchoice:active { background: rgba(255,255,255,0.05); }
.bigchoice-icon { display: grid; place-items: center; width: 3rem; height: 3rem; border-radius: 0.5rem; flex: 0 0 auto; }
.bigchoice-icon.primary { background: rgba(245,158,11,0.15); color: var(--primary); }
.bigchoice-icon.plain { background: rgba(255,255,255,0.05); color: var(--fg); }
.bigchoice-icon svg { width: 1.5rem; height: 1.5rem; }
.bigchoice-title { font-family: "Bebas Neue", sans-serif; font-size: 1.25rem; line-height: 1; }
.bigchoice-sub { margin-top: 0.25rem; font-size: 0.75rem; color: var(--muted); }
.hint { font-size: 0.75rem; line-height: 1.5; color: var(--muted); padding: 0 0.25rem; }

.field { display: block; }
.field-label { margin-bottom: 0.375rem; font-size: 0.625rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.2em; color: var(--muted); }
.input, .textarea {
  width: 100%; border-radius: var(--radius); border: 1px solid var(--border-strong);
  background: var(--surface); color: var(--fg); padding: 0 0.75rem; font-size: 0.875rem; font-family: inherit;
}
.input { height: 2.75rem; }
.textarea { min-height: 100px; padding: 0.5rem 0.75rem; line-height: 1.5; }
.input::placeholder, .textarea::placeholder { color: var(--muted); }
.input:focus, .textarea:focus { outline: none; border-color: rgba(245,158,11,0.5); }
.row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }

/* TMDb resultater */
.result {
  display: flex; gap: 0.75rem; width: 100%; text-align: left;
  border-radius: 0.5rem; border: 1px solid var(--border); background: var(--surface);
  padding: 0.625rem; color: var(--fg);
}
.result:active { background: rgba(255,255,255,0.05); }
.result img, .result .result-noimg {
  width: 3rem; height: 4.5rem; object-fit: cover; border-radius: 0.25rem; flex: 0 0 auto; background: var(--card);
}
.result-title { font-weight: 600; font-size: 0.875rem; }
.result-sub { font-size: 0.75rem; color: var(--muted); margin-top: 0.125rem; }

.scanwrap { display: flex; flex-direction: column; gap: 1rem; }
.scanview {
  position: relative; aspect-ratio: 3 / 4; width: 100%; overflow: hidden;
  border-radius: 0.75rem; border: 1px solid var(--border-strong); background: var(--surface);
}
.scanview video { width: 100%; height: 100%; object-fit: cover; }
.scanframe {
  position: absolute; inset: 0; display: grid; place-items: center; pointer-events: none;
}
.scanframe div {
  width: 14rem; height: 8rem; border-radius: 0.375rem; border: 2px solid rgba(245,158,11,0.8);
  box-shadow: 0 0 0 9999px rgba(0,0,0,0.45);
}
.scan-hit { position: absolute; inset: auto 0 0 0; background: var(--primary); color: var(--primary-fg); padding: 0.75rem; text-align: center; font-weight: 700; }
.alert {
  border-radius: var(--radius); padding: 0.75rem; font-size: 0.875rem;
  border: 1px solid rgba(229,72,77,0.3); background: rgba(229,72,77,0.1); color: var(--danger);
}
.note {
  border-radius: var(--radius); border: 1px solid var(--border);
  background: var(--surface); padding: 0.5rem 0.75rem; font-size: 0.6875rem;
  line-height: 1.5; color: var(--muted);
}
.toast {
  position: fixed; left: 50%; bottom: 6rem; transform: translateX(-50%);
  background: var(--card); color: var(--fg); border: 1px solid var(--border-strong);
  border-radius: 9999px; padding: 0.625rem 1.25rem; font-size: 0.875rem; z-index: 60;
  box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}

.spinner {
  width: 1.5rem; height: 1.5rem; border-radius: 50%;
  border: 2px solid var(--border-strong); border-top-color: var(--primary);
  animation: spin 0.7s linear infinite; margin: 2rem auto;
}
@keyframes spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .spinner { animation-duration: 2s; } }
