/*
Theme Name:   HEROIC 3.0
Theme URI:    https://heroic.com/
Author:       DreamWeb Studio
Description:  HEROIC 3.0 theme. Owns the blog post template and its CSS.
Version:      1.0.5
Text Domain:  heroic-3-0
*/

/* ==========================================================================
   HEROIC -- Blog post template
   ========================================================================== */

/* --- Layout width: hero + content match at 1100px --------------------- */
.hrc-post-hero .hrc-container,
.hrc-post-body .hrc-container,
.hrc-post-author-wrap .hrc-container,
.hrc-post-related .hrc-container {
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--hrc-space-lg, 1.75rem);
  padding-right: var(--hrc-space-lg, 1.75rem);
}

/* --- POST HERO -------------------------------------------------------- */
.hrc-post-hero {
  position: relative;
  background: var(--hrc-color-bg-navy, #0b0e1a);
  color: var(--hrc-white, #ffffff);
  padding-block: calc(72px + var(--hrc-space-2xl, 3rem)) var(--hrc-space-3xl, 4rem);
  text-align: left;
  overflow: hidden;
}
.hrc-post-hero::before {
  content: "";
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse at 20% 0%, rgba(186,2,2,0.20) 0%, transparent 55%),
    radial-gradient(ellipse at 80% 100%, rgba(30,120,220,0.16) 0%, transparent 55%);
}
.hrc-post-hero .hrc-container { position: relative; z-index: 1; }
.hrc-post-hero__title {
  font-family: var(--hrc-font-heading, sans-serif); font-weight: 700;
  font-size: clamp(2.25rem, 1.3rem + 3.4vw, 3.75rem);
  line-height: 1.12; letter-spacing: -0.015em;
  color: var(--hrc-white, #fff);
  margin: 0 0 var(--hrc-space-xl, 2rem);
  max-width: 22ch;
}

/* --- HERO META (cleaner: body font, not italic, more breathing) ------- */
.hrc-post-hero__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
  font-family: var(--hrc-font-body, sans-serif);
  font-weight: 400;
  font-style: normal;
  font-size: 15px;
  letter-spacing: 0.01em;
  color: rgba(255,255,255,0.85);
}
.hrc-post-hero__meta > span {
  display: inline-flex;
  align-items: center;
  line-height: 1;
}
.hrc-post-hero__sep {
  display: inline-block;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: rgba(255,255,255,0.4);
  padding: 0 !important;
  margin: 0 2px;
}

/* --- FEATURED IMAGE (slim cinematic strip) ---------------------------- */
.hrc-post-thumb {
  max-width: 880px;
  margin: 0 auto var(--hrc-space-2xl, 3rem);
  padding: 0 var(--hrc-space-lg, 1.75rem);
  position: relative;
  z-index: 2;
}
.hrc-post-thumb__img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 320px;
  aspect-ratio: 21 / 9;
  object-fit: cover;
  object-position: center;
  border-radius: 12px;
}

