/* ════════════════════════════════════════════════════════════
   Friday Night Lights — shared layout styles
   Loaded alongside /crew/crew.css (base + colors) and /nav.css
   Used by /friday-night-lights/cast/ and /friday-night-lights/crew/
   ════════════════════════════════════════════════════════════ */

/* ─── HERO ─── */
.fnl-hero {
  position: relative;
  padding: 7rem 2rem 5rem;
  background: linear-gradient(160deg, #04060c 0%, #070d18 38%, #0b1322 72%, var(--dark-mid) 100%);
  overflow: hidden;
  text-align: center;
}
.fnl-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 8%, rgba(232,208,138,.10) 0, transparent 22%),
    radial-gradient(circle at 82% 8%, rgba(232,208,138,.10) 0, transparent 22%),
    repeating-linear-gradient(0deg, transparent 0, transparent 59px, rgba(201,168,76,.03) 60px),
    repeating-linear-gradient(90deg, transparent 0, transparent 59px, rgba(201,168,76,.03) 60px);
}
.fnl-hero::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 5px;
  background: repeating-linear-gradient(90deg, var(--gold) 0 14px, transparent 14px 24px);
  opacity: .28;
}
.fnl-hero-inner { position: relative; z-index: 2; max-width: 880px; margin: 0 auto; }
.fnl-eyebrow {
  display: inline-block;
  border: 1px solid var(--gold);
  color: var(--gold);
  font-size: .56rem;
  letter-spacing: .32em;
  text-transform: uppercase;
  padding: .4em 1.6em;
  margin-bottom: 1.75rem;
}
.fnl-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(2.8rem, 7.5vw, 6rem);
  font-style: italic;
  color: #fff;
  line-height: .98;
  letter-spacing: -.01em;
  margin-bottom: .5rem;
}
.fnl-sub {
  font-size: .62rem;
  letter-spacing: .34em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.5rem;
}
.fnl-motto {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: 1.05rem;
  color: var(--gold-lt);
  letter-spacing: .02em;
  margin: 1.25rem auto .5rem;
}
.fnl-lede {
  font-size: .92rem;
  color: var(--muted);
  max-width: 60ch;
  margin: 0 auto 2rem;
  line-height: 1.75;
}

/* ─── HUB CONTENT WRAPPER ─── */
.hub-content {
  max-width: 1180px;
  margin: 0 auto;
  padding: 4rem 2rem 2rem;
}

/* ─── LEAD CARD ─── */
.lead-card {
  background: var(--dark-mid);
  border: 1px solid rgba(201,168,76,.18);
  border-top: 4px solid var(--gold);
  overflow: hidden;
  margin-bottom: 3rem;
}
.lead-card-inner {
  display: grid;
  grid-template-columns: 440px 1fr;
  min-height: 560px;
}
.lead-photo-wrap { position: relative; background: #000; overflow: hidden; }
.lead-photo-wrap img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  display: block; opacity: .92;
  filter: contrast(1.08) saturate(.9);
}
.lead-content {
  padding: 2.5rem 2.5rem 2rem;
  display: flex; flex-direction: column; justify-content: center;
}
.lead-eyebrow {
  font-size: .54rem; letter-spacing: .3em; text-transform: uppercase;
  color: var(--gold); margin-bottom: .75rem;
}
.lead-actor-name {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  color: #fff; line-height: 1.1; margin-bottom: .2rem;
}
.lead-character {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.1rem; font-style: italic;
  color: var(--gold-lt); margin-bottom: 1.5rem;
}
.lead-bio p {
  font-size: .88rem; color: var(--muted); line-height: 1.75; margin-bottom: .85rem;
}
.lead-bio p:last-child { margin-bottom: 0; }

/* ─── FILMOGRAPHY PILLS ─── */
.film-pills { display: flex; flex-wrap: wrap; gap: .35rem; margin-top: 1.25rem; }
.film-pill {
  font-size: .55rem; letter-spacing: .1em; text-transform: uppercase;
  padding: .22em .75em;
  background: rgba(201,168,76,.06);
  border: 1px solid rgba(201,168,76,.18);
  color: var(--gold-lt);
}
.film-pill.award {
  background: rgba(201,168,76,.12);
  border-color: rgba(201,168,76,.35);
  color: var(--gold);
}

/* ─── CAST GRID ─── */
.cast-grid-main {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.75rem;
  margin-bottom: 3rem;
}
.actor-card {
  background: var(--dark-mid);
  border: 1px solid rgba(168,205,221,.07);
  border-top: 3px solid rgba(201,168,76,.4);
  overflow: hidden;
  display: flex; flex-direction: column;
}
.actor-photo-wrap { position: relative; height: 300px; background: #000; overflow: hidden; }
.actor-photo-wrap img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  display: block; opacity: .85;
  filter: contrast(1.05) saturate(.88);
  transition: opacity .3s, transform .4s;
}
.actor-card:hover .actor-photo-wrap img { opacity: .92; transform: scale(1.02); }

