/* ============================================
   PAM Istanbul — Film / Showreel Page
   Editorial asymmetric layout · Vimeo embeds
   ============================================ */

.film-main {
  background: var(--bg);
  color: var(--ink);
  padding: 0 var(--sp-8) var(--sp-16);
}

/* ---------- HERO REEL (full-width 16:9) ---------- */
.film-hero-reel {
  max-width: 1680px;
  margin: 0 auto var(--sp-12);
  position: relative;
}

.film-hero-reel__frame {
  position: relative;
  aspect-ratio: 16 / 9;
  width: 100%;
  background: var(--bg-elevated);
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
}

.film-hero-reel__frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.film-hero-reel__caption {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-top: var(--sp-4);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

.film-hero-reel__caption .acid { color: var(--accent); }
.film-hero-reel__caption h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.1rem, 1.6vw, 1.6rem);
  letter-spacing: -0.02em;
  text-transform: none;
  color: var(--ink);
}

/* ---------- INDEX STRIP ---------- */
.film-index {
  max-width: 1680px;
  margin: 0 auto var(--sp-8);
  display: flex;
  gap: var(--sp-6);
  flex-wrap: wrap;
  padding: var(--sp-4) 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.film-index span.acid { color: var(--accent); }

/* ---------- REEL GRID (asymmetric 12-col) ---------- */
.reel-grid {
  max-width: 1680px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5) var(--sp-3);
  align-items: start;
}

/* 3 per row — uniform grid (1 col in 3-col grid) */
.reel-item { grid-column: span 1; position: relative; }
.reel-item--big,
.reel-item--small,
.reel-item--mid,
.reel-item--wide,
.reel-item--left5,
.reel-item--right7 { grid-column: span 1; }

/* Offsets disabled for uniform 3-col layout */
.reel-item--offset-down { margin-top: 0; }
.reel-item--offset-up   { margin-top: 0; }

.reel-item__frame {
  position: relative;
  aspect-ratio: 16 / 9;
  width: 100%;
  overflow: hidden;
  background: var(--bg-elevated);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  transition: border-color var(--dur-normal) var(--ease-expo),
              transform var(--dur-normal) var(--ease-expo);
}

/* Uniform 16:9 regardless of original aspect hint */
.reel-item--portrait .reel-item__frame,
.reel-item--square   .reel-item__frame { aspect-ratio: 16 / 9; }

.reel-item__frame img,
.reel-item__frame video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.reel-item__frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
  transition: transform var(--dur-slow) var(--ease-expo);
}

.reel-item:hover .reel-item__frame {
  border-color: var(--accent);
  transform: translateY(-3px);
}

/* Play overlay hint (non-blocking — doesn't cover iframe clicks, sits top-left) */
.reel-item__play {
  position: absolute;
  top: var(--sp-3);
  left: var(--sp-3);
  padding: 0.45em 0.9em;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--bg);
  background: var(--accent);
  border-radius: var(--radius-xs);
  pointer-events: none;
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity var(--dur-quick), transform var(--dur-quick) var(--ease-expo);
  z-index: 2;
}
.reel-item:hover .reel-item__play {
  opacity: 1;
  transform: translateY(0);
}

/* Info block under each video */
.reel-item__info {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--sp-2) var(--sp-3);
  align-items: baseline;
  margin-top: var(--sp-2);
  padding-top: var(--sp-2);
  border-top: 1px solid var(--line);
  min-height: 5.2em;
}

.reel-item__num {
  font-family: var(--font-mono);
  font-size: 0.64rem;
  letter-spacing: 0.22em;
  color: var(--accent);
}

.reel-item__title {
  font-family: var(--font-display);
  font-size: 0.98rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--ink);
  line-height: 1.18;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.reel-item__title .client {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 0.3em;
}

.reel-item__meta {
  font-family: var(--font-mono);
  font-size: 0.64rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
  text-align: right;
  white-space: nowrap;
}