/* --- POST BODY -------------------------------------------------------- */
.hrc-post-body {
  padding-block: var(--hrc-space-2xl, 3rem) var(--hrc-space-4xl, 6rem);
  background: var(--hrc-white, #ffffff);
}
.hrc-post-content {
  width: 100%;
  max-width: none;
  margin: 0;
}

/* --- PROSE (output of the_content()) ---------------------------------- */
.hrc-prose {
  font-family: var(--hrc-font-body, sans-serif);
  font-weight: 300;
  font-size: 0.9375rem;
  line-height: 1.75;
  color: var(--hrc-text-body, #454545);
}
.hrc-prose > * + * { margin-top: var(--hrc-space-md, 1.25rem); }
.hrc-prose h2 {
  font-family: var(--hrc-font-heading, sans-serif); font-weight: 700;
  font-size: clamp(1.375rem, 0.95rem + 1.2vw, 1.75rem);
  line-height: 1.25; letter-spacing: -0.01em;
  color: var(--hrc-text-heading, #1d1d1d);
  margin: var(--hrc-space-2xl, 3rem) 0 var(--hrc-space-md, 1.25rem);
}
.hrc-prose h3 {
  font-family: var(--hrc-font-heading, sans-serif); font-weight: 700;
  font-size: 1.25rem; line-height: 1.3;
  color: var(--hrc-text-heading, #1d1d1d);
  margin: var(--hrc-space-xl, 2rem) 0 var(--hrc-space-sm, 0.75rem);
}
.hrc-prose h4 {
  font-family: var(--hrc-font-heading, sans-serif); font-weight: 700;
  font-size: 1.0625rem;
  color: var(--hrc-text-heading, #1d1d1d);
  margin: var(--hrc-space-lg, 1.75rem) 0 var(--hrc-space-sm, 0.75rem);
}
.hrc-prose p { margin: 0 0 var(--hrc-space-md, 1.25rem); }
.hrc-prose a {
  color: var(--hrc-primary, #ba0202);
  text-decoration: underline; text-underline-offset: 3px;
  text-decoration-thickness: 1px; transition: color .2s ease;
}
.hrc-prose a:hover { color: var(--hrc-primary-dark, #8a0101); }
.hrc-prose strong { color: var(--hrc-text-heading, #1d1d1d); font-weight: 600; }
.hrc-prose em { font-style: italic; }
.hrc-prose ul, .hrc-prose ol {
  padding-left: var(--hrc-space-lg, 1.75rem);
  margin: var(--hrc-space-md, 1.25rem) 0 var(--hrc-space-lg, 1.75rem);
}
.hrc-prose li { margin: 0 0 var(--hrc-space-sm, 0.75rem); }
.hrc-prose blockquote {
  margin: var(--hrc-space-xl, 2rem) 0;
  padding: var(--hrc-space-md, 1.25rem) var(--hrc-space-lg, 1.75rem);
  border-left: 3px solid var(--hrc-primary, #ba0202);
  background: var(--hrc-color-bg-alt, #f5f5f7);
  font-family: var(--hrc-font-highlight, sans-serif);
  font-style: italic; font-size: 1.0625rem; line-height: 1.55;
  color: var(--hrc-text-heading, #1d1d1d);
  border-radius: 0 8px 8px 0;
}
.hrc-prose blockquote p:last-child { margin-bottom: 0; }
.hrc-prose code {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 0.9em;
  background: var(--hrc-color-bg-alt, #f5f5f7);
  padding: 2px 6px; border-radius: 4px;
  color: var(--hrc-text-heading, #1d1d1d);
}
.hrc-prose pre {
  margin: var(--hrc-space-lg, 1.75rem) 0;
  padding: var(--hrc-space-md, 1.25rem) var(--hrc-space-lg, 1.75rem);
  background: var(--hrc-color-bg-navy, #0b0e1a);
  color: rgba(255,255,255,0.9);
  border-radius: 10px; overflow-x: auto;
  font-size: 0.875rem; line-height: 1.55;
}
.hrc-prose pre code { background: transparent; padding: 0; color: inherit; font-size: inherit; }
.hrc-prose hr {
  border: 0; border-top: 1px solid var(--hrc-border, #e5e7eb);
  margin: var(--hrc-space-2xl, 3rem) 0;
}
.hrc-prose img, .hrc-prose figure {
  display: block; max-width: 100%; height: auto;
  margin: var(--hrc-space-xl, 2rem) auto;
  border-radius: 10px;
}
.hrc-prose figure img { margin: 0 auto; }
.hrc-prose figcaption {
  font-family: var(--hrc-font-highlight, sans-serif);
  font-style: italic; font-size: 0.85rem;
  color: var(--hrc-text-muted, #666);
  text-align: center; margin-top: var(--hrc-space-sm, 0.75rem);
}
.hrc-prose .wp-block-embed, .hrc-prose iframe {
  display: block; width: 100%;
  margin: var(--hrc-space-xl, 2rem) 0; border-radius: 10px;
}
.hrc-prose table {
  width: 100%; border-collapse: collapse;
  margin: var(--hrc-space-lg, 1.75rem) 0; font-size: 0.9rem;
}
.hrc-prose th, .hrc-prose td {
  padding: var(--hrc-space-sm, 0.75rem) var(--hrc-space-md, 1.25rem);
  border-bottom: 1px solid var(--hrc-border, #e5e7eb);
  text-align: left;
}
.hrc-prose th { color: var(--hrc-text-heading, #1d1d1d); font-weight: 600; }

/* --- TAG PILLS -------------------------------------------------------- */
.hrc-post-tags {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-top: var(--hrc-space-2xl, 3rem);
  padding-top: var(--hrc-space-lg, 1.75rem);
  border-top: 1px solid var(--hrc-border, #e5e7eb);
}
.hrc-post-tag {
  display: inline-block; padding: 6px 12px;
  font-family: var(--hrc-font-body, sans-serif);
  font-weight: 500;
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--hrc-text-muted, #666);
  background: var(--hrc-color-bg-alt, #f5f5f7);
  border-radius: 999px;
  text-decoration: none;
  transition: background .2s ease, color .2s ease;
}
.hrc-post-tag:hover { background: var(--hrc-primary, #ba0202); color: var(--hrc-white, #fff); }

/* --- AUTHOR BIO (cleaner, tighter, more breathing) ------------------- */
.hrc-post-author-wrap {
  padding-block: var(--hrc-space-3xl, 4rem);
  background: var(--hrc-color-bg-alt, #f5f5f7);
  border-top: 1px solid var(--hrc-border, #e5e7eb);
}
.hrc-post-author {
  background: white;
	border-radius: 10px;
	padding: 10px;
  margin: 0 auto;
  display: flex;
  gap: 24px;
  align-items: center;
  text-align: left;
}
.hrc-post-author__avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  flex-shrink: 0;
  object-fit: cover;
  border: 2px solid var(--hrc-white, #fff);
  box-shadow: 0 2px 8px rgba(11,14,26,0.06);
}
.hrc-post-author__eyebrow {
  font-family: var(--hrc-font-body, sans-serif);
  font-weight: 500;
  font-style: normal;
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--hrc-text-muted, #888);
  margin: 0 0 6px;
}
.hrc-post-author__name {
  font-family: var(--hrc-font-heading, sans-serif);
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.2;
  color: var(--hrc-text-heading, #1d1d1d);
  margin: 0 0 4px;
}
.hrc-post-author__bio {
  font-family: var(--hrc-font-body, sans-serif);
  font-weight: 300;
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--hrc-text-muted, #666);
  margin: 0;
}

/* --- RELATED POSTS ("More from HEROIC" white cards) ------------------ */
.hrc-post-related {
  padding-block: var(--hrc-space-4xl, 6rem);
  background: var(--hrc-color-bg-alt, #f5f5f7);
}
.hrc-post-related__heading {
  font-family: var(--hrc-font-heading, sans-serif);
  font-weight: 700;
  font-size: clamp(1.375rem, 0.95rem + 1.2vw, 1.75rem);
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--hrc-text-heading, #1d1d1d);
  margin: 0 0 var(--hrc-space-xl, 2rem);
}
.hrc-post-card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.hrc-post-card {
  display: flex;
  flex-direction: column;
  background: white;
  border: 1px solid rgba(11,14,26,0.06);
  border-radius: 14px;
  overflow: hidden;
  text-decoration: none;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.hrc-post-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 36px rgba(11,14,26,0.10);
  border-color: rgba(11,14,26,0.10);
}
.hrc-post-card__thumb {
  aspect-ratio: 16 / 9;
  background: var(--hrc-color-bg-alt, #f5f5f7);
  overflow: hidden;
}
.hrc-post-card__img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .35s ease;
}
.hrc-post-card:hover .hrc-post-card__img { transform: scale(1.04); }
.hrc-post-card__body {
  padding: 20px 22px 22px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.hrc-post-card__cat {
  font-family: var(--hrc-font-body, sans-serif);
  font-weight: 500;
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--hrc-primary, #ba0202);
}
.hrc-post-card__title {
  font-family: var(--hrc-font-heading, sans-serif);
  font-weight: 700;
  font-size: 1.0625rem;
  line-height: 1.35;
  color: var(--hrc-text-heading, #1d1d1d);
  margin: 0;
}
.hrc-post-card__date {
  font-family: var(--hrc-font-body, sans-serif);
  font-weight: 400;
  font-size: 0.8125rem;
  color: var(--hrc-text-muted, #888);
  margin: auto 0 0;
  padding-top: 8px;
}

/* --- Responsive ------------------------------------------------------- */
@media (max-width: 900px) {
  .hrc-post-card-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .hrc-post-card-grid { grid-template-columns: 1fr; }
  .hrc-post-author { flex-direction: column; align-items: flex-start; gap: 16px; text-align: left; }
  .hrc-post-hero { padding-block: calc(72px + var(--hrc-space-xl, 2rem)) var(--hrc-space-2xl, 3rem); }
  .hrc-post-thumb__img { max-height: 220px; aspect-ratio: 16 / 9; }
}