/* photo placeholder (used when no licensed photo) */
.actor-photo-placeholder {
  width: 100%; height: 300px; position: relative; overflow: hidden;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  background: #060c14;
}
.actor-photo-placeholder.lead-ph { height: 100%; min-height: 480px; }
.actor-photo-placeholder::before {
  content: attr(data-initial);
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 13rem; font-style: italic;
  color: rgba(201,168,76,.07);
  line-height: 1; pointer-events: none; z-index: 0; white-space: nowrap;
}
.actor-photo-placeholder.lead-ph::before { font-size: 18rem; }
.placeholder-char-name {
  position: relative; z-index: 1;
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.55rem; font-style: italic;
  color: rgba(201,168,76,.5); text-align: center; line-height: 1.2; padding: 0 1rem;
}
.actor-photo-placeholder.lead-ph .placeholder-char-name { font-size: 2.4rem; }
.placeholder-actor-id {
  position: relative; z-index: 1;
  font-size: .52rem; letter-spacing: .24em; text-transform: uppercase;
  color: rgba(168,205,221,.3); margin-top: .6rem;
}
.placeholder-badge {
  position: relative; z-index: 1;
  font-size: .46rem; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(122,146,168,.3); margin-top: .5rem;
  border: 1px solid rgba(122,146,168,.16); padding: .2em .8em;
}

.actor-card-body { padding: 1.5rem 1.5rem 1.75rem; display: flex; flex-direction: column; flex: 1; }
.actor-name {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.25rem; color: #fff; margin-bottom: .1rem;
}
.actor-character {
  font-size: .6rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 1rem;
}
.actor-bio { font-size: .84rem; color: var(--muted); line-height: 1.7; margin-bottom: .85rem; }
.actor-stat-row {
  display: flex; gap: 1.5rem; flex-wrap: wrap;
  margin-top: auto; padding-top: 1rem;
  border-top: 1px solid rgba(201,168,76,.08);
}
.actor-stat { display: flex; flex-direction: column; }
.actor-stat-label {
  font-size: .5rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--gold); margin-bottom: .15rem;
}
.actor-stat-val { font-size: .78rem; color: var(--text); }
.profile-link {
  margin-top: 1.1rem; padding-top: 1rem;
  border-top: 1px solid rgba(201,168,76,.08);
}
.profile-link a {
  font-size: .54rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--gold); text-decoration: none;
}
.profile-link a:hover { color: var(--gold-lt); }

/* ─── CHARACTER QUOTE ─── */
.char-quote {
  border-left: 2px solid var(--gold);
  padding: .85rem 1.25rem; margin: 1.1rem 0;
  background: rgba(201,168,76,.03);
  font-family: 'Playfair Display', Georgia, serif;
  font-size: .92rem; font-style: italic;
  color: var(--text); line-height: 1.6;
}

/* ─── ERA / CONTEXT BLOCKS ─── */
.era-block {
  background: var(--dark-mid);
  border-left: 3px solid var(--gold);
  padding: 1.5rem 1.75rem;
  margin-bottom: 1.5rem;
}
.era-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.15rem; color: #fff; margin-bottom: .25rem;
}
.era-years {
  font-size: .56rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--gold); margin-bottom: .9rem;
}
.era-desc { font-size: .86rem; color: var(--muted); line-height: 1.75; }

