/* ==========================================================================
   EGT Single Post — video facade, 2-col body grid, sidebar, bridge, related.
   Loaded only on is_single().
   ========================================================================== */

/* ── Post hero ──────────────────────────────────────────────────────────── */
.phead { padding: var(--space-12) 0; }
.phead .crumb { margin-bottom: var(--space-4); }
.phead h1 { font-size: clamp(2rem, 4.5vw, 3rem); }

/* ── Video wrapper ──────────────────────────────────────────────────────── */
.vwrap {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: #000;
  margin: var(--space-10) 0;
  aspect-ratio: 16 / 9;
}
.vwrap iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}
.egt-facade {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
}
.egt-facade img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.egt-facade .play {
  position: relative;
  z-index: 1;
  width: 68px;
  height: 68px;
  border-radius: 50%;
  background: var(--brand);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(0,0,0,0.4);
  transition: transform var(--transition-fast), background var(--transition-fast);
}
.egt-facade:hover .play { background: var(--brand-hover); transform: scale(1.08); }
.egt-facade .play svg { color: #fff; }
.vcap {
  font-size: 0.88rem;
  color: var(--ink-muted);
  margin-top: var(--space-3);
  font-style: italic;
}

/* ── Body grid ──────────────────────────────────────────────────────────── */
.body-grid {
  max-width: 1140px;
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--space-14);
  align-items: start;
  padding: var(--space-10) var(--space-6) var(--space-16);
}

/* ── Article prose ──────────────────────────────────────────────────────── */
.article {
  font-size: 1.13rem;
  line-height: var(--leading-loose);
  color: var(--ink-body);
}
.article p { margin-bottom: var(--space-5); }
.article h2 { font-size: 1.75rem; margin: var(--space-10) 0 var(--space-4); }
.article h3 { font-size: 1.35rem; margin: var(--space-8) 0 var(--space-3); }
.article h4 { font-size: 1.12rem; margin: var(--space-6) 0 var(--space-2); }
.article strong { color: var(--ink-heading); }
.article a { color: var(--brand-strong); }
.article ul, .article ol { margin: 0 0 var(--space-5) var(--space-6); }
.article li { margin-bottom: var(--space-2); }
.article blockquote.pull {
  border-left: 4px solid var(--brand);
  padding: var(--space-5) var(--space-6);
  margin: var(--space-8) 0;
  background: var(--brand-wash);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-size: 1.22rem;
  font-style: italic;
  color: var(--ink-heading);
}
.article figure { margin: var(--space-8) 0; }
.article figcaption { font-size: 0.86rem; color: var(--ink-muted); text-align: center; margin-top: var(--space-3); }

/* ── Post-inline FAQ ─────────────────────────────────────────────────────── */
.article .faq { max-width: 100%; margin: var(--space-10) 0; }

/* ── GTU bridge (inline affiliate band) ─────────────────────────────────── */
.bridge {
  border-radius: var(--radius-lg);
  background: var(--dark);
  color: var(--on-dark-muted);
  padding: var(--space-10) var(--space-10);
  margin: var(--space-12) 0;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-8);
  align-items: center;
}
.bridge-copy .eyebrow { color: #5FD6CB; margin-bottom: var(--space-2); }
.bridge-copy h3 { color: #fff; font-size: 1.3rem; margin-bottom: 0.4rem; }
.bridge-copy p { color: var(--on-dark-muted); font-size: 0.96rem; }
@media (max-width: 680px) {
  .bridge { grid-template-columns: 1fr; }
}

/* ── Sidebar ────────────────────────────────────────────────────────────── */
.sidebar { display: grid; gap: var(--space-6); }

/* Dark optin sidebar card */
.s-optin {
  background: var(--dark);
  color: var(--on-dark-muted);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
}
.s-optin .eyebrow { color: #5FD6CB; display: block; margin-bottom: var(--space-2); }
.s-optin h3 { color: #fff; font-size: 1.1rem; margin-bottom: var(--space-4); }
.s-optin .pg-optin-form input[type="email"] {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.15);
  color: #fff;
}
.s-optin .pg-optin-form input[type="email"]::placeholder { color: rgba(255,255,255,0.4); }
.s-optin .optin-fine { color: rgba(255,255,255,0.35); }

/* Sidebar list block */
.s-block {
  background: #fff;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  padding: var(--space-7);
}
.s-block-head {
  font-size: 0.8rem;
  font-weight: var(--weight-semibold);
  letter-spacing: var(--track-eyebrow);
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: var(--space-5);
}
.s-list { list-style: none; display: grid; gap: var(--space-3); }
.s-list a {
  font-size: 0.92rem;
  font-weight: var(--weight-medium);
  color: var(--ink-body);
  text-decoration: none;
  line-height: var(--leading-tight);
}
.s-list a:hover { color: var(--brand-strong); }

@media (max-width: 860px) {
  .body-grid {
    grid-template-columns: 1fr;
  }
  .sidebar { display: contents; }
  .s-optin { order: 10; }
  .s-block { order: 11; }
}

/* ── Related posts ──────────────────────────────────────────────────────── */
.related { padding: var(--space-14) 0; border-top: 1px solid var(--hairline); }
.related-head {
  font-size: 1.4rem;
  color: var(--ink-heading);
  margin-bottom: var(--space-8);
}
.rgrid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
.rcard {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  overflow: hidden;
  text-decoration: none;
  background: #fff;
  transition: box-shadow var(--transition-fast);
}
.rcard:hover { box-shadow: var(--shadow-md); }
.rcard-thumb {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--paper-tint);
}
.rcard-thumb img { width: 100%; height: 100%; object-fit: cover; }
.rcard-body { padding: var(--space-5) var(--space-5) var(--space-6); }
.rcard-cat {
  font-size: 0.75rem;
  font-weight: var(--weight-semibold);
  letter-spacing: var(--track-eyebrow);
  text-transform: uppercase;
  color: var(--brand-strong);
  display: block;
  margin-bottom: var(--space-2);
}
.rcard-body h3 { font-size: 1rem; color: var(--ink-heading); }
@media (max-width: 760px) {
  .rgrid { grid-template-columns: 1fr; }
}