.reel-item__tag {
  grid-column: 1 / -1;
  font-family: var(--font-sans);
  font-size: 0.8rem;
  font-weight: 300;
  color: var(--ink-muted);
  font-style: italic;
  line-height: 1.3;
  margin-top: 0.15em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Bigger titles on bigger cards */
.reel-item--big .reel-item__title,
.reel-item--wide .reel-item__title {
  font-size: 1.05rem;
}

/* ---------- CLOSING STRIP ---------- */
.film-outro {
  max-width: 1680px;
  margin: var(--sp-16) auto 0;
  padding-top: var(--sp-8);
  border-top: 1px solid var(--line-strong);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-8);
  align-items: end;
}

.film-outro__headline {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3vw, 3rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--ink);
}
.film-outro__headline .it { font-style: italic; color: var(--accent); }

.film-outro__body {
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--ink-muted);
  line-height: 1.6;
  max-width: 42ch;
  font-weight: 300;
}

.film-outro__body a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 4px;
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 900px) {
  .reel-grid { grid-template-columns: repeat(2, 1fr); }
  .reel-item,
  .reel-item--big,
  .reel-item--small,
  .reel-item--mid,
  .reel-item--wide,
  .reel-item--left5,
  .reel-item--right7 { grid-column: span 1; }
  .reel-item--offset-down,
  .reel-item--offset-up { margin-top: 0; }
}

@media (max-width: 600px) {
  .film-main { padding: 0 var(--sp-4) var(--sp-12); }
  .reel-grid { grid-template-columns: 1fr; }
  .film-outro { grid-template-columns: 1fr; }
  .reel-item__info {
    grid-template-columns: auto 1fr;
    min-height: 0;
  }
  .reel-item__meta { grid-column: 1 / -1; text-align: left; }
}

/* ---------- Thumbnail click overrides ---------- */
.film-hero-reel__frame,
.reel-item__frame {
  display: block;
  padding: 0;
  border: 1px solid var(--line);
  background: #000;
  cursor: pointer;
  overflow: hidden;
  position: relative;
}
.film-hero-reel__frame img,
.reel-item__frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .6s cubic-bezier(.16,1,.3,1), filter .4s;
  filter: saturate(.95);
}
.film-hero-reel__frame:hover img,
.reel-item__frame:hover img { transform: scale(1.03); filter: saturate(1.1); }
.reel-item__play {
  position: absolute;
  left: 18px; bottom: 18px;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(6px);
  color: var(--accent);
  padding: 10px 16px;
  font: 600 12px/1 var(--font-mono, monospace);
  letter-spacing: .08em;
  z-index: 2;
  border: 1px solid rgba(255,255,255,.08);
  transition: background .3s, color .3s;
}
.film-hero-reel__frame:hover .reel-item__play,
.reel-item__frame:hover .reel-item__play {
  background: var(--accent);
  color: #000;
}

/* ---------- Vimeo Modal ---------- */
.film-modal {
  position: fixed;
  inset: 0;
  background: rgba(5,5,5,.96);
  backdrop-filter: blur(14px);
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: clamp(16px, 4vw, 48px);
}
.film-modal[data-open="true"] {
  display: flex;
  animation: fmIn .3s ease-out;
}
@keyframes fmIn { from { opacity: 0 } to { opacity: 1 } }
.film-modal__stage {
  width: 100%;
  max-width: 1400px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.film-modal__frame {
  position: relative;
  aspect-ratio: 16/9;
  width: 100%;
  background: #000;
  border: 1px solid rgba(255,255,255,.08);
}
.film-modal__frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.film-modal__caption {
  color: var(--ink-muted);
  font: 500 13px/1.3 var(--font-mono, monospace);
  letter-spacing: .06em;
  text-transform: uppercase;
}
.film-modal__close {
  position: absolute;
  top: clamp(16px, 3vw, 32px);
  right: clamp(16px, 3vw, 32px);
  background: transparent;
  color: var(--ink);
  border: 1px solid rgba(255,255,255,.2);
  padding: 10px 16px;
  font: 600 12px/1 var(--font-mono, monospace);
  letter-spacing: .1em;
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s;
}
.film-modal__close:hover {
  background: var(--accent);
  color: #000;
  border-color: var(--accent);
}
