/* ====================================================================
   Tiddlywinks Blog Template — blog.css
   Added 2026-04-22.
   Scoped with .tw-blog-* class prefix to avoid collisions with main.css.
   Relies on theme globals for typography (soleil), .button variants,
   and .primary-container.
   ==================================================================== */

:root {
  --twb-text: #2e2f33;
  --twb-muted: #919399;
  --twb-border: #d1cbc3;
  --twb-warm: #f6f5f3;
  --twb-warm-2: #e8e5e1;
  --twb-warm-3: #f0eeeb;
  --twb-blue: #84a7c8;
  --twb-tan: #d8ae7d;
  --twb-pink: #c77cb3;
  --twb-indigo: #373b97;
  --twb-reading-max: 760px;
  --twb-radius-card: 20px;
  --twb-radius-media: 24px;
}

/* ====== HERO (single post) ====== */
.tw-blog-hero {
  position: relative;
  overflow: hidden;
  color: #fff;
  padding: 32px 0 48px;
  background-color: var(--twb-text);
  background-size: cover;
  background-position: center;
}
.tw-blog-hero:not(.has-image) {
  background-image: linear-gradient(135deg, #84a7c8 0%, #d8ae7d 55%, #c77cb3 100%);
}
@media (min-width: 1000px) {
  .tw-blog-hero { padding: 40px 0 64px; }
}
.tw-blog-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.25) 40%, rgba(0,0,0,.75) 100%);
  pointer-events: none;
  z-index: 1;
}
/* Explicit min-height on the INNER flex container is the most reliable way
   to get the space-between behaviour (breadcrumbs top, content bottom)
   without depending on flex:1 propagation from the outer hero. */
.tw-blog-hero-inner {
  position: relative;
  z-index: 2;
  width: 85vw;
  margin: 0 auto;
  min-height: 360px;
  display: flex;
  flex-direction: column;
  gap: 40px;
}
@media (min-width: 1000px) {
  .tw-blog-hero-inner {
    max-width: 1600px;
    width: 90vw;
    min-height: 420px;
  }
}
/* Push the title/meta block to the bottom of the hero, regardless of
   outer flex chain. More robust than justify-content: space-between. */
.tw-blog-hero-content { margin-top: auto; }
/* Both breadcrumbs and content sit in a reading-width column, centered,
   so hero text visually lines up with the article body below. */
