/* ============ Theme / Reset ============ */
:root{
  --bg: #0f1115;
  --surface: #131722;
  --surface-2: #181d2b;
  --text: #e9edf3;
  --muted: #a8b2c1;
  --focus: #7cc7ff;
  --accent: #f7c87c;
  --card-shadow: 4px 4px 8px rgba(0,0,0,.05);
  --radius: 14px;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
html { background: var(--bg); color: var(--text); }
body { margin: 0; font: 400 16px/1.5 system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif; }

.skip-link{ position: absolute; left:-9999px; top:-9999px; background:#fff; color:#111; padding:.5rem .75rem; border-radius:.375rem; }
.skip-link:focus{ left:.75rem; top:.75rem; z-index:9999; }

.wrap { width:min(1400px, 94%); margin-inline:auto; }

.site-header{ background: linear-gradient(180deg,#0f1115 0%, #10131a 100%); border-bottom:1px solid #22283a; }
.site-header .wrap{ padding: 1rem 0 1.25rem; }
.brand{ display:inline-block; font-weight:700; letter-spacing:.1em; }
.brand img{
  width: 120px; height:auto; display:block;
  border:1px solid #2b3246; padding:.25rem .5rem; border-radius:.5rem; margin-bottom:.5rem;
}

h1{ margin:.25rem 0 .5rem; font-size: clamp(1.25rem, 2.8vw, 1.9rem); }
.lede{ margin:0; color:var(--muted); font-size: clamp(.5rem, 1vw, .9rem); font-weight:400; }

.site-footer{ border-top:1px solid #22283a; padding:1rem 0 1.5rem; color:var(--muted); }

/* ============ Board / Infinite Plane ============ */
.board{ padding: 1rem 0; }
.viewport{
  position: relative;
  height: calc(100vh - 180px);
  border: 1px solid #22283a;
  border-radius: .9rem;
  background: var(--surface);
  overflow: hidden;
  touch-action: none;
  outline: none;
}
.viewport:focus-visible{ outline:3px solid var(--focus); outline-offset:2px; }

.plane{
  position:absolute; inset:0;
  transform-origin: 0 0;
  will-change: transform;
}

/* Tile (card) */
.tile{
  position:absolute;
  width: clamp(240px, 28vw, 520px);
  height: clamp(160px, 26vh, 350px);
  border-radius: var(--radius);
  background: var(--surface-2);
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: var(--card-shadow);
  overflow: hidden;
  transform-style: preserve-3d;
  transition: box-shadow .2s ease;
}
.tile:focus-visible{ outline:3px solid var(--focus); outline-offset:2px; }
.tile:hover{ box-shadow: 0 8px 24px rgba(0,0,0,.25), var(--card-shadow); cursor: pointer; }

/* Tilt look follows cursor */
.tile__inner{
  position: absolute; inset:0;
  display:grid; place-items:center;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0.02)),
    radial-gradient(120% 80% at 20% 20%, rgba(255,255,255,0.08), rgba(255,255,255,0));
}
.tile__label{
  position:absolute; left:12px; bottom:10px;
  padding:.2rem .5rem; background: rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.12); border-radius:.4rem; color:#fff; font-size:.85rem;
}

/* Poster */
.tile__poster{ width:100%; height:100%; object-fit:cover; display:block; }

/* ============ Modal ============ */
.modal{
  position: fixed; inset:0; display:none; place-items:center;
  background: rgba(0,0,0,.5);
  z-index: 50;
}
.modal[aria-hidden="false"]{ display:grid; }

.modal__sheet{
  width:min(1200px, 94vw);
  max-height: 90vh;
  background: var(--surface);
  border: 1px solid #2a3246;
  border-radius: 1rem;
  overflow: hidden;
  display:grid; grid-template-columns: 1.1fr 1fr;
}
@media (max-width: 980px){
  .modal__sheet{ grid-template-columns: 1fr; }
}

.modal__close{
  position:absolute; top:.75rem; right:.75rem; z-index:2;
  width:38px; height:38px; border-radius:50%;
  border:1px solid #2a3246; background:#0f1115; color:#fff; font-size:20px;
}
.modal__media{ padding: 1rem; border-right:1px solid #22283a; min-height: 280px; }
@media (max-width:980px){ .modal__media{ border-right:0; border-bottom:1px solid #22283a; } }

.media-frame{ aspect-ratio: 16/9; width:100%; background:#0b0e15; border:1px solid #2a3246; border-radius:.75rem; overflow:hidden; }
.media{ width:100%; height:100%; object-fit:contain; display:none; background:#000; }
.media--video{ background:#000; }

.toggle{ display:flex; align-items:center; gap:.6rem; margin-top:.6rem; }
.switch{ position:relative; display:inline-block; width:54px; height:28px; }
.switch input{ opacity:0; width:0; height:0; }
.slider{ position:absolute; inset:0; background:#2a3246; border-radius:28px; }
.slider::before{
  content:""; position:absolute; left:4px; top:4px; width:20px; height:20px; border-radius:50%;
  background:#fff; transition: transform .18s ease;
}
.switch input:checked + .slider::before{ transform: translateX(26px); }
.switch input:checked + .slider{ background:#3a8fdd; }

.share-row{ margin-top:.6rem; }
.btn{ background:#1b2132; color:#fff; border:1px solid #2a3246; padding:.4rem .7rem; border-radius:.5rem; }

.modal__info{ padding:1rem; overflow:auto; }
.modal__info h2{ margin:.25rem 0 .35rem; }
.modal__info p{ color:var(--muted); margin-top:0; }

/* Credit (blockquote with optional cite) */
.credit{ margin-top:.75rem; font-size:.9rem; color:var(--muted); text-align:right; }
.credit blockquote{
  margin:0;
  padding:.25rem 0 .25rem .5rem;
  border-left: 2px solid var(--accent);
  font-style: italic;
}

/* Accordion */
.accordion{ margin-top:.5rem; border:1px solid #22283a; border-radius:.6rem; overflow:hidden; }
.ac-item + .ac-item{ border-top:1px solid #22283a; }
.ac-head{ display:flex; gap:.6rem; align-items:center; width:100%; background:#141a28; color:#fff; border:0; text-align:left; padding:.75rem 1rem; font-weight:600; }
.ac-body{ padding:.8rem 1rem .9rem; display:none; color:var(--text); background:#111521; }
.ac-item[aria-expanded="true"] .ac-body{ display:block; }

.related{
  margin-top:1.25rem;
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:.75rem;
}
.related__title{
  margin:0 0 .5rem 0;
  font-size:1rem;
  font-weight:600;
  color:#e9eef7;
}
.related__list{
  list-style:none; margin:0; padding:0;
  display:grid; gap:.5rem;
}
.related__list a{
  display:inline-flex; align-items:center; gap:.5rem;
  text-decoration:none; font-size:.95rem; line-height:1.3;
  border:1px solid rgba(255,255,255,.08);
  padding:.5rem .6rem; border-radius:.5rem;
}
.related__list a:hover{ border-color: rgba(255,255,255,.2); }
.related__badge{
  font-size:.75rem; padding:.15rem .4rem;
  border:1px solid rgba(255,255,255,.2); border-radius:.375rem; opacity:.8;
}

.disclaimer{ color:var(--muted); font-size:.85rem; margin-top:.75rem; }

/* Focus rings */
button:focus-visible, .btn:focus-visible{ outline:3px solid var(--focus); outline-offset:3px; }

/* ============ Misc ============ */
@media (pointer: coarse){
  .tile:hover{ box-shadow: var(--card-shadow); }
}
