/* ===========================================================================
   DOSSIER — Personnel files page.
   One band-level organization file + three personnel dossiers in founding
   order: Nils → Rufus → Klaas. Original 2010 bombring.com bios preserved
   verbatim in the narrative column; filing chrome around them.
   Depends on tokens.css + page.css.
   =========================================================================== */

/* --- Hero customizations ------------------------------------------------- */

.hero--dossier {
  min-height: 52vh;
}

.hero--dossier .hero__content {
  min-height: 52vh;
  padding-top: 100px;
  padding-bottom: 56px;
}

.hero--dossier .hero__wordmark {
  font-size: clamp(40px, 6.5vw, 84px);
}

/* Heavier left-bias gradient — no figure to anchor right side */
.hero--dossier .hero__overlay {
  background:
    linear-gradient(to right,
      rgba(8, 10, 12, 0.85) 0%,
      rgba(8, 10, 12, 0.45) 50%,
      rgba(8, 10, 12, 0.20) 100%
    ),
    linear-gradient(180deg,
      rgba(8, 10, 12, 0.5) 0%,
      rgba(8, 10, 12, 0) 35%,
      rgba(8, 10, 12, 0) 70%,
      rgba(8, 10, 12, 0.7) 100%
    );
}

/* --- The archive --------------------------------------------------------- */

.dossier-archive {
  position: relative;
  z-index: 4;
  padding: 0 56px 80px calc(var(--nav-strip-width) + 56px);
  max-width: var(--content-max);
  margin: 0 auto;
}

/* --- Shared meta-row vocabulary (used in both org file and personnel) --- */

.dossier-meta-row {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 12px;
  padding: 8px 0;
  align-items: baseline;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-bottom: 1px solid rgba(43, 43, 44, 0.5);
}

.dossier-meta-row:last-of-type { border-bottom: none; }

.dossier-meta-label {
  color: var(--bomb-ash);
  font-size: 10px;
  letter-spacing: 0.22em;
}

.dossier-meta-value {
  color: var(--bomb-bone);
  word-break: break-word;
}

.dossier-meta-value--amber {
  color: var(--bomb-amber);
}

.dossier-meta-value--unknown {
  color: var(--bomb-ash);
  letter-spacing: 0.28em;
}

.dossier-meta-link {
  color: var(--bomb-bone);
  text-decoration: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  transition: color 0.2s ease, border-color 0.2s ease;
}

.dossier-meta-link:hover {
  color: var(--bomb-visor);
  border-bottom-color: var(--bomb-visor);
}

/* =========================================================================
   REGISTERED ORGANIZATION FILE — band-level preamble
   ========================================================================= */

.organization-file {
  padding: 80px 0 96px 0;
  border-bottom: 1px solid var(--bomb-iron);
}

.organization-file__header {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: baseline;
  gap: 24px;
  margin-bottom: 32px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--bomb-iron);
}

.organization-file__tx {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.3em;
  color: var(--bomb-amber);
  text-transform: uppercase;
}

.organization-file__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(28px, 3.5vw, 44px);
  line-height: 1;
  color: var(--bomb-fog);
  text-transform: uppercase;
  text-shadow: 2px 0 0 var(--bomb-visor);
  letter-spacing: 0.005em;
  margin: 0;
  padding: 0 16px;
  position: relative;
}

.organization-file__title::before,
.organization-file__title::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 18px;
  height: 1px;
  background: var(--bomb-iron);
}
.organization-file__title::before { left: -18px; }
.organization-file__title::after  { right: -18px; }

.organization-file__stamp {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--bomb-bone);
  text-transform: uppercase;
}

/* "Bombring is standard." — the four-word filing statement.
   Sits between the header and the body. Display font, large but not
   overpowering, low-contrast — reads as a printed inscription on the
   front of the file folder. */
.organization-file__statement {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(20px, 2.6vw, 32px);
  letter-spacing: 0.04em;
  color: var(--bomb-bone);
  text-transform: uppercase;
  text-align: center;
  padding: 28px 0 40px 0;
  margin-bottom: 16px;
  border-bottom: 1px solid rgba(43, 43, 44, 0.4);
}

.organization-file__body {
  display: grid;
  grid-template-columns: minmax(0, 0.55fr) minmax(0, 1fr);
  gap: 56px;
  align-items: start;
  margin-top: 12px;
}

.organization-file__metadata {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.organization-file__narrative {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: 15px;
  line-height: 1.75;
  color: var(--bomb-bone);
  max-width: 65ch;
}

.organization-file__narrative p {
  margin: 0 0 18px 0;
}

.organization-file__narrative p:last-child {
  margin-bottom: 0;
}

.organization-file__narrative em {
  font-style: italic;
  color: var(--bomb-fog);
}

/* Codicil — the small "Scotland Yard/Interpol" paragraph at the end of
   the narrative. Slightly smaller, slightly faded — reads as an
   appended note rather than primary text. */
.organization-file__codicil {
  font-size: 13.5px;
  color: var(--bomb-ash);
  border-left: 2px solid var(--bomb-iron);
  padding: 4px 0 4px 18px;
  margin-top: 24px !important;
  font-style: italic;
}

/* =========================================================================
   PERSONNEL DOSSIER — three stacked, founding order
   ========================================================================= */

.personnel-dossier {
  padding: 80px 0;
  border-bottom: 1px solid var(--bomb-iron);
}

.personnel-dossier:last-of-type {
  border-bottom: none;
}

/* --- Header strip — // DOSSIER NN ── NAME ── CLASSIFICATION ------------ */

.personnel-dossier__header {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: baseline;
  gap: 24px;
  margin-bottom: 44px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--bomb-iron);
}