.tw-blog-breadcrumbs {
  max-width: var(--twb-reading-max);
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  font-size: 13px;
  color: rgba(255,255,255,.8);
}
.tw-blog-breadcrumbs a { color: rgba(255,255,255,.8); }
.tw-blog-breadcrumbs a:hover { color: #fff; }
.tw-blog-breadcrumbs .current { color: #fff; }

.tw-blog-hero-content {
  max-width: var(--twb-reading-max);
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}
.tw-blog-category-pill {
  display: inline-block;
  background: var(--twb-blue);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .5px;
  text-transform: uppercase;
  padding: 8px 16px;
  border-radius: 25px;
  margin-bottom: 32px;
}
.tw-blog-category-pill:hover { opacity: .9; }
.tw-blog-hero h1 {
  color: #fff;
  max-width: 900px;
  margin-bottom: 24px;
  font-size: 36px;
  line-height: 115%;
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
  text-shadow: 0 2px 20px rgba(0,0,0,.3);
}
@media (min-width: 700px) { .tw-blog-hero h1 { font-size: 44px; } }
@media (min-width: 1000px) { .tw-blog-hero h1 { font-size: 56px; line-height: 110%; } }

.tw-blog-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 20px;
  color: rgba(255,255,255,.85);
  font-size: 14px;
}
.tw-blog-meta * { color: inherit; font-size: inherit; }
.tw-blog-dot {
  width: 4px; height: 4px;
  background: rgba(255,255,255,.6);
  border-radius: 50%;
  display: inline-block;
}
.tw-blog-author-mini { display: flex; align-items: center; gap: 10px; }
.tw-blog-author-mini img.tw-blog-avatar,
.tw-blog-author-mini .avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.4);
}
.tw-blog-meta-name { color: #fff; font-weight: 600; }

/* ====== BODY ====== */
.tw-blog-body { padding: 56px 0; }
.tw-blog-reading {
  max-width: var(--twb-reading-max);
  margin: 0 auto;
  width: 100%;
}
.tw-blog-content { font-size: 16px; }
.tw-blog-content p { line-height: 165%; margin-bottom: 20px; }
.tw-blog-content p:last-child { margin-bottom: 0; }
.tw-blog-content h2 {
  font-size: 32px;
  line-height: 120%;
  margin-top: 48px;
  margin-bottom: 20px;
}
@media (min-width: 1000px) { .tw-blog-content h2 { font-size: 36px; } }
.tw-blog-content h2:first-child { margin-top: 0; }
.tw-blog-content h3 {
  font-size: 24px;
  line-height: 125%;
  margin-top: 40px;
  margin-bottom: 16px;
}
.tw-blog-content h4 {
  font-size: 20px;
  margin-top: 32px;
  margin-bottom: 12px;
}
.tw-blog-content a:not(.button) {
  color: var(--twb-indigo);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.tw-blog-content a:not(.button):hover { color: var(--twb-blue); }
/* Buttons (from [cta] shortcode) should never look like prose links. */
.tw-blog-content a.button {
  text-decoration: none;
}
/* Override the theme's global `ul/ol { display: flex; flex-direction: column }`
   so bullets render as a normal block list inside the article body, and
   consecutive single-item lists (Classic Editor quirk) collapse into one
   visual list rather than leaving big vertical gaps between them. */
.tw-blog-content ul,
.tw-blog-content ol {
  display: block;
  list-style-position: outside;
  padding-left: 22px;
  margin: 0 0 20px 0;
}
.tw-blog-content ul { list-style-type: disc; }
.tw-blog-content ol { list-style-type: decimal; }
.tw-blog-content ul + ul,
.tw-blog-content ol + ol {
  margin-top: -10px;
}
.tw-blog-content li {
  margin: 0 0 8px 0;
  padding-left: 4px;
  line-height: 160%;
  display: list-item;
  align-items: initial;
}
.tw-blog-content li:last-child { margin-bottom: 0; }
.tw-blog-content li > p:first-child { margin: 0; }
.tw-blog-content blockquote {
  border-left: 3px solid var(--twb-blue);
  padding: 8px 0 8px 24px;
  margin: 32px 0;
  font-style: italic;
  font-size: 20px;
  line-height: 150%;
}
.tw-blog-content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--twb-radius-media);
  margin: 32px 0;
}

/* ====== TABLE OF CONTENTS ====== */
.tw-blog-toc {
  background: var(--twb-warm);
  border-left: 3px solid var(--twb-blue);
  border-radius: 0 var(--twb-radius-card) var(--twb-radius-card) 0;
  padding: 24px 28px;
  margin-bottom: 40px;
}
.tw-blog-toc[hidden] { display: none; }
.tw-blog-toc-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--twb-blue);
  margin-bottom: 14px;
}
.tw-blog-toc ol {
  counter-reset: twb-toc;
  list-style: none;
  padding: 0;
  margin: 0;
  display: block;
}
.tw-blog-toc ol li {
  counter-increment: twb-toc;
  margin-bottom: 10px;
  line-height: 140%;
  display: flex;
  gap: 18px;
  align-items: baseline;
}
.tw-blog-toc ol li::before {
  content: counter(twb-toc, decimal-leading-zero);
  font-size: 13px;
  font-weight: 700;
  color: var(--twb-muted);
  flex-shrink: 0;
  min-width: 22px;
}
.tw-blog-toc ol li a {
  font-size: 15px;
  font-weight: 600;
  color: var(--twb-text);
  border-bottom: 1px solid transparent;
  transition: border-color .2s ease;
}
.tw-blog-toc ol li a:hover {
  border-bottom-color: var(--twb-blue);
}
.tw-blog-toc ol li.is-h3 { padding-left: 14px; }

/* ====== AUTHOR BIO ====== */
.tw-blog-author-bio {
  background: var(--twb-warm);
  border-radius: var(--twb-radius-card);
  padding: 32px;
  margin-top: 64px;
  display: flex;
  gap: 24px;
  align-items: flex-start;
  flex-wrap: wrap;
}
.tw-blog-author-avatar .avatar,
.tw-blog-author-avatar img {
  width: 80px; height: 80px;
  border-radius: 50%;
  flex-shrink: 0;
}
.tw-blog-author-text { flex: 1; min-width: 200px; }
.tw-blog-author-label {
  font-size: 12px;
  color: var(--twb-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 4px;
}
.tw-blog-author-bio h4 { margin-bottom: 8px; font-size: 20px; }
.tw-blog-author-bio p {
  font-size: 15px;
  line-height: 160%;
  color: var(--twb-muted);
  margin: 0;
}

/* ====== RELATED POSTS ====== */
.tw-blog-related {
  padding: 72px 0;
  background: var(--twb-warm-3);
}
.tw-blog-related-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 40px;
  flex-wrap: wrap;
  gap: 16px;
}
.tw-blog-related-head h2 { margin: 0; }

