/* Feldstein Family Law — Single Blog Post Styles
   Migrated by Hephaestus migrate-template from
   feldstein-source/v1a-round2/templates/single-blog-post.html.

   Global tokens (--navy, --wine, --cream, --serif, --sans, --ease, etc.)
   live in global.css. CTA band, Locations band, Locations bar, and
   .overline / .container / .rv reveal also live in global.css.
   This file holds only single-post-specific styles.
*/

/* =========================================
   ARTICLE HERO
   ========================================= */
.article-hero {
  padding: 180px 48px 60px;
  background: var(--cream);
  text-align: center;
}
.article-hero-inner {
  max-width: 820px;
  margin: 0 auto;
}
.article-category {
  display: inline-block;
  background: var(--wine);
  color: #fff !important;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  padding: 7px 16px;
  border-radius: 2px;
  margin-bottom: 28px;
  transition: background .25s var(--ease), color .25s var(--ease);
}
a.article-category:hover { background: var(--wine-deep); color: #fff !important; }
[data-theme="dark"] .article-category { color: #fff !important; }
[data-theme="dark"] a.article-category:hover { color: #fff !important; }
.article-hero h1 {
  font-family: var(--serif);
  font-size: clamp(2.2rem, 4.2vw, 3.4rem);
  font-weight: 500;
  line-height: 1.18;
  color: var(--ink);
  letter-spacing: -0.4px;
  margin-bottom: 28px;
}
.article-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 14px;
  font-size: 0.88rem;
  color: var(--ink-soft);
  margin-bottom: 36px;
}
.article-meta .meta-sep { color: var(--ink-muted); opacity: 0.5; }
.article-meta .meta-author { color: var(--wine); font-weight: 600; }
.article-hero-rule {
  width: 60px;
  height: 1px;
  background: var(--wine);
  margin: 0 auto;
}

/* =========================================
   TOC BAR — populated by post.js from H2s
   ========================================= */
.article-toc {
  background: var(--wine-soft);
  border-top: 1px solid rgba(137, 46, 83, 0.15);
  border-bottom: 1px solid rgba(137, 46, 83, 0.15);
  padding: 22px 48px;
}
.article-toc[hidden] { display: none; }
.article-toc-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px 28px;
  justify-content: center;
}
.article-toc-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--wine);
  margin-right: 12px;
}
.article-toc-inner a {
  font-size: 0.85rem;
  color: var(--ink-soft);
  transition: color .3s var(--ease);
}
.article-toc-inner a:hover { color: var(--wine); }

/* =========================================
   ARTICLE BODY + SIDEBAR
   ========================================= */
.article-body-section {
  padding: 80px 48px 100px;
  background: var(--cream);
}
.article-body-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 72px;
  align-items: flex-start;
}
.article-prose {
  max-width: 720px;
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--ink);
}
.article-prose p { margin-bottom: 22px; color: var(--ink); }
.article-prose p.lead {
  font-size: 1.18rem;
  line-height: 1.75;
  color: var(--ink-soft);
  margin-bottom: 32px;
}
.article-prose h2 {
  font-family: var(--serif);
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.22;
  color: var(--ink);
  margin: 48px 0 20px;
  letter-spacing: -0.2px;
  scroll-margin-top: 120px;
}
.article-prose h2:first-child { margin-top: 0; }
.article-prose h3 {
  font-family: var(--serif);
  font-size: 1.3rem;
  font-weight: 500;
  color: var(--ink);
  margin: 32px 0 14px;
  scroll-margin-top: 120px;
}
.article-prose strong { color: var(--wine); font-weight: 600; }
.article-prose ul,
.article-prose ol {
  margin: 18px 0 26px 22px;
  padding-left: 0;
}
.article-prose li { margin-bottom: 10px; padding-left: 8px; }
.article-prose li::marker { color: var(--wine); }
.article-prose a {
  color: var(--wine);
  border-bottom: 1px solid rgba(137, 46, 83, 0.3);
  transition: border-color .3s var(--ease);
}
.article-prose a:hover { border-bottom-color: var(--wine); }
.article-prose .pullquote,
.article-prose blockquote {
  background: var(--wine-soft);
  border-left: 3px solid var(--wine);
  padding: 28px 32px;
  margin: 36px 0;
  border-radius: 2px;
  font-family: var(--serif);
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 1.45;
  color: var(--ink);
}
.article-prose .article-close {
  margin-top: 40px;
  padding-top: 28px;
  border-top: 1px solid var(--border);
  font-size: 1.02rem;
  color: var(--ink-soft);
  line-height: 1.8;
}
.article-prose .article-close strong { color: var(--wine); }
.article-prose img,
.article-prose figure {
  margin: 28px 0;
  border-radius: 2px;
}
.article-prose figcaption {
  font-size: 0.82rem;
  color: var(--ink-muted);
  margin-top: 8px;
  font-style: italic;
}

