/* =========================================================
   MOVIES.PHP - extra CSS (add to your main style.css)
   Uses theme vars from generateThemeCSS + your existing CSS.
========================================================= */

/* Page shell helpers (if not present) */
.movies-hero{ padding-top: calc(var(--header-height, 80px) + 70px); padding-bottom: 30px; }
.movies-hero .kicker{
  font-family: var(--font-accent, var(--font-body, 'Segoe UI', sans-serif));
  font-size: 12px;
  letter-spacing: .10em;
  text-transform: uppercase;
  opacity: .9;
  margin-bottom: 12px;
}

.movies-lead{ max-width: 980px; color: var(--text, #1a1a1a); opacity: .92; }

.movies-grid{ display:grid; grid-template-columns: 1fr 1.1fr; gap: 22px; align-items: start; }
@media (max-width: 1050px){ .movies-grid{ grid-template-columns: 1fr; } }

.movies-card{
  background: rgba(255,255,255,.78);
  border: 3px solid var(--comic-border, #111);
  border-radius: 18px;
  box-shadow: var(--comic-shadow, 4px 4px 0 #111);
  backdrop-filter: blur(6px);
  overflow: hidden;
}

.movies-card__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
  padding: 18px 18px 12px;
  background: linear-gradient(135deg, rgba(255,255,255,.35), rgba(255,255,255,.0));
}

.movies-card__title{
  margin:0;
  font-family: var(--font-heading, 'Segoe UI', sans-serif);
  letter-spacing: .03em;
  font-size: clamp(20px, 2.1vw, 30px);
}

.movies-card__meta{ display:flex; flex-wrap:wrap; gap: 10px; align-items:center; }

.movies-badge{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 12px;
  border: 3px solid var(--comic-border, #111);
  border-radius: 999px;
  background: var(--panel, #fff);
  box-shadow: var(--comic-shadow-small, 2px 2px 0 #111);
  font-weight: 800;
}

.movies-card__body{ padding: 16px 18px 18px; }

.movies-actions{ display:flex; gap: 10px; flex-wrap: wrap; }
.movies-actions .btn{ white-space: nowrap; }

.movies-filters{ display:grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 620px){ .movies-filters{ grid-template-columns: 1fr; } }

.movies-field label{
  display:block;
  font-weight: 900;
  margin-bottom: 6px;
  letter-spacing: .02em;
}

.movies-field select,
.movies-field input[type="text"],
.movies-field input[type="number"]{
  width:100%;
  padding: 10px 12px;
  border: 3px solid var(--comic-border, #111);
  border-radius: 14px;
  background: rgba(255,255,255,.85);
  font-family: var(--font-body, 'Segoe UI', sans-serif);
  box-shadow: var(--comic-shadow-small, 2px 2px 0 #111);
}

.movies-field small{ display:block; margin-top: 6px; color: var(--muted, #666); font-size: 12px; }

.movies-toggles{ display:flex; flex-wrap:wrap; gap: 10px; margin-top: 6px; }
.movies-toggle{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 8px 12px;
  border: 3px solid var(--comic-border, #111);
  border-radius: 999px;
  background: rgba(255,255,255,.86);
  box-shadow: var(--comic-shadow-small, 2px 2px 0 #111);
  cursor: pointer;
  user-select: none;
}
.movies-toggle input{ width: 18px; height: 18px; }
.movies-toggle--danger{ background: rgba(255, 59, 59, .10); }

/* Dice */
.dice-wrap{ display:flex; gap: 16px; align-items:center; justify-content:flex-end; }
@media (max-width: 1050px){ .dice-wrap{ justify-content:flex-start; } }

.dice-btn{
  width: 88px;
  height: 88px;
  border: none;
  background: transparent;
  cursor: pointer;
  padding: 0;
}

.dice-stage{
  width: 88px;
  height: 88px;
  perspective: 680px;
}

.dice{
  width: 88px;
  height: 88px;
  position: relative;
  transform-style: preserve-3d;
  transition: transform 900ms cubic-bezier(.2,.9,.2,1);
  animation: dice-float 3.2s ease-in-out infinite;
}

@keyframes dice-float{
  0%,100%{ transform: translateY(0) rotateX(18deg) rotateY(28deg); }
  50%{ transform: translateY(-6px) rotateX(22deg) rotateY(34deg); }
}

.dice-face{
  position:absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.95), rgba(255,255,255,.70));
  border: 4px solid var(--comic-border, #111);
  border-radius: 18px;
  box-shadow: var(--comic-shadow, 4px 4px 0 #111);
  display:flex;
  align-items:center;
  justify-content:center;
}

.dice-face::after{
  content: '';
  position:absolute;
  inset: 10px;
  border-radius: 14px;
  border: 3px dashed rgba(0,0,0,.18);
}

/* Pips */
.pips{ width: 60px; height: 60px; display:grid; grid-template-columns: repeat(3, 1fr); grid-template-rows: repeat(3, 1fr); gap: 8px; }
.pip{ width: 12px; height: 12px; border-radius: 50%; background: var(--primary, #ff3b3b); box-shadow: 2px 2px 0 var(--comic-border, #111); opacity: 0; justify-self:center; align-self:center; }

/* helper class to show pips */
.show{ opacity: 1; }

/* 3D positions */
.face-1{ transform: translateZ(44px); }
.face-2{ transform: rotateY(90deg) translateZ(44px); }
.face-3{ transform: rotateY(180deg) translateZ(44px); }
.face-4{ transform: rotateY(-90deg) translateZ(44px); }
.face-5{ transform: rotateX(90deg) translateZ(44px); }
.face-6{ transform: rotateX(-90deg) translateZ(44px); }

/* Orientation classes (set by JS) */
.dice--show1{ transform: translateY(0) rotateX(18deg) rotateY(28deg); }
.dice--show2{ transform: translateY(0) rotateY(-90deg) rotateX(10deg); }
.dice--show3{ transform: translateY(0) rotateY(180deg) rotateX(10deg); }
.dice--show4{ transform: translateY(0) rotateY(90deg) rotateX(10deg); }
.dice--show5{ transform: translateY(0) rotateX(-90deg) rotateY(10deg); }
.dice--show6{ transform: translateY(0) rotateX(90deg) rotateY(10deg); }

.dice.is-rolling{
  animation: dice-roll 900ms cubic-bezier(.15,.8,.2,1);
}

@keyframes dice-roll{
  0%{ transform: rotateX(25deg) rotateY(30deg) translateY(0); }
  35%{ transform: rotateX(320deg) rotateY(210deg) translateY(-8px); }
  70%{ transform: rotateX(540deg) rotateY(420deg) translateY(-4px); }
  100%{ transform: rotateX(18deg) rotateY(28deg) translateY(0); }
}

.dice-hint{ max-width: 420px; color: var(--muted, #666); font-size: 12px; }

/* Result panel inside films modal */
.movie-night-result{
  margin: 16px 20px 0;
  border: 3px solid var(--comic-border, #111);
  border-radius: 18px;
  box-shadow: var(--comic-shadow, 4px 4px 0 #111);
  background: rgba(255,255,255,.90);
  overflow:hidden;
}

.movie-night-result__head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 10px;
  padding: 12px 14px;
  background: linear-gradient(135deg, rgba(255,59,59,.12), rgba(0,168,255,.10));
  border-bottom: 3px solid var(--comic-border, #111);
}

.movie-night-chip{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 6px 10px;
  border: 3px solid var(--comic-border, #111);
  border-radius: 999px;
  box-shadow: var(--comic-shadow-small, 2px 2px 0 #111);
  font-weight: 900;
  background: var(--panel, #fff);
}

.movie-night-result__body{ padding: 14px; display:grid; grid-template-columns: 120px 1fr; gap: 14px; }
@media (max-width: 560px){ .movie-night-result__body{ grid-template-columns: 1fr; } }

.movie-night-poster{
  width: 120px;
  height: 160px;
  border-radius: 14px;
  border: 3px solid var(--comic-border, #111);
  box-shadow: var(--comic-shadow-small, 2px 2px 0 #111);
  object-fit: cover;
  background: rgba(0,0,0,.06);
}

.movie-night-title{ margin:0 0 6px; font-family: var(--font-heading, 'Segoe UI', sans-serif); font-size: 26px; letter-spacing: .02em; }
.movie-night-meta{ display:flex; flex-wrap:wrap; gap: 10px; color: var(--muted, #666); font-size: 13px; margin-bottom: 8px; }
.movie-night-plot{ margin:0; line-height: 1.55; }

/* Make the films modal feel more "arcade" */
.films-modal-title i{ filter: drop-shadow(2px 2px 0 var(--comic-border, #111)); }
.films-modal-subtitle{ opacity: .9; }

/* Small neon-ish emphasis without overriding your theme */
.movies-neon{
  position: relative;
  display:inline-block;
}
.movies-neon::after{
  content:'';
  position:absolute;
  left: -6px; right: -6px; bottom: -4px;
  height: 10px;
  background: rgba(255, 215, 0, .35);
  filter: blur(6px);
  z-index: -1;
  border-radius: 999px;
}


/* =============================
   v3: OMDb RNG (main pick + shortlist) + nicer quests grid
============================= */

/* Side Quests grid (responsive) */
.movies-quests .mn-quest-grid{
  max-width: 1120px;
  margin-left: auto;
  margin-right: auto;
  display: grid;
  grid-template-columns: repeat(4, minmax(220px, 1fr));
  gap: 18px;
  align-items: stretch;
}
@media (max-width: 1100px){
  .movies-quests .mn-quest-grid{ grid-template-columns: repeat(2, minmax(240px, 1fr)); }
}
@media (max-width: 560px){
  .movies-quests .mn-quest-grid{ grid-template-columns: 1fr; }
}

/* OMDb results headings */
#omdbModal .omdb-results-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin: 6px 0 12px;
}
#omdbModal .omdb-results-head--sub{ margin-top: 18px; }

#omdbModal .omdb-results-title h3{
  margin: 0;
  font-family: var(--font-heading);
  letter-spacing: 1px;
  color: var(--primary);
  text-shadow: 2px 2px 0 var(--comic-border);
}
#omdbModal .omdb-results-sub{
  margin: 6px 0 0;
  color: var(--text-light);
  font-size: .95rem;
}

/* Main pick container */
#omdbModal .omdb-main{ margin-bottom: 8px; }
#omdbModal .omdb-empty{
  padding: 14px;
  border: 3px dashed var(--comic-border);
  border-radius: 16px;
  background: rgba(255,255,255,.75);
  color: var(--text-light);
  font-family: var(--font-accent);
}

/* Main pick: bigger card */
#omdbModal .film-card--main{
  border-width: 5px;
  background: rgba(255,255,255,.92);
}
#omdbModal .film-card--main::after{
  content:"MAIN PICK";
  position:absolute;
  top: 14px;
  right: 14px;
  background: rgba(255,215,0,.9);
  border: 3px solid var(--comic-border);
  border-radius: 999px;
  padding: 6px 10px;
  font-family: var(--font-accent);
  font-weight: 900;
  font-size: .75rem;
  box-shadow: var(--comic-shadow-small);
  transform: rotate(2deg);
}
#omdbModal .film-card--main .film-title{ font-size: 2.0rem; }
#omdbModal .film-card--main .film-poster-wrap{ width: 140px; flex: 0 0 140px; }
#omdbModal .film-card--main .film-poster{ width: 140px; border-radius: 16px; }

/* Shortlist count pill */
#omdbModal .omdb-count{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 6px 10px;
  border: 3px solid var(--comic-border);
  border-radius: 999px;
  background: rgba(255,255,255,.85);
  box-shadow: var(--comic-shadow-small);
  font-family: var(--font-accent);
  font-weight: 900;
  font-size: .85rem;
}

/* Clickable shortlist cards */
#omdbModal .film-card[data-promote="1"]{ cursor: pointer; }
#omdbModal .film-card[data-promote="1"]:hover{
  outline: 3px solid rgba(255,215,0,.8);
  outline-offset: -3px;
}

/* Mobile: main pick goes vertical */
@media (max-width: 520px){
  #omdbModal .film-card--main .film-card-main{ flex-direction: column; }
  #omdbModal .film-card--main .film-poster-wrap{ width: 100%; flex: 0 0 auto; }
  #omdbModal .film-card--main .film-poster{ width: 100%; max-width: 280px; }
}

#omdbModal .film-poster--empty{ width:110px; height:160px; display:block; border-radius:14px; border:3px solid var(--comic-border); box-shadow: var(--comic-shadow-small); background: repeating-linear-gradient(45deg, rgba(0,0,0,.05), rgba(0,0,0,.05) 10px, rgba(0,0,0,.02) 10px, rgba(0,0,0,.02) 20px); }


/* =============================
   v4: UI polish (opmaak-fixes)
   - Side quests cards kregen geen styling
   - Hero dice gebruikte andere class names dan de CSS
   - OMDb modal: filters + results moeten Filmkluis look krijgen
============================= */

/* --- Hero visual card (rechts) --- */
.movies-visual-card{
  background: rgba(255,255,255,.78);
  border: 3px solid var(--comic-border, #111);
  border-radius: 18px;
  box-shadow: var(--comic-shadow, 4px 4px 0 #111);
  backdrop-filter: blur(6px);
  padding: 16px 18px;
}

.movies-visual-top{ display:flex; gap: 10px; align-items:center; margin-bottom: 10px; }
.movies-visual-top .tag{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 6px 10px;
  border: 3px solid var(--comic-border, #111);
  border-radius: 999px;
  background: rgba(255,255,255,.86);
  box-shadow: var(--comic-shadow-small, 2px 2px 0 #111);
  font-family: var(--font-accent, var(--font-body));
  font-weight: 900;
}

.movies-visual-title{ margin: 6px 0 6px; font-family: var(--font-heading); font-size: 1.4rem; text-shadow: 2px 2px 0 var(--comic-border); }
.movies-visual-sub{ margin-bottom: 8px; }
.movies-visual-sub .chip{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 6px 10px;
  border: 3px solid var(--comic-border, #111);
  border-radius: 999px;
  background: rgba(255,215,0,.26);
  box-shadow: var(--comic-shadow-small, 2px 2px 0 #111);
  font-weight: 900;
}

.movies-visual-text{ margin: 0 0 12px; color: var(--text, #111); opacity: .9; }

/* --- Hero dice button (fix: markup gebruikt .dice-btn-inline + .dice__side) --- */
.dice-btn-inline{
  width: 100%;
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 14px;
  padding: 12px 14px;
  border: 3px solid var(--comic-border, #111);
  border-radius: 16px;
  background: rgba(255,255,255,.86);
  box-shadow: var(--comic-shadow, 4px 4px 0 #111);
  cursor: pointer;
}
.dice-btn-inline:hover{ transform: translate(-2px,-2px); box-shadow: 8px 8px 0 var(--comic-border, #111); }

.dice-btn-inline .dice-wrap{
  width: 88px;
  height: 88px;
  display:flex;
  align-items:center;
  justify-content:center;
  perspective: 680px;
}

.dice-btn-inline .dice{
  width: 72px;
  height: 72px;
  position: relative;
  transform-style: preserve-3d;
  transition: transform 900ms cubic-bezier(.2,.9,.2,1);
}

.dice-btn-inline .dice__side{
  position:absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.95), rgba(255,255,255,.70));
  border: 4px solid var(--comic-border, #111);
  border-radius: 16px;
  box-shadow: var(--comic-shadow-small, 2px 2px 0 #111);
}

/* Cube faces */
.dice-btn-inline .dice__side--1{ transform: translateZ(36px); }
.dice-btn-inline .dice__side--2{ transform: rotateY(90deg) translateZ(36px); }
.dice-btn-inline .dice__side--3{ transform: rotateY(180deg) translateZ(36px); }
.dice-btn-inline .dice__side--4{ transform: rotateY(-90deg) translateZ(36px); }
.dice-btn-inline .dice__side--5{ transform: rotateX(90deg) translateZ(36px); }
.dice-btn-inline .dice__side--6{ transform: rotateX(-90deg) translateZ(36px); }

.dice-btn-inline .dice-label{
  font-family: var(--font-accent, var(--font-body));
  font-weight: 900;
  letter-spacing: .02em;
  white-space: nowrap;
}

/* --- Side Quests (cards) --- */
.movies-quests{
  padding: 54px 0 70px;
  background: repeating-linear-gradient(45deg,
    rgba(0,0,0,.03), rgba(0,0,0,.03) 14px,
    rgba(255,255,255,.18) 14px, rgba(255,255,255,.18) 28px);
  border-top: 4px solid var(--comic-border, #111);
  border-bottom: 4px solid var(--comic-border, #111);
}

.movies-quests .section-title{ text-align:center; margin-bottom: 22px; }

.mn-quest-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(220px, 1fr));
  gap: 18px;
  align-items: stretch;
}
@media (max-width: 1100px){ .mn-quest-grid{ grid-template-columns: repeat(2, minmax(240px, 1fr)); } }
@media (max-width: 560px){ .mn-quest-grid{ grid-template-columns: 1fr; } }

.mn-card{
  background: rgba(255,255,255,.92);
  border: 4px solid var(--comic-border, #111);
  border-radius: 18px;
  box-shadow: var(--comic-shadow, 4px 4px 0 #111);
  padding: 14px;
  position: relative;
  overflow: hidden;
}

.mn-card::before{
  content:"";
  position:absolute;
  top:-10px; left:-10px; right:-10px;
  height:6px;
  background: linear-gradient(90deg, var(--primary), var(--secondary), var(--accent));
  opacity:.9;
}

.mn-card-icon{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 4px solid var(--comic-border, #111);
  background: rgba(255,215,0,.85);
  box-shadow: var(--comic-shadow-small, 2px 2px 0 #111);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom: 10px;
}

.mn-card-title{
  font-family: var(--font-heading);
  font-size: 1.2rem;
  color: var(--primary);
  text-shadow: 2px 2px 0 var(--comic-border, #111);
  margin-bottom: 6px;
}

.mn-card-text{ color: var(--text, #111); opacity:.92; line-height: 1.45; margin-bottom: 10px; }

.mn-card-output{
  font-family: var(--font-accent, var(--font-body));
  font-weight: 900;
  padding: 10px 12px;
  background: rgba(0,168,255,.10);
  border: 3px dashed rgba(0,0,0,.25);
  border-radius: 14px;
  box-shadow: var(--comic-shadow-small, 2px 2px 0 #111);
  margin-bottom: 10px;
}

.mn-btn{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 9px 12px;
  border: 4px solid var(--comic-border, #111);
  border-radius: 12px;
  background: var(--accent, #ffd700);
  box-shadow: var(--comic-shadow-small, 2px 2px 0 #111);
  font-family: var(--font-accent, var(--font-body));
  font-weight: 900;
  cursor: pointer;
}
.mn-btn:hover{ transform: translate(-1px,-1px); box-shadow: var(--comic-shadow, 4px 4px 0 #111); }

/* --- OMDb modal: filters grid + buttons in Brick style --- */
#omdbModal .movies-field-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  padding: 0 16px 6px;
}
#omdbModal .movies-field--wide{ grid-column: 1 / -1; }
@media (max-width: 720px){ #omdbModal .movies-field-grid{ grid-template-columns: 1fr; } }

#omdbModal .movies-help{ color: var(--muted); font-size: .85rem; margin-top: 6px; }

#omdbModal .movies-actions{ padding: 0 16px 12px; margin-top: 2px; }

#omdbModal .btn{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 9px 12px;
  border: 4px solid var(--comic-border);
  border-radius: 12px;
  box-shadow: var(--comic-shadow-small);
  font-family: var(--font-accent);
  font-weight: 900;
  cursor:pointer;
}
#omdbModal .btn-primary{ background: var(--accent); color: var(--comic-border); }
#omdbModal .btn-secondary{ background: rgba(255,255,255,.9); }

#omdbModal .omdb-status{
  margin: 0 16px 10px;
  padding: 10px 12px;
  border: 3px dashed rgba(0,0,0,.25);
  border-radius: 14px;
  background: rgba(255,255,255,.72);
  font-family: var(--font-accent);
  font-weight: 900;
}

/* --- Copy Filmkluis card styles to OMDb modal (style.css scopes them to #filmsModal) --- */
#omdbModal .films-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 14px;
  padding: 0;
  align-items: start;
}

#omdbModal .film-info{ min-width: 0; }

#omdbModal .film-card{
  background: var(--panel);
  border: 4px solid var(--comic-border);
  border-radius: 18px;
  box-shadow: var(--comic-shadow);
  padding: 14px;
  transition: transform .2s ease, box-shadow .2s ease;
  position: relative;
  overflow:hidden;
}

#omdbModal .film-card::before{
  content:"";
  position:absolute;
  top:-10px; left:-10px; right:-10px;
  height:6px;
  background: linear-gradient(90deg, var(--primary), var(--secondary), var(--accent));
  opacity:.9;
}

#omdbModal .film-card:hover{
  transform: translate(-3px,-3px);
  box-shadow: 8px 8px 0 var(--comic-border);
}

#omdbModal .film-card-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-bottom: 10px;
}

#omdbModal .film-type{
  font-family: var(--font-accent);
  font-size: .75rem;
  background: var(--accent);
  color: var(--comic-border);
  border: 2px solid var(--comic-border);
  border-radius: 999px;
  padding: 6px 10px;
  box-shadow: var(--comic-shadow-small);
}

#omdbModal .film-rating{
  font-size: 18px;
  letter-spacing: 2px;
  color: var(--accent-dark);
  text-shadow: 1px 1px 0 var(--comic-border);
}

#omdbModal .film-card-main{ display:flex; gap:14px; align-items:flex-start; }

#omdbModal .film-poster-wrap{ width: 110px; flex: 0 0 110px; }

#omdbModal .film-poster{
  width:110px;
  height:auto;
  display:block;
  border-radius: 14px;
  border: 3px solid var(--comic-border);
  box-shadow: var(--comic-shadow-small);
}

#omdbModal .film-title{
  font-family: var(--font-heading);
  font-size: 1.6rem;
  color: var(--primary);
  text-shadow: 2px 2px 0 var(--comic-border);
  margin: 0 0 6px;
}

#omdbModal .film-meta{
  color: var(--muted);
  font-family: var(--font-accent);
  font-size: .75rem;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom: 8px;
}

#omdbModal .film-imdb{ display:flex; align-items:center; gap:8px; margin: 8px 0; }

#omdbModal .badge{
  background: var(--primary);
  color:#fff;
  border: 2px solid var(--comic-border);
  border-radius: 999px;
  padding: 3px 8px;
  font-family: var(--font-accent);
  font-size: .7rem;
  box-shadow: var(--comic-shadow-small);
}

#omdbModal .imdb-link{
  font-family: var(--font-accent);
  font-size: .8rem;
  text-decoration:none;
  background: rgba(0,168,255,.12);
  border: 2px solid var(--comic-border);
  border-radius: 10px;
  padding: 4px 8px;
  box-shadow: var(--comic-shadow-small);
}

#omdbModal .imdb-link:hover{ background: var(--accent); transform: translate(-1px,-1px); box-shadow: var(--comic-shadow); }

#omdbModal .film-credits{ font-size: .98rem; line-height: 1.35; color: var(--text); margin-top: 6px; overflow-wrap:anywhere; }
#omdbModal .film-credits strong{ font-family: var(--font-accent); font-size: .78rem; color: var(--muted); }

#omdbModal .film-plot{
  margin-top: 10px;
  padding: 10px 12px;
  background: rgba(255,215,0,.16);
  border: 3px solid var(--comic-border);
  border-radius: 14px;
  box-shadow: var(--comic-shadow-small);
  line-height: 1.55;
  overflow-wrap:anywhere;
}

#omdbModal .film-date{ margin-top: 10px; font-family: var(--font-accent); font-size: .75rem; color: var(--muted); }

@media (max-width: 520px){
  #omdbModal .film-card-main{ flex-direction: column; }
  #omdbModal .film-poster-wrap{ width: 100%; flex: 0 0 auto; }
  #omdbModal .film-poster{ width: 100%; max-width: 240px; }
}


/* =========================================================
   v5: FIXES (mobile header/footer overlap + modals)
========================================================= */

/* --- 1) Header/Footer overlap (mobiel) --- */
@media (max-width: 920px){
  body.movies-page .header{ position: sticky !important; top: 0; z-index: 3000; }
  body.movies-page .footer{ position: static !important; }
  /* header staat nu weer in de flow -> haal de 'fixed header' compensatie uit de hero */
  body.movies-page .movies-hero{ padding-top: 72px; }
}

body.movies-page .page-shell{
  /* als footer fixed is in style.css, voorkomt dit dat je laatste content erachter verdwijnt */
  padding-bottom: calc(120px + env(safe-area-inset-bottom));
}

/* --- 2) Modals: scroll + rode hero + gele close button --- */
body.movies-page .modal{
  display: none; /* JS zet display:flex bij open */
  position: fixed;
  inset: 0;
  padding: 16px;
  background: rgba(0,0,0,.65);
  z-index: 9999;
  justify-content: center;
  align-items: flex-start;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

body.movies-page .modal .modal-content{
  width: min(1100px, 100%);
  margin: 0 auto;
  background: rgba(255,255,255,.95);
  border: 4px solid var(--comic-border, #111);
  border-radius: 18px;
  box-shadow: 8px 8px 0 var(--comic-border, #111);
  display: flex;
  flex-direction: column;
  overflow: auto; /* dit is de daadwerkelijke scroll container */
  overscroll-behavior: contain;
}

@supports (height: 100svh){
  body.movies-page .modal .modal-content{ max-height: calc(100svh - 32px); }
}
@supports not (height: 100svh){
  body.movies-page .modal .modal-content{ max-height: calc(100vh - 32px); }
}

/* Close button (geel) */
body.movies-page .modal .close-button{
  align-self: flex-end;
  position: sticky;
  top: 12px;
  /* negatieve margin: button "zweeft" op de rode header zonder extra witvlak */
  margin: 12px 12px -52px 0;
  width: 46px;
  height: 46px;
  border-radius: 14px;
  border: 4px solid var(--comic-border, #111);
  background: var(--accent, #ffd700);
  color: var(--comic-border, #111);
  font-size: 30px;
  line-height: 1;
  box-shadow: var(--comic-shadow, 4px 4px 0 #111);
  cursor: pointer;
  z-index: 30;
}
body.movies-page .modal .close-button:hover{
  transform: translate(-2px, -2px);
  box-shadow: 8px 8px 0 var(--comic-border, #111);
}

/* Modal hero/header (rood) */
body.movies-page .modal .films-modal-header{
  position: sticky;
  top: 0;
  z-index: 20;
  padding: 18px 18px 14px;
  background: linear-gradient(135deg, var(--primary, #ff3b3b), rgba(255,59,59,.82));
  color: #fff;
  border-bottom: 4px solid var(--comic-border, #111);
  text-shadow: 2px 2px 0 var(--comic-border, #111);
}
body.movies-page .modal .films-modal-header h2{
  margin: 0;
  font-family: var(--font-heading, var(--font-body, 'Segoe UI', sans-serif));
  letter-spacing: .06em;
  text-transform: uppercase;
}
body.movies-page .modal .films-modal-header p{
  margin: 6px 0 0;
  opacity: .95;
}

/* wat padding zodat alles netjes blijft */
body.movies-page #filmsModal .films-modal-controls,
body.movies-page #filmsModal .films-modal-body{
  padding: 16px 18px;
}

body.movies-page #omdbModal .omdb-results{
  padding: 0 16px 16px;
}

body.movies-page .movies-sep{
  border: 0;
  border-top: 4px dashed rgba(0,0,0,.25);
  margin: 14px 18px;
}

/* =========================================================
   v6: FIX (short viewport / landscape) footer overlap
   - screenshot: small HEIGHT but wide => max-width media query didn't trigger
========================================================= */

/* Reserve space for a fixed footer (if your global style.css uses one) */
body.movies-page{ --footer-reserve: 360px; }
body.movies-page .page-shell{
  padding-bottom: calc(var(--footer-reserve) + env(safe-area-inset-bottom));
}

/* If viewport height is small (mobile landscape / small laptop window): disable fixed footer */
@media (max-height: 760px){
  body.movies-page{ --footer-reserve: 32px; }
  body.movies-page .footer{ position: static !important; }
}

/* Keep your existing mobile width behaviour consistent */
@media (max-width: 920px){
  body.movies-page{ --footer-reserve: 32px; }
}
/* =========================================================
   v7: LAYOUT FIX (copy dice-page approach)
   - voorkomt overlap: footer over content / header over hero
   - body = flex column; main = flex:1; footer = static
========================================================= */

body.movies-page{
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

body.movies-page main.page-shell{
  flex: 1 0 auto;
  min-height: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 3rem !important;
  overflow: visible !important;
}

/* Footer mag nooit fixed/sticky zijn op deze pagina */
body.movies-page .footer{
  position: static !important;
  bottom: auto !important;
  left: auto !important;
  right: auto !important;
  width: auto !important;
  margin-top: auto;
}

/* Header in-flow houden zodat hij niet over content heen valt */
body.movies-page .header{
  position: sticky !important;
  top: 0;
  z-index: 3000;
}

/* movies-hero had compensatie voor 'fixed header' — bij sticky wordt dat te veel */
body.movies-page .movies-hero{
  padding-top: 80px !important;
}
@media (max-width: 768px){
  body.movies-page .movies-hero{ padding-top: 64px !important; }
}
/* =========================================================
   Modal polish v2 (Movies page)
   - 1 scroll area (smooth)
   - header/hero stays clean (scrollbar starts BELOW header)
   - close button always visible, sits on the red header
========================================================= */

/* Overlay should NOT scroll (prevents "double scroll") */
body.movies-page .modal{
  overflow: hidden !important;
  padding: max(16px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right))
           max(16px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));
  align-items: center;
}

/* Modal content becomes a flex column; inner sections handle scroll */
body.movies-page .modal .modal-content{
  position: relative;
  display: flex;
  flex-direction: column;
  width: min(1200px, 100%);
  max-height: calc(100dvh - 32px);
  overflow: hidden !important;
}

@supports not(height: 100dvh){
  body.movies-page .modal .modal-content{
    max-height: calc(100vh - 32px);
  }
}

/* Close button: always visible, not part of any scroll area */
body.movies-page .modal .close-button{
  position: absolute !important;
  top: 12px;
  right: 12px;
  z-index: 80;
  margin: 0 !important;
}

/* Header/hero stays clean (no scrollbar through it) */
body.movies-page .modal .films-modal-header{
  width: 100%;
  flex: 0 0 auto;
  padding-right: 86px; /* ruimte voor close btn */
  border-top-left-radius: 18px;
  border-top-right-radius: 18px;
}

/* FILMKLUIS: alleen de body scrolt (geen scrollbar door de header) */
body.movies-page #filmsModal .films-modal-controls{
  flex: 0 0 auto;
  padding: 12px 16px 0;
}

body.movies-page #filmsModal .films-modal-body{
  flex: 1 1 auto;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
  padding: 12px 16px 16px;
}

/* OMDb: alleen results scrolt */
body.movies-page #omdbModal .movies-field-grid,
body.movies-page #omdbModal .movies-actions,
body.movies-page #omdbModal .omdb-status,
body.movies-page #omdbModal .movies-sep{
  flex: 0 0 auto;
}

body.movies-page #omdbModal .omdb-results{
  flex: 1 1 auto;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
  padding: 0 16px 16px;
}

/* Kleine hoogte: laat alles gewoon scrollen (1 scrollbar) */
@media (max-height: 640px){
  body.movies-page .modal .modal-content{
    overflow-y: auto !important;
  }
  body.movies-page #filmsModal .films-modal-body,
  body.movies-page #omdbModal .omdb-results{
    overflow: visible !important;
    flex: 0 0 auto;
    padding-bottom: 18px;
  }
  body.movies-page .modal .films-modal-header{
    position: sticky;
    top: 0;
    z-index: 40;
  }
}