/* ====== POST GRID ====== */
.tw-blog-post-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
}
@media (min-width: 700px) {
  .tw-blog-post-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1000px) {
  .tw-blog-post-grid { grid-template-columns: repeat(3, 1fr); }
}

.tw-blog-post-card {
  background: #fff;
  border-radius: var(--twb-radius-card);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .3s ease, box-shadow .3s ease;
  color: inherit;
  border: 1px solid transparent;
}
.tw-blog-post-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 40px -20px rgba(46, 47, 51, .15);
}
.tw-blog-thumb {
  aspect-ratio: 16 / 10;
  background-color: var(--twb-warm-2);
  background-size: cover;
  background-position: center;
}
.tw-blog-post-card:nth-child(3n+1) .tw-blog-thumb:not([style*="url"]) { background: linear-gradient(135deg, var(--twb-tan), var(--twb-pink)); }
.tw-blog-post-card:nth-child(3n+2) .tw-blog-thumb:not([style*="url"]) { background: linear-gradient(135deg, var(--twb-blue), var(--twb-indigo)); }
.tw-blog-post-card:nth-child(3n+3) .tw-blog-thumb:not([style*="url"]) { background: linear-gradient(135deg, var(--twb-pink), var(--twb-blue)); }

.tw-blog-card-body {
  padding: 24px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.tw-blog-card-cat {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--twb-blue);
  margin-bottom: 12px;
}
.tw-blog-post-card h3 {
  font-size: 22px;
  line-height: 125%;
  margin: 0 0 12px 0;
  color: var(--twb-text);
}
.tw-blog-card-excerpt {
  font-size: 14px;
  color: var(--twb-muted);
  line-height: 155%;
  margin: 0 0 16px 0;
}
.tw-blog-card-meta {
  display: flex;
  gap: 12px;
  font-size: 12px;
  color: var(--twb-muted);
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid var(--twb-warm-2);
  flex-wrap: wrap;
}