/* ─── INDIVIDUAL PROFILE PAGE ─── */
.profile-hero {
  position: relative;
  padding: 6rem 2rem 3.5rem;
  background: linear-gradient(160deg, #04060c 0%, #070d18 45%, var(--dark-mid) 100%);
  overflow: hidden; text-align: center;
}
.profile-hero::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 4px;
  background: repeating-linear-gradient(90deg, var(--gold) 0 14px, transparent 14px 24px);
  opacity: .28;
}
.profile-hero-inner { position: relative; z-index: 2; max-width: 760px; margin: 0 auto; }
.profile-breadcrumb {
  font-size: .54rem; letter-spacing: .24em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 1.25rem;
}
.profile-breadcrumb a { color: var(--gold); text-decoration: none; }
.profile-breadcrumb a:hover { color: var(--gold-lt); }
.profile-name {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(2.2rem, 5.5vw, 4rem);
  color: #fff; line-height: 1.05; margin-bottom: .35rem;
}
.profile-char {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: 1.25rem;
  color: var(--gold-lt); margin-bottom: 1rem;
}
.profile-body { max-width: 760px; margin: 0 auto; padding: 3rem 2rem 1rem; }
.profile-body h2 {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.5rem; color: #fff;
  margin: 2.5rem 0 1rem; padding-bottom: .6rem;
  border-bottom: 1px solid rgba(201,168,76,.15);
}
.profile-body h2:first-child { margin-top: 0; }
.profile-body p {
  font-size: .94rem; color: var(--text); line-height: 1.85; margin-bottom: 1.1rem;
}
.profile-body p.muted { color: var(--muted); }
.profile-factbox {
  background: var(--dark-mid);
  border: 1px solid rgba(201,168,76,.15);
  border-top: 3px solid var(--gold);
  padding: 1.5rem 1.75rem; margin: 0 auto 1rem;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 1.25rem;
}
.fact-cell-label {
  font-size: .5rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--gold); margin-bottom: .25rem;
}
.fact-cell-val { font-size: .86rem; color: var(--text); line-height: 1.4; }
.film-list { list-style: none; padding: 0; margin: 0; }
.film-list li {
  font-size: .9rem; color: var(--text); line-height: 1.5;
  padding: .55rem 0; border-bottom: 1px solid rgba(201,168,76,.08);
  display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
}
.film-list li:last-child { border-bottom: none; }
.film-list .film-year { color: var(--gold); font-size: .8rem; white-space: nowrap; }
.back-row {
  text-align: center; padding: 1rem 0 2rem;
}
.back-btn {
  display: inline-block; font-size: .58rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--gold); border: 1px solid rgba(201,168,76,.35);
  padding: .55em 1.8em; text-decoration: none; transition: all .2s; margin: .3rem;
}
.back-btn:hover { background: rgba(201,168,76,.1); border-color: var(--gold); color: var(--gold-lt); }

/* ─── SOCIAL / EXTERNAL LINKS ROW ─── */
.links-row {
  display: flex; flex-wrap: wrap; gap: .5rem;
  margin: 1.25rem 0 .25rem;
}
.ext-link {
  display: inline-flex; align-items: center; gap: .4em;
  font-size: .58rem; letter-spacing: .12em; text-transform: uppercase;
  padding: .42em .9em;
  border: 1px solid rgba(201,168,76,.25);
  background: rgba(201,168,76,.05);
  color: var(--gold-lt); text-decoration: none;
  transition: all .18s;
}
.ext-link:hover { background: rgba(201,168,76,.14); border-color: var(--gold); color: var(--gold); }
.ext-link.imdb { border-color: rgba(245,197,24,.4); color: #f5c518; }
.ext-link.imdb:hover { background: rgba(245,197,24,.12); border-color: #f5c518; }
.ext-link.x-link { border-color: rgba(168,205,221,.3); color: var(--accent); }
.ext-link.insta { border-color: rgba(221,42,123,.35); color: #e1719c; }
.ext-link.fb { border-color: rgba(66,103,178,.4); color: #7e9be0; }
.ext-link.linkedin { border-color: rgba(10,102,194,.4); color: #6aa6e0; }
.ext-link.web { border-color: rgba(168,205,221,.25); color: var(--accent); }
.links-note {
  font-size: .58rem; color: var(--muted); margin-top: .4rem; line-height: 1.5;
}
/* compact links row inside hub/card context */
.card-links { display: flex; flex-wrap: wrap; gap: .35rem; margin-top: .85rem; }
.card-links .ext-link { font-size: .52rem; padding: .35em .7em; }

/* ─── PHOTO CREDITS ─── */
.photo-credits {
  font-size: .62rem; color: var(--muted); line-height: 1.8;
  padding: 2rem; border-top: 1px solid rgba(201,168,76,.08); margin-top: 4rem;
}
.photo-credits a { color: var(--accent); }

@media (max-width: 960px) {
  .lead-card-inner { grid-template-columns: 340px 1fr; min-height: 480px; }
}
@media (max-width: 800px) {
  .lead-card-inner { grid-template-columns: 1fr; min-height: 0; }
  .lead-photo-wrap, .actor-photo-placeholder.lead-ph { height: 420px; min-height: 0; }
  .lead-content { padding: 1.75rem 1.5rem; }
  .cast-grid-main { grid-template-columns: 1fr 1fr; }
  .fnl-hero { padding: 4.5rem 1.25rem 3.5rem; }
  .hub-content { padding: 2.5rem 1.25rem 2rem; }
}
@media (max-width: 540px) {
  .cast-grid-main { grid-template-columns: 1fr; }
}