/* =========================================
   STICKY SIDEBAR
   ========================================= */
.article-sidebar { position: sticky; top: 120px; }

.sidebar-form {
  background: var(--cream);
  border: 1px solid var(--border);
  border-top: 4px solid var(--wine);
  border-radius: 3px;
  padding: 36px 28px 32px;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.08), 0 2px 8px rgba(0, 0, 0, 0.04);
}
.sidebar-form h3 {
  font-family: var(--serif);
  font-size: 1.4rem;
  font-weight: 500;
  color: var(--ink);
  margin: 0 0 6px;
  line-height: 1.25;
}
.sidebar-form .sf-sub,
.sidebar-form .sticky-form-sub {
  font-size: 0.88rem;
  color: var(--ink-soft);
  margin: 0 0 22px;
  line-height: 1.6;
}
.sidebar-form .sf-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 14px;
}
.sidebar-form .sf-row .sf-field { margin-bottom: 0; }
.sidebar-form .sf-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 14px;
}
.sidebar-form .sf-field label {
  font-family: var(--sans);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--wine);
}
.sidebar-form .sf-field input,
.sidebar-form .sf-field select,
.sidebar-form .sf-field textarea {
  font-family: var(--sans);
  font-size: 0.92rem;
  padding: 11px 14px;
  border: 1px solid var(--border);
  border-radius: 2px;
  background: #fff;
  color: var(--ink);
  transition: border-color .25s var(--ease), box-shadow .25s var(--ease);
  outline: none;
}
.sidebar-form .sf-field input::placeholder,
.sidebar-form .sf-field textarea::placeholder { color: var(--ink-muted); }
.sidebar-form .sf-field select { cursor: pointer; }
.sidebar-form .sf-field select option { color: var(--ink); background: #fff; }
.sidebar-form .sf-field input:hover,
.sidebar-form .sf-field select:hover,
.sidebar-form .sf-field textarea:hover { border-color: #c9c2b5; }
.sidebar-form .sf-field input:focus,
.sidebar-form .sf-field select:focus,
.sidebar-form .sf-field textarea:focus {
  border-color: var(--wine);
  box-shadow: 0 0 0 3px rgba(137, 46, 83, 0.12);
}
.sidebar-form .sf-field textarea {
  resize: vertical;
  min-height: 80px;
  font-family: var(--sans);
  line-height: 1.55;
}
.sidebar-form .sf-helper {
  font-size: 0.72rem;
  color: var(--ink-muted);
  line-height: 1.55;
  font-style: italic;
  margin: -4px 0 4px;
}
.sidebar-form .sf-submit,
.sidebar-form button[type="submit"] {
  display: block;
  width: 100%;
  background: var(--wine);
  color: #fff;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  padding: 16px 20px;
  border: none;
  border-radius: 2px;
  cursor: pointer;
  transition: background .25s var(--ease), transform .25s var(--ease), box-shadow .25s var(--ease);
  margin-top: 6px;
}
.sidebar-form .sf-submit:hover,
.sidebar-form button[type="submit"]:hover {
  background: var(--wine-deep);
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(137, 46, 83, 0.22);
}
.sidebar-form .sf-disclaimer {
  font-size: 0.72rem;
  color: var(--ink-soft);
  line-height: 1.55;
  margin: 12px 0 0;
}

.sidebar-phone {
  text-align: center;
  margin-top: 36px;
  padding: 28px 20px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 2px;
}
.sidebar-phone .sidebar-phone-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 10px;
  display: block;
}
.sidebar-phone a {
  font-family: var(--serif);
  font-size: 1.85rem;
  font-weight: 600;
  color: var(--wine);
  letter-spacing: 0.5px;
  display: block;
  transition: color .3s var(--ease);
}
.sidebar-phone a:hover { color: var(--wine-deep); }
.sidebar-phone .sidebar-phone-note {
  font-size: 0.78rem;
  color: var(--ink-muted);
  margin-top: 8px;
}

.sidebar-related {
  margin-top: 36px;
  padding: 28px 24px;
  background: var(--warm);
  border-radius: 2px;
}
.sidebar-related-title {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--wine);
  margin-bottom: 16px;
}
.sidebar-related ul { list-style: none; padding: 0; margin: 0; }
.sidebar-related li {
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
}
.sidebar-related li:last-child { border-bottom: none; }
.sidebar-related a {
  font-size: 0.92rem;
  color: var(--ink);
  line-height: 1.5;
  transition: color .3s var(--ease);
  display: block;
}
.sidebar-related a:hover { color: var(--wine); }

/* =========================================
   RELATED POSTS — section wrapper.
   Cards render via ffl_render_blog_card() (.blog-card).
   The .blog-card rules below mirror archive.css so the cards
   render correctly when archive.css is not enqueued on singles.
   ========================================= */