/* ====== FINAL CTA BAND ====== */
.tw-blog-cta-band {
  background: var(--twb-text);
  color: #fff;
  padding: 72px 0;
  text-align: center;
}
.tw-blog-cta-band * { color: #fff; }
.tw-blog-cta-band h2 { margin: 0 0 16px 0; }
.tw-blog-cta-band p {
  font-size: 18px;
  max-width: 640px;
  margin: 0 auto 32px;
  opacity: .85;
  line-height: 150%;
}
.tw-blog-cta-band .buttons {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.button.tw-blog-button-ghost {
  background: transparent;
  color: #fff;
  border-color: rgba(255,255,255,.4);
}
.button.tw-blog-button-ghost:hover {
  background: #fff;
  color: var(--twb-text);
  border-color: #fff;
}

/* ====== ARCHIVE HERO ====== */
.tw-blog-archive-hero {
  padding: 60px 0 40px;
  background: var(--twb-warm);
}
.tw-blog-eyebrow {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--twb-blue);
  margin-bottom: 16px;
}
.tw-blog-archive-hero h1 {
  max-width: 900px;
  margin-bottom: 20px;
  font-size: 36px;
  line-height: 115%;
}
@media (min-width: 700px) { .tw-blog-archive-hero h1 { font-size: 44px; } }
@media (min-width: 1000px) { .tw-blog-archive-hero h1 { font-size: 56px; } }
.tw-blog-lead {
  font-size: 18px;
  max-width: 720px;
  color: var(--twb-muted);
  line-height: 160%;
  margin-bottom: 32px;
}
.tw-blog-lead p { margin: 0; line-height: inherit; }

/* ====== CATEGORY FILTER CHIPS ====== */
.tw-blog-category-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.tw-blog-chip {
  padding: 8px 18px;
  border-radius: 25px;
  background: #fff;
  border: 1px solid var(--twb-border);
  font-size: 13px;
  font-weight: 600;
  color: var(--twb-text);
  cursor: pointer;
  transition: all .3s ease;
  text-decoration: none;
}
.tw-blog-chip:hover,
.tw-blog-chip.active {
  background: var(--twb-text);
  color: #fff;
  border-color: var(--twb-text);
}

/* ====== FEATURED POST ====== */
.tw-blog-featured-wrap { padding: 56px 0 40px; }
.tw-blog-featured {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  align-items: stretch;
  background: var(--twb-warm);
  border-radius: var(--twb-radius-card);
  overflow: hidden;
}
@media (min-width: 1000px) {
  .tw-blog-featured { grid-template-columns: 1.1fr 1fr; }
}
.tw-blog-featured-image {
  display: block;
  min-height: 320px;
  background-color: var(--twb-warm-2);
  background-size: cover;
  background-position: center;
}
.tw-blog-featured-image:not([style*="url"]) {
  background: linear-gradient(135deg, var(--twb-blue), var(--twb-tan));
}
.tw-blog-featured-body { padding: 32px; }
@media (min-width: 1000px) { .tw-blog-featured-body { padding: 48px; } }
.tw-blog-featured-body .tw-blog-eyebrow { color: var(--twb-pink); }
.tw-blog-featured-body h2 {
  font-size: 28px;
  line-height: 120%;
  margin: 0 0 20px 0;
}
@media (min-width: 1000px) { .tw-blog-featured-body h2 { font-size: 36px; } }
.tw-blog-featured-body h2 a { color: inherit; }
.tw-blog-featured-body h2 a:hover { color: var(--twb-indigo); }
.tw-blog-featured-excerpt {
  font-size: 16px;
  line-height: 160%;
  color: var(--twb-text);
  margin-bottom: 20px;
}
.tw-blog-featured-body .tw-blog-card-meta {
  border: 0;
  padding: 0;
  margin: 0 0 24px 0;
  color: var(--twb-muted);
  font-size: 13px;
}

/* ====== ALL POSTS SECTION ====== */
.tw-blog-all-posts { padding: 40px 0 72px; }
.tw-blog-all-posts h2 { margin-bottom: 32px; }

/* ====== PAGINATION ====== */
.tw-blog-pagination {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 48px;
  flex-wrap: wrap;
}
.tw-blog-pagination a,
.tw-blog-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 44px;
  padding: 0 8px;
  border-radius: 50%;
  border: 1px solid var(--twb-border);
  font-weight: 600;
  font-size: 14px;
  color: var(--twb-text);
  text-decoration: none;
  transition: all .3s ease;
}
.tw-blog-pagination a:hover {
  background: var(--twb-text);
  color: #fff;
  border-color: var(--twb-text);
}
.tw-blog-pagination .current {
  background: var(--twb-text);
  color: #fff;
  border-color: var(--twb-text);
}

/* ====== NEWSLETTER BAND ====== */
.tw-blog-newsletter-band {
  background: var(--twb-blue);
  padding: 56px 0;
  color: #fff;
}
.tw-blog-newsletter-band * { color: #fff; }
.tw-blog-newsletter-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: center;
}
@media (min-width: 1000px) {
  .tw-blog-newsletter-grid { grid-template-columns: 1fr 1fr; }
}
.tw-blog-newsletter-band h3 { font-size: 28px; margin-bottom: 8px; line-height: 120%; }
.tw-blog-newsletter-band p { opacity: .9; font-size: 15px; margin: 0; line-height: 150%; }
.tw-blog-newsletter-form {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.tw-blog-newsletter-form input[type=email] {
  flex: 1;
  min-width: 220px;
  padding: 14px 20px;
  border-radius: 25px;
  border: 0;
  background: rgba(255,255,255,.18);
  color: #fff;
  font-size: 15px;
  font-family: inherit;
}
.tw-blog-newsletter-form input[type=email]::placeholder {
  color: rgba(255,255,255,.7);
}
.tw-blog-newsletter-form input[type=email]:focus {
  outline: 2px solid #fff;
  background: rgba(255,255,255,.25);
}

/* ====== INLINE CTA (from [cta] shortcode) ====== */
.tw-blog-inline-cta {
  background: var(--twb-warm);
  border-radius: var(--twb-radius-card);
  padding: 32px;
  margin: 40px 0;
  text-align: center;
}
.tw-blog-inline-cta p {
  margin: 0 0 20px 0;
  font-size: 18px;
  font-weight: 600;
  line-height: 140%;
  color: var(--twb-text);
}
.tw-blog-inline-cta .button {
  display: inline-block;
}
/* Naked variant (no heading): just a centered button with no box. */
.tw-blog-inline-cta--naked {
  background: transparent;
  padding: 16px 0;
  margin: 32px 0;
}