.personnel-dossier__file {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.3em;
  color: var(--bomb-amber);
  text-transform: uppercase;
}

.personnel-dossier__name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(28px, 3.5vw, 44px);
  line-height: 1;
  color: var(--bomb-fog);
  text-transform: uppercase;
  text-shadow: 2px 0 0 var(--bomb-visor);
  letter-spacing: 0.005em;
  margin: 0;
  padding: 0 16px;
  position: relative;
}

.personnel-dossier__name::before,
.personnel-dossier__name::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 18px;
  height: 1px;
  background: var(--bomb-iron);
}
.personnel-dossier__name::before { left: -18px; }
.personnel-dossier__name::after  { right: -18px; }

.personnel-dossier__classification {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--bomb-bone);
  text-transform: uppercase;
}

/* Klaas's dossier — slightly amber-tinted classification to mark
   intermittent status without overstating it */
.personnel-dossier--intermittent .personnel-dossier__classification {
  color: var(--bomb-amber);
}

/* --- Two-column body — portrait+metadata column / narrative column ---- */

.personnel-dossier__body {
  display: grid;
  grid-template-columns: minmax(0, 0.55fr) minmax(0, 1fr);
  gap: 56px;
  align-items: start;
}

.personnel-dossier__column-left {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

/* --- Portrait treatment ----------------------------------------------- */

.personnel-dossier__portrait {
  margin: 0;
  border: 1px solid var(--bomb-iron);
  background: var(--bomb-charcoal);
  padding: 10px;
  width: 220px;
  align-self: flex-start;
  position: relative;
}

.personnel-dossier__portrait img {
  display: block;
  width: 100%;
  height: auto;
  /* Image treatment to match site atmospheric language:
     heavy desaturation, slight darkening, contrast bump.
     The originals are small/old/JPEG, with white borders —
     the filter brings them into the site's tonal world. */
  filter: grayscale(0.85) brightness(0.88) contrast(1.08);
  /* Mix the warm bone tone in faintly via tinted overlay below */
}

.personnel-dossier__portrait::after {
  /* Tint overlay — gives the desaturated portrait a faint warmth */
  content: '';
  position: absolute;
  top: 10px;
  left: 10px;
  right: 10px;
  bottom: 38px; /* leave caption visible */
  pointer-events: none;
  background: linear-gradient(180deg,
    rgba(178, 175, 167, 0.06) 0%,
    rgba(178, 175, 167, 0.04) 50%,
    rgba(120, 95, 85, 0.06) 100%
  );
  mix-blend-mode: overlay;
}

.personnel-dossier__portrait-caption {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: 10px;
  padding-top: 8px;
  border-top: 1px solid var(--bomb-iron);
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.28em;
  color: var(--bomb-ash);
  text-transform: uppercase;
}

.personnel-dossier__portrait-caption span:first-child {
  color: var(--bomb-amber);
}

/* --- Personnel metadata block ---------------------------------------- */

.personnel-dossier__metadata {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* --- Narrative column — preserves the original 2010 bio voice ------- */

.personnel-dossier__narrative {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: 15px;
  line-height: 1.8;
  color: var(--bomb-bone);
  max-width: 65ch;
}

.personnel-dossier__narrative p {
  margin: 0 0 22px 0;
}

.personnel-dossier__narrative p:last-child {
  margin-bottom: 0;
}

.personnel-dossier__narrative em {
  font-style: italic;
  color: var(--bomb-fog);
}

.personnel-dossier__narrative strong {
  /* Reserved for TEH BOMBRING SOUND and similar emphatic phrases.
     Slight upgrade in weight + cyan offset, matching the site's
     emphatic typography vocabulary. */
  font-weight: 500;
  color: var(--bomb-fog);
  letter-spacing: 0.02em;
}

/* --- Per-dossier footer ----------------------------------------------- */

.personnel-dossier__footer {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: 48px;
  padding-top: 18px;
  border-top: 1px solid var(--bomb-iron);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.3em;
  color: var(--bomb-ash);
  text-transform: uppercase;
}

.personnel-dossier__footer span:first-child {
  color: var(--bomb-bone);
}

/* --- Animations ------------------------------------------------------- */

.page-dossier .organization-file,
.page-dossier .personnel-dossier {
  animation: fade-up 0.7s ease-out both;
}

.page-dossier .organization-file              { animation-delay: 1.3s; }
.page-dossier .personnel-dossier:nth-of-type(1) { animation-delay: 1.45s; }
.page-dossier .personnel-dossier:nth-of-type(2) { animation-delay: 1.6s; }
.page-dossier .personnel-dossier:nth-of-type(3) { animation-delay: 1.75s; }

/* --- Responsive ------------------------------------------------------- */

@media (max-width: 1100px) {
  .organization-file__body,
  .personnel-dossier__body {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .personnel-dossier__portrait {
    width: 180px;
  }
}

@media (max-width: 900px) {
  .dossier-archive {
    padding: 0 28px 60px 28px;
  }

  .organization-file__header,
  .personnel-dossier__header {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .organization-file__title::before,
  .organization-file__title::after,
  .personnel-dossier__name::before,
  .personnel-dossier__name::after { display: none; }

  .organization-file__title,
  .personnel-dossier__name { padding: 0; }

  .dossier-meta-row {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .personnel-dossier__portrait {
    width: 160px;
  }
}