.single-post + .blogroll,
article.single-post ~ .blogroll {
  /* spacing handled by section padding */
}
.blogroll {
  padding: 100px 0;
  background: var(--warm);
}
.blogroll-header {
  max-width: 720px;
  margin-bottom: 56px;
}
.blogroll-header .overline { margin-bottom: 20px; }
.blogroll-header h2 {
  font-family: var(--serif);
  font-size: clamp(2rem, 3.5vw, 2.6rem);
  font-weight: 500;
  line-height: 1.18;
  color: var(--ink);
  margin-bottom: 12px;
}
.blogroll-header p {
  font-size: 1rem;
  color: var(--ink-soft);
  line-height: 1.8;
}
.blogroll-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

/* .blog-card mirror — produced by ffl_render_blog_card() */
.blogroll-grid .blog-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 2px;
  overflow: hidden;
  transition: border-color .3s var(--ease), box-shadow .3s var(--ease), transform .3s var(--ease);
  display: flex;
  flex-direction: column;
}
.blogroll-grid .blog-card:hover {
  border-color: var(--wine);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.04);
  transform: translateY(-3px);
}
.blogroll-grid .blog-card-image {
  display: block;
  overflow: hidden;
  aspect-ratio: 16 / 10;
  background: var(--warm);
}
.blogroll-grid .blog-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s var(--ease);
}
.blogroll-grid .blog-card:hover .blog-card-image img { transform: scale(1.04); }
.blogroll-grid .blog-card-content { padding: 28px 24px; }
.blogroll-grid .blog-card-category {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--wine);
  margin: 0 0 12px;
}
.blogroll-grid .blog-card-category a { color: inherit; }
.blogroll-grid .blog-card h3 {
  font-family: var(--serif);
  font-size: 1.15rem;
  font-weight: 500;
  line-height: 1.35;
  color: var(--ink);
  margin: 0 0 10px;
}
.blogroll-grid .blog-card h3 a { color: inherit; transition: color .25s var(--ease); }
.blogroll-grid .blog-card h3 a:hover { color: var(--wine); }
.blogroll-grid .blog-card-excerpt {
  font-size: 0.88rem;
  line-height: 1.75;
  color: var(--ink-soft);
  margin: 0 0 16px;
}
.blogroll-grid .blog-card-meta {
  font-size: 0.78rem;
  color: var(--ink-muted);
  margin: 0;
}

/* =========================================
   RESPONSIVE — 1024px
   ========================================= */
@media (max-width: 1024px) {
  .article-body-inner { grid-template-columns: 1fr 340px; gap: 48px; }
  .blogroll-grid { gap: 20px; }
}

/* =========================================
   RESPONSIVE — 768px
   ========================================= */
@media (max-width: 768px) {
  .article-hero { padding: 140px 24px 48px; }
  .article-hero h1 { font-size: clamp(1.8rem, 7vw, 2.4rem); }
  .article-meta { gap: 8px; font-size: 0.82rem; }

  .article-toc { padding: 18px 24px; }
  .article-toc-inner { gap: 8px 18px; justify-content: flex-start; }
  .article-toc-label { width: 100%; margin-bottom: 4px; }

  .article-body-section { padding: 56px 24px 72px; }
  .article-body-inner { grid-template-columns: 1fr; gap: 56px; }
  .article-prose { max-width: 100%; font-size: 1rem; }
  .article-prose h2 { font-size: 1.5rem; margin: 36px 0 16px; }
  .article-prose .pullquote,
  .article-prose blockquote { padding: 22px 24px; font-size: 1.15rem; margin: 28px 0; }

  .article-sidebar { position: relative; top: auto; }
  .sidebar-form { padding: 32px 22px 28px; }

  .blogroll { padding: 72px 0; }
  .blogroll-grid { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; }
}

/* =========================================
   RESPONSIVE — 480px
   ========================================= */
@media (max-width: 480px) {
  .article-hero { padding: 120px 20px 40px; }
  .article-body-section { padding: 48px 20px 64px; }
  .sidebar-form { padding: 28px 20px 24px; }
}

/* =========================================
   DARK MODE
   ========================================= */
[data-theme="dark"] .article-hero { background: #0a1520; }
[data-theme="dark"] .article-hero h1 { color: #e8f0f5; }
[data-theme="dark"] .article-meta { color: #b8cbd6; }
[data-theme="dark"] .article-meta .meta-author { color: #d99fb5; }

[data-theme="dark"] .article-body-section { background: #0a1520; }
[data-theme="dark"] .article-prose,
[data-theme="dark"] .article-prose p,
[data-theme="dark"] .article-prose li { color: #b8cbd6; }
[data-theme="dark"] .article-prose h2,
[data-theme="dark"] .article-prose h3 { color: #e8f0f5; }
[data-theme="dark"] .article-prose strong { color: #d99fb5; }
[data-theme="dark"] .article-prose .pullquote,
[data-theme="dark"] .article-prose blockquote {
  background: rgba(137, 46, 83, 0.18);
  color: #e8f0f5;
}
[data-theme="dark"] .article-prose .article-close {
  border-top-color: #1e3549;
  color: #b8cbd6;
}
[data-theme="dark"] .article-prose a {
  color: #d99fb5;
  border-bottom-color: rgba(217, 159, 181, 0.35);
}
[data-theme="dark"] .article-prose a:hover { border-bottom-color: #d99fb5; }

[data-theme="dark"] .article-toc {
  background: rgba(137, 46, 83, 0.15);
  border-color: #1e3549;
}
[data-theme="dark"] .article-toc-inner a { color: #e8f0f5; }
[data-theme="dark"] .article-toc-inner a:hover { color: #d99fb5; }

[data-theme="dark"] .sidebar-form {
  background: #111f2e;
  border-color: #1e3549;
  border-top-color: var(--wine);
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.5);
}
[data-theme="dark"] .sidebar-form h3 { color: #e8f0f5; }
[data-theme="dark"] .sidebar-form .sf-sub,
[data-theme="dark"] .sidebar-form .sticky-form-sub { color: #b8cbd6; }
[data-theme="dark"] .sidebar-form .sf-field input,
[data-theme="dark"] .sidebar-form .sf-field select,
[data-theme="dark"] .sidebar-form .sf-field textarea {
  background: #0a1520;
  border-color: #1e3549;
  color: #e8f0f5;
}
[data-theme="dark"] .sidebar-form .sf-field input::placeholder,
[data-theme="dark"] .sidebar-form .sf-field textarea::placeholder { color: #7a9aac; }
[data-theme="dark"] .sidebar-form .sf-field select option { background: #0a1520; color: #e8f0f5; }
[data-theme="dark"] .sidebar-form .sf-field input:hover,
[data-theme="dark"] .sidebar-form .sf-field select:hover,
[data-theme="dark"] .sidebar-form .sf-field textarea:hover { border-color: #2a4a68; }
[data-theme="dark"] .sidebar-form .sf-field input:focus,
[data-theme="dark"] .sidebar-form .sf-field select:focus,
[data-theme="dark"] .sidebar-form .sf-field textarea:focus {
  border-color: var(--wine);
  box-shadow: 0 0 0 3px rgba(137, 46, 83, 0.2);
}
[data-theme="dark"] .sidebar-form .sf-helper { color: #7a9aac; }
[data-theme="dark"] .sidebar-form .sf-disclaimer { color: #b8cbd6; }

[data-theme="dark"] .sidebar-phone {
  background: #111f2e;
  border-color: #1e3549;
}
[data-theme="dark"] .sidebar-phone .sidebar-phone-label { color: #7a9aac; }
[data-theme="dark"] .sidebar-phone a { color: #d99fb5; }
[data-theme="dark"] .sidebar-phone a:hover { color: #e8b6c6; }
[data-theme="dark"] .sidebar-phone .sidebar-phone-note { color: #7a9aac; }

[data-theme="dark"] .sidebar-related { background: #11212d; }
[data-theme="dark"] .sidebar-related-title { color: #d99fb5; }
[data-theme="dark"] .sidebar-related li { border-bottom-color: #1e3549; }
[data-theme="dark"] .sidebar-related a { color: #e8f0f5; }
[data-theme="dark"] .sidebar-related a:hover { color: #d99fb5; }

[data-theme="dark"] .blogroll { background: #11212d; }
[data-theme="dark"] .blogroll-header h2 { color: #e8f0f5; }
[data-theme="dark"] .blogroll-header p { color: #b8cbd6; }
[data-theme="dark"] .blogroll-grid .blog-card {
  background: #0d1c28;
  border-color: #1e3549;
}
[data-theme="dark"] .blogroll-grid .blog-card:hover {
  background: #16263a;
  border-color: var(--wine);
}
[data-theme="dark"] .blogroll-grid .blog-card h3,
[data-theme="dark"] .blogroll-grid .blog-card h3 a { color: #e8f0f5; }
[data-theme="dark"] .blogroll-grid .blog-card h3 a:hover { color: #d99fb5; }
[data-theme="dark"] .blogroll-grid .blog-card-excerpt { color: #b8cbd6; }
[data-theme="dark"] .blogroll-grid .blog-card-meta { color: #7a9aac; }
[data-theme="dark"] .blogroll-grid .blog-card-category,
[data-theme="dark"] .blogroll-grid .blog-card-category a { color: #d99fb5; }
