/*
 * Mechlar Blog System — style.css
 * Design: Editorial — Playfair Display headings, DM Sans body.
 * Palette: Deep ink (#0F172A) + warm cream (#FAFAF7) + cobalt accent (#2563EB).
 * ─────────────────────────────────────────────────────────────────────────────
 */

/* ── Variables ─────────────────────────────────────────────────────────────── */
:root {
  /* Colours */
  --cbs-ink:          #0F172A;
  --cbs-ink-2:        #334155;
  --cbs-ink-3:        #64748B;
  --cbs-ink-4:        #94A3B8;
  --cbs-cream:        #FAFAF7;
  --cbs-white:        #FFFFFF;
  --cbs-border:       #E2E8F0;
  --cbs-border-soft:  #F1F5F9;
  --cbs-accent:       #2563EB;
  --cbs-accent-dark:  #1D4ED8;
  --cbs-accent-tint:  #EFF6FF;
  --cbs-accent-mid:   #BFDBFE;
  --cbs-success:      #059669;
  --cbs-card-bg:      #FFFFFF;

  /* Typography */
  --cbs-font-display: 'Playfair Display', Georgia, serif;
  --cbs-font-body:    'DM Sans', system-ui, sans-serif;

  /* Radius */
  --cbs-radius-sm:    6px;
  --cbs-radius:       12px;
  --cbs-radius-lg:    18px;
  --cbs-radius-pill:  999px;

  /* Shadow */
  --cbs-shadow-xs:    0 1px 2px rgba(15,23,42,.05);
  --cbs-shadow-sm:    0 2px 8px rgba(15,23,42,.07), 0 1px 2px rgba(15,23,42,.04);
  --cbs-shadow:       0 6px 24px rgba(15,23,42,.09), 0 1px 4px rgba(15,23,42,.05);
  --cbs-shadow-lg:    0 16px 48px rgba(15,23,42,.13), 0 2px 8px rgba(15,23,42,.06);

  /* Transitions */
  --cbs-ease:         cubic-bezier(.4,0,.2,1);
  --cbs-dur:          220ms;

  /* Layout */
  --cbs-max-width:    1180px;
  --cbs-gap:          28px;
}

/* ── Reset / Base ──────────────────────────────────────────────────────────── */
.cbs-listing-page *,
.cbs-single-page * {
  box-sizing: border-box;
}

.cbs-listing-page,
.cbs-single-page {
  background:  var(--cbs-cream);
  font-family: var(--cbs-font-body);
  color:       var(--cbs-ink);
  padding:     56px 0 80px;
  min-height:  70vh;
}

/* ── Container ─────────────────────────────────────────────────────────────── */
.cbs-container {
  max-width:   var(--cbs-max-width);
  margin:      0 auto;
  padding:     0 24px;
  width:       100%;
}

/* ══════════════════════════════════════════════════════════════════════════════
   LISTING PAGE
══════════════════════════════════════════════════════════════════════════════ */

/* ── Listing Header ────────────────────────────────────────────────────────── */
.cbs-listing-header {
  text-align:    center;
  margin-bottom: 56px;
}

.cbs-listing-header__eyebrow {
  font-size:      0.75rem;
  font-weight:    600;
  text-transform: uppercase;
  letter-spacing: .14em;
  color:          var(--cbs-accent);
  margin:         0 0 12px;
}

.cbs-listing-header__title {
  font-family:    var(--cbs-font-display);
  font-size:      clamp(2rem, 5vw, 3.25rem);
  font-weight:    700;
  color:          var(--cbs-ink);
  margin:         0 0 20px;
  line-height:    1.15;
  letter-spacing: -.025em;
}

.cbs-listing-header__rule {
  width:         48px;
  height:        3px;
  background:    var(--cbs-accent);
  border-radius: var(--cbs-radius-pill);
  margin:        0 auto;
}

/* ── Grid ──────────────────────────────────────────────────────────────────── */
.cbs-grid {
  display:               grid;
  grid-template-columns: repeat(3, 1fr);
  gap:                   var(--cbs-gap);
}

/* First card spans full width ── "featured" hero card */
.cbs-card--featured {
  grid-column: 1 / -1;
  display:     grid;
  grid-template-columns: 58% 1fr;
}

.cbs-card--featured .cbs-card__media {
  aspect-ratio: 16/9;
  height:       100%;
}

.cbs-card--featured .cbs-card__body {
  padding: 40px 36px;
}

.cbs-card--featured .cbs-card__title {
  font-size:   1.9rem;
  line-height: 1.2;
}

/* ── Card ──────────────────────────────────────────────────────────────────── */
.cbs-card {
  background:    var(--cbs-card-bg);
  border-radius: var(--cbs-radius-lg);
  box-shadow:    var(--cbs-shadow-sm);
  border:        1px solid var(--cbs-border);
  overflow:      hidden;
  display:       flex;
  flex-direction: column;
  transition:    transform var(--cbs-dur) var(--cbs-ease),
                 box-shadow var(--cbs-dur) var(--cbs-ease);
}

.cbs-card:hover {
  transform:  translateY(-5px);
  box-shadow: var(--cbs-shadow-lg);
}

/* Media */
.cbs-card__media-link {
  display: block;
  overflow: hidden;
}

.cbs-card__media {
  width:        100%;
  aspect-ratio: 16/10;
  overflow:     hidden;
  background:   var(--cbs-border-soft);
  position:     relative;
}

.cbs-card__media img {
  width:      100%;
  height:     100%;
  object-fit: cover;
  display:    block;
  transition: transform 480ms var(--cbs-ease);
}

.cbs-card:hover .cbs-card__media img {
  transform: scale(1.05);
}

.cbs-placeholder {
  width:           100%;
  height:          100%;
  display:         flex;
  align-items:     center;
  justify-content: center;
  background:      var(--cbs-border-soft);
}

.cbs-placeholder svg {
  width:   80%;
  height:  auto;
  opacity: .7;
}

/* Body */
.cbs-card__body {
  padding:        22px 24px 24px;
  display:        flex;
  flex-direction: column;
  flex:           1;
}

.cbs-card__cat {
  display:        inline-block;
  font-size:      0.7rem;
  font-weight:    700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color:          var(--cbs-accent);
  text-decoration: none;
  margin-bottom:  10px;
  transition:     color var(--cbs-dur) var(--cbs-ease);
}

.cbs-card__cat:hover { color: var(--cbs-accent-dark); }

.cbs-card__title {
  font-family:    var(--cbs-font-display);
  font-size:      1.2rem;
  font-weight:    700;
  line-height:    1.32;
  color:          var(--cbs-ink);
  margin:         0 0 12px;
  letter-spacing: -.015em;
}

.cbs-card__title a {
  color:           inherit;
  text-decoration: none;
  transition:      color var(--cbs-dur) var(--cbs-ease);
}

.cbs-card__title a:hover { color: var(--cbs-accent); }

.cbs-card__excerpt {
  font-size:   0.9rem;
  line-height: 1.75;
  color:       var(--cbs-ink-2);
  text-align:  justify;
  flex:        1;
  margin:      0 0 20px;
}

/* Footer / byline */
.cbs-card__footer {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  flex-wrap:       wrap;
  gap:             12px;
  padding-top:     16px;
  border-top:      1px solid var(--cbs-border-soft);
  margin-top:      auto;
}

.cbs-card__byline {
  display:     flex;
  align-items: center;
  gap:         8px;
  font-size:   0.8rem;
  color:       var(--cbs-ink-3);
  flex-wrap:   wrap;
}

.cbs-card__avatar {
  width:         28px !important;
  height:        28px !important;
  border-radius: 50% !important;
  object-fit:    cover;
}

.cbs-card__author { font-weight: 500; }
.cbs-card__dot    { opacity: .4; }

/* ── Buttons ───────────────────────────────────────────────────────────────── */
.cbs-btn {
  display:         inline-flex;
  align-items:     center;
  gap:             6px;
  padding:         8px 18px;
  border-radius:   var(--cbs-radius-pill);
  font-family:     var(--cbs-font-body);
  font-size:       0.82rem;
  font-weight:     600;
  cursor:          pointer;
  text-decoration: none;
  border:          2px solid transparent;
  line-height:     1;
  transition:      background var(--cbs-dur) var(--cbs-ease),
                   color      var(--cbs-dur) var(--cbs-ease),
                   border-color var(--cbs-dur) var(--cbs-ease),
                   transform  var(--cbs-dur) var(--cbs-ease),
                   box-shadow var(--cbs-dur) var(--cbs-ease);
}

.cbs-btn:focus-visible {
  outline:        3px solid var(--cbs-accent);
  outline-offset: 3px;
}

.cbs-btn--ghost {
  border-color: var(--cbs-border);
  color:        var(--cbs-ink-2);
  background:   transparent;
}

.cbs-btn--ghost:hover,
.cbs-btn--ghost:focus-visible {
  border-color: var(--cbs-accent);
  color:        var(--cbs-accent);
  background:   var(--cbs-accent-tint);
  transform:    translateX(2px);
}

.cbs-btn--outline {
  border-color: var(--cbs-accent);
  color:        var(--cbs-accent);
  background:   transparent;
}

.cbs-btn--outline:hover {
  background: var(--cbs-accent);
  color:      var(--cbs-white);
}

.cbs-btn--primary {
  background: var(--cbs-accent);
  color:      var(--cbs-white);
  border-color: var(--cbs-accent);
}

.cbs-btn--primary:hover,
.cbs-btn--primary:focus-visible {
  background:   var(--cbs-accent-dark);
  border-color: var(--cbs-accent-dark);
  box-shadow:   0 4px 14px rgba(37,99,235,.4);
}

/* ── Pagination ────────────────────────────────────────────────────────────── */
.cbs-pagination {
  margin-top: 52px;
}

.cbs-pagination__list {
  list-style:      none;
  margin:          0;
  padding:         0;
  display:         flex;
  flex-wrap:       wrap;
  gap:             8px;
  justify-content: center;
}

.cbs-pagination__list li a,
.cbs-pagination__list li span {
  display:         inline-flex;
  align-items:     center;
  justify-content: center;
  min-width:       42px;
  height:          42px;
  padding:         0 14px;
  border-radius:   var(--cbs-radius-pill);
  border:          1px solid var(--cbs-border);
  font-size:       0.875rem;
  font-weight:     500;
  color:           var(--cbs-ink-2);
  text-decoration: none;
  background:      var(--cbs-white);
  transition:      all var(--cbs-dur) var(--cbs-ease);
}

.cbs-pagination__list li a:hover {
  border-color: var(--cbs-accent);
  color:        var(--cbs-accent);
  background:   var(--cbs-accent-tint);
}

.cbs-pagination__list li.is-active span,
.cbs-pagination__list li span.current {
  background:   var(--cbs-accent);
  border-color: var(--cbs-accent);
  color:        var(--cbs-white);
  font-weight:  700;
}

/* ── Empty State ───────────────────────────────────────────────────────────── */
.cbs-empty-state {
  text-align:    center;
  padding:       80px 24px;
  background:    var(--cbs-white);
  border:        1px dashed var(--cbs-border);
  border-radius: var(--cbs-radius-lg);
}

.cbs-empty-state__icon {
  color:         var(--cbs-ink-4);
  margin-bottom: 16px;
}

.cbs-empty-state__icon svg {
  width:  48px;
  height: 48px;
}

.cbs-empty-state__message {
  font-size: 1.05rem;
  color:     var(--cbs-ink-3);
  margin:    0;
}

/* ══════════════════════════════════════════════════════════════════════════════
   SINGLE POST PAGE
══════════════════════════════════════════════════════════════════════════════ */

/* ── Layout ────────────────────────────────────────────────────────────────── */
.cbs-single-layout {
  display:               grid;
  grid-template-columns: 1fr 320px;
  gap:                   48px;
  align-items:           start;
}

/* ── Breadcrumb ────────────────────────────────────────────────────────────── */
.cbs-breadcrumb {
  margin-bottom: 24px;
}

.cbs-breadcrumb ol {
  list-style:  none;
  margin:      0;
  padding:     0;
  display:     flex;
  flex-wrap:   wrap;
  align-items: center;
  gap:         6px;
  font-size:   0.8rem;
  color:       var(--cbs-ink-3);
}

.cbs-breadcrumb ol li a {
  color:           var(--cbs-accent);
  text-decoration: none;
  transition:      color var(--cbs-dur) var(--cbs-ease);
}

.cbs-breadcrumb ol li a:hover { color: var(--cbs-accent-dark); }

.cbs-breadcrumb__sep { opacity: .4; }

/* ── Article ───────────────────────────────────────────────────────────────── */
.cbs-article__cats {
  display:   flex;
  flex-wrap: wrap;
  gap:       8px;
  margin-bottom: 16px;
}

.cbs-badge {
  display:         inline-block;
  padding:         4px 14px;
  border-radius:   var(--cbs-radius-pill);
  background:      var(--cbs-accent-tint);
  color:           var(--cbs-accent);
  font-size:       0.72rem;
  font-weight:     700;
  text-transform:  uppercase;
  letter-spacing:  .08em;
  text-decoration: none;
  border:          1px solid var(--cbs-accent-mid);
  transition:      background var(--cbs-dur) var(--cbs-ease),
                   color      var(--cbs-dur) var(--cbs-ease);
}

.cbs-badge:hover {
  background: var(--cbs-accent);
  color:      var(--cbs-white);
}

.cbs-article__title {
  font-family:    var(--cbs-font-display);
  font-size:      clamp(1.8rem, 3.5vw, 2.75rem);
  font-weight:    800;
  color:          var(--cbs-ink);
  margin:         0 0 24px;
  line-height:    1.15;
  letter-spacing: -.025em;
}

/* Meta bar */
.cbs-article__meta {
  display:       flex;
  align-items:   center;
  gap:           14px;
  margin-bottom: 32px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--cbs-border);
  flex-wrap:     wrap;
}

.cbs-article__avatar {
  width:         36px !important;
  height:        36px !important;
  border-radius: 50% !important;
  object-fit:    cover;
  flex-shrink:   0;
}

.cbs-article__meta-info {
  display:        flex;
  flex-direction: column;
  gap:            2px;
}

.cbs-article__author {
  font-size:   0.88rem;
  font-weight: 600;
  color:       var(--cbs-ink);
}

.cbs-article__author a {
  color:           inherit;
  text-decoration: none;
}

.cbs-article__author a:hover { color: var(--cbs-accent); }

.cbs-article__meta-secondary {
  display:     flex;
  align-items: center;
  gap:         8px;
  font-size:   0.78rem;
  color:       var(--cbs-ink-3);
}

.cbs-article__dot { opacity: .4; }

/* Hero Image */
.cbs-article__hero {
  margin-bottom:  36px;
  border-radius:  var(--cbs-radius-lg);
  overflow:       hidden;
  box-shadow:     var(--cbs-shadow);
  line-height:    0;
}

.cbs-article__hero-img {
  width:        100%;
  height:       auto;
  max-height:   520px;
  object-fit:   cover;
  display:      block;
}

.cbs-article__hero-placeholder {
  width:        100%;
  aspect-ratio: 16/7;
  display:      flex;
  align-items:  center;
  justify-content: center;
  background:   var(--cbs-border-soft);
}

.cbs-article__hero-placeholder svg {
  width:   60%;
  height:  auto;
}

/* Article Content */
.cbs-article__content {
  font-size:   1.02rem;
  line-height: 1.9;
  color:       var(--cbs-ink-2);
  text-align:  justify;
}

.cbs-article__content p { margin: 0 0 1.5em; }

.cbs-article__content h2,
.cbs-article__content h3,
.cbs-article__content h4 {
  font-family:    var(--cbs-font-display);
  font-weight:    700;
  color:          var(--cbs-ink);
  margin:         1.8em 0 .6em;
  letter-spacing: -.015em;
  line-height:    1.25;
  text-align:     left;
}

.cbs-article__content h2 { font-size: 1.6rem; }
.cbs-article__content h3 { font-size: 1.3rem; }
.cbs-article__content h4 { font-size: 1.1rem; }

.cbs-article__content a {
  color:                 var(--cbs-accent);
  text-underline-offset: 3px;
}

.cbs-article__content a:hover { color: var(--cbs-accent-dark); }

.cbs-article__content ul,
.cbs-article__content ol {
  padding-left: 1.6em;
  margin:       0 0 1.5em;
  text-align:   left;
}

.cbs-article__content li { margin-bottom: .4em; }

.cbs-article__content blockquote {
  border-left:   4px solid var(--cbs-accent);
  margin:        2em 0;
  padding:       18px 24px;
  background:    var(--cbs-accent-tint);
  border-radius: 0 var(--cbs-radius) var(--cbs-radius) 0;
  font-style:    italic;
  font-size:     1.08rem;
  color:         var(--cbs-ink);
  text-align:    left;
}

.cbs-article__content img {
  max-width:     100%;
  height:        auto;
  border-radius: var(--cbs-radius);
  margin:        .5em 0;
}

.cbs-article__content pre {
  background:    #0F172A;
  color:         #E2E8F0;
  padding:       20px 24px;
  border-radius: var(--cbs-radius);
  overflow-x:    auto;
  font-size:     0.875rem;
  line-height:   1.7;
  margin:        0 0 1.5em;
  text-align:    left;
}

.cbs-article__content code {
  font-family: 'Cascadia Code', 'Fira Code', monospace;
}

.cbs-article__content p > code {
  background:    var(--cbs-border-soft);
  color:         #9333EA;
  padding:       2px 6px;
  border-radius: 4px;
  font-size:     .88em;
}

/* Page links */
.cbs-page-links {
  display:     flex;
  flex-wrap:   wrap;
  align-items: center;
  gap:         8px;
  margin:      24px 0;
  font-size:   .875rem;
  font-weight: 600;
}

.cbs-page-links a {
  display:         inline-flex;
  align-items:     center;
  justify-content: center;
  width:           34px;
  height:          34px;
  border-radius:   var(--cbs-radius);
  border:          1px solid var(--cbs-border);
  text-decoration: none;
  color:           var(--cbs-ink-2);
  transition:      all var(--cbs-dur) var(--cbs-ease);
}

.cbs-page-links a:hover {
  border-color: var(--cbs-accent);
  color:        var(--cbs-accent);
  background:   var(--cbs-accent-tint);
}

/* Tags */
.cbs-article__tags {
  display:     flex;
  align-items: center;
  flex-wrap:   wrap;
  gap:         8px;
  margin-top:  32px;
  padding-top: 24px;
  border-top:  1px solid var(--cbs-border);
}

.cbs-article__tags-label {
  color:       var(--cbs-ink-3);
  font-size:   .82rem;
  line-height: 1;
}

.cbs-tag {
  display:         inline-block;
  padding:         5px 14px;
  border-radius:   var(--cbs-radius-pill);
  border:          1px solid var(--cbs-border);
  font-size:       0.78rem;
  color:           var(--cbs-ink-3);
  text-decoration: none;
  transition:      all var(--cbs-dur) var(--cbs-ease);
}

.cbs-tag:hover {
  border-color: var(--cbs-accent);
  color:        var(--cbs-accent);
  background:   var(--cbs-accent-tint);
}

/* Author Card */
.cbs-author-card {
  display:       flex;
  gap:           20px;
  align-items:   flex-start;
  margin-top:    36px;
  padding:       28px;
  background:    var(--cbs-white);
  border:        1px solid var(--cbs-border);
  border-radius: var(--cbs-radius-lg);
  box-shadow:    var(--cbs-shadow-xs);
}

.cbs-author-card__avatar {
  width:         80px !important;
  height:        80px !important;
  border-radius: 50% !important;
  object-fit:    cover;
  flex-shrink:   0;
  border:        3px solid var(--cbs-accent-mid);
}

.cbs-author-card__eyebrow {
  font-size:      0.72rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color:          var(--cbs-ink-4);
  margin:         0 0 4px;
  font-weight:    600;
}

.cbs-author-card__name {
  font-family:   var(--cbs-font-display);
  font-size:     1.1rem;
  font-weight:   700;
  margin:        0 0 10px;
  color:         var(--cbs-ink);
}

.cbs-author-card__name a {
  color:           inherit;
  text-decoration: none;
  transition:      color var(--cbs-dur) var(--cbs-ease);
}

.cbs-author-card__name a:hover { color: var(--cbs-accent); }

.cbs-author-card__bio {
  font-size:  0.9rem;
  color:      var(--cbs-ink-2);
  line-height: 1.7;
  margin:     0;
}

/* Post Navigation */
.cbs-post-nav {
  display:    flex;
  gap:        16px;
  margin-top: 36px;
  padding-top: 28px;
  border-top:  1px solid var(--cbs-border);
  flex-wrap:  wrap;
}

.cbs-post-nav__item {
  flex:            1;
  min-width:       200px;
  display:         flex;
  flex-direction:  column;
  gap:             6px;
  padding:         18px 22px;
  background:      var(--cbs-white);
  border:          1px solid var(--cbs-border);
  border-radius:   var(--cbs-radius);
  text-decoration: none;
  color:           var(--cbs-ink);
  transition:      border-color var(--cbs-dur) var(--cbs-ease),
                   background   var(--cbs-dur) var(--cbs-ease),
                   transform    var(--cbs-dur) var(--cbs-ease),
                   box-shadow   var(--cbs-dur) var(--cbs-ease);
}

.cbs-post-nav__item:hover {
  border-color: var(--cbs-accent);
  background:   var(--cbs-accent-tint);
  transform:    translateY(-2px);
  box-shadow:   var(--cbs-shadow-sm);
}

.cbs-post-nav__item--next { text-align: right; }

.cbs-post-nav__dir {
  font-size:      0.72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight:    700;
  color:          var(--cbs-accent);
}

.cbs-post-nav__title {
  font-size:   0.9rem;
  font-weight: 600;
  line-height: 1.4;
  color:       var(--cbs-ink);
}

/* ══════════════════════════════════════════════════════════════════════════════
   COMMENTS — Full custom styling
══════════════════════════════════════════════════════════════════════════════ */
.cbs-comments-wrapper {
  margin-top:    48px;
  padding-top:   40px;
  border-top:    2px solid var(--cbs-border);
}

/* Section title */
.cbs-comments-wrapper #comments .comments-title,
.cbs-comments-wrapper #reply-title,
.cbs-comments-wrapper h2.comments-title,
.cbs-comments-wrapper h3#reply-title {
  font-family:    var(--cbs-font-display) !important;
  font-size:      1.55rem !important;
  font-weight:    700 !important;
  color:          var(--cbs-ink) !important;
  letter-spacing: -.015em !important;
  margin:         0 0 28px !important;
  padding:        0 !important;
  border:         none !important;
}

/* Comment list */
.cbs-comments-wrapper ol.comment-list,
.cbs-comments-wrapper ul.comment-list {
  list-style:     none;
  margin:         0 0 40px;
  padding:        0;
  display:        flex;
  flex-direction: column;
  gap:            20px;
}

.cbs-comments-wrapper .comment-list .comment,
.cbs-comments-wrapper .comment-list article.comment-body {
  background:    var(--cbs-white);
  border:        1px solid var(--cbs-border);
  border-radius: var(--cbs-radius-lg);
  padding:       24px;
  box-shadow:    var(--cbs-shadow-xs);
}

/* Comment header */
.cbs-comments-wrapper .comment-meta {
  display:       flex;
  align-items:   flex-start;
  gap:           14px;
  margin-bottom: 14px;
}

.cbs-comments-wrapper .comment-author img.avatar {
  width:         44px !important;
  height:        44px !important;
  border-radius: 50% !important;
  flex-shrink:   0;
  border:        2px solid var(--cbs-border);
}

.cbs-comments-wrapper .comment-author .fn {
  font-size:   .9rem;
  font-weight: 600;
  color:       var(--cbs-ink);
}

.cbs-comments-wrapper .comment-author .fn a {
  color:           inherit;
  text-decoration: none;
}

.cbs-comments-wrapper .comment-metadata {
  font-size: .75rem;
  color:     var(--cbs-ink-3);
  margin-top: 2px;
}

.cbs-comments-wrapper .comment-metadata a {
  color:           inherit;
  text-decoration: none;
}

/* Comment body */
.cbs-comments-wrapper .comment-content {
  font-size:   .93rem;
  line-height: 1.8;
  color:       var(--cbs-ink-2);
  text-align:  justify;
}

.cbs-comments-wrapper .comment-content p { margin: 0 0 .8em; }

/* Reply link */
.cbs-comments-wrapper .comment-reply-link,
.cbs-comments-wrapper .reply a {
  display:         inline-flex;
  align-items:     center;
  gap:             4px;
  font-size:       .78rem;
  font-weight:     600;
  color:           var(--cbs-accent);
  text-decoration: none;
  margin-top:      10px;
  border:          1px solid var(--cbs-accent-mid);
  background:      var(--cbs-accent-tint);
  padding:         4px 12px;
  border-radius:   var(--cbs-radius-pill);
  transition:      background var(--cbs-dur) var(--cbs-ease),
                   color      var(--cbs-dur) var(--cbs-ease);
}

.cbs-comments-wrapper .comment-reply-link:hover,
.cbs-comments-wrapper .reply a:hover {
  background: var(--cbs-accent);
  color:      var(--cbs-white);
}

/* Moderation notice */
.cbs-comments-wrapper .comment-awaiting-moderation {
  display:       inline-block;
  font-size:     .78rem;
  color:         var(--cbs-ink-3);
  background:    var(--cbs-border-soft);
  padding:       3px 10px;
  border-radius: var(--cbs-radius-pill);
  margin-top:    6px;
}

/* Nested comments */
.cbs-comments-wrapper .children {
  list-style: none;
  padding:    0;
  margin:     12px 0 0 36px;
  display:    flex;
  flex-direction: column;
  gap: 12px;
}

/* ── Comment Form ──────────────────────────────────────────────────────────── */
.cbs-comments-wrapper #respond {
  background:    var(--cbs-white);
  border:        1px solid var(--cbs-border);
  border-radius: var(--cbs-radius-lg);
  padding:       32px;
  margin-top:    12px;
  box-shadow:    var(--cbs-shadow-sm);
}

.cbs-comments-wrapper .comment-form {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   16px;
}

.cbs-comments-wrapper .comment-form .comment-form-author,
.cbs-comments-wrapper .comment-form .comment-form-email {
  grid-column: span 1;
}

.cbs-comments-wrapper .comment-form .comment-form-url,
.cbs-comments-wrapper .comment-form .comment-form-comment,
.cbs-comments-wrapper .comment-form .comment-form-cookies-consent,
.cbs-comments-wrapper .comment-form .form-submit {
  grid-column: 1 / -1;
}

.cbs-comments-wrapper .comment-form label {
  display:       block;
  font-size:     .8rem;
  font-weight:   600;
  color:         var(--cbs-ink-2);
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: .07em;
}

.cbs-comments-wrapper .comment-form input[type="text"],
.cbs-comments-wrapper .comment-form input[type="email"],
.cbs-comments-wrapper .comment-form input[type="url"],
.cbs-comments-wrapper .comment-form textarea {
  width:            100%;
  padding:          11px 15px;
  border:           1.5px solid var(--cbs-border);
  border-radius:    var(--cbs-radius);
  font-family:      var(--cbs-font-body);
  font-size:        .93rem;
  color:            var(--cbs-ink);
  background:       var(--cbs-cream);
  transition:       border-color var(--cbs-dur) var(--cbs-ease),
                    box-shadow   var(--cbs-dur) var(--cbs-ease),
                    background   var(--cbs-dur) var(--cbs-ease);
  outline:          none;
  display:          block;
  box-sizing:       border-box;
}

.cbs-comments-wrapper .comment-form input[type="text"]:hover,
.cbs-comments-wrapper .comment-form input[type="email"]:hover,
.cbs-comments-wrapper .comment-form input[type="url"]:hover,
.cbs-comments-wrapper .comment-form textarea:hover {
  border-color: var(--cbs-ink-3);
}

.cbs-comments-wrapper .comment-form input[type="text"]:focus,
.cbs-comments-wrapper .comment-form input[type="email"]:focus,
.cbs-comments-wrapper .comment-form input[type="url"]:focus,
.cbs-comments-wrapper .comment-form textarea:focus {
  border-color: var(--cbs-accent);
  background:   var(--cbs-white);
  box-shadow:   0 0 0 3px rgba(37,99,235,.15);
}

.cbs-comments-wrapper .comment-form textarea {
  min-height:  140px;
  resize:      vertical;
  line-height: 1.7;
}

/* Submit button */
.cbs-comments-wrapper .comment-form .form-submit {
  margin: 0;
}

.cbs-comments-wrapper .comment-form input[type="submit"] {
  display:       inline-flex;
  align-items:   center;
  gap:           8px;
  padding:       13px 32px;
  background:    var(--cbs-accent);
  color:         var(--cbs-white);
  border:        none;
  border-radius: var(--cbs-radius-pill);
  font-family:   var(--cbs-font-body);
  font-size:     .92rem;
  font-weight:   700;
  cursor:        pointer;
  letter-spacing: .02em;
  transition:    background  var(--cbs-dur) var(--cbs-ease),
                 box-shadow  var(--cbs-dur) var(--cbs-ease),
                 transform   var(--cbs-dur) var(--cbs-ease);
}

.cbs-comments-wrapper .comment-form input[type="submit"]:hover {
  background:  var(--cbs-accent-dark);
  box-shadow:  0 4px 18px rgba(37,99,235,.4);
  transform:   translateY(-1px);
}

.cbs-comments-wrapper .comment-form input[type="submit"]:focus-visible {
  outline:        3px solid var(--cbs-accent);
  outline-offset: 3px;
}

/* Cancel reply */
.cbs-comments-wrapper #cancel-comment-reply-link {
  font-size:       .8rem;
  color:           var(--cbs-ink-3);
  text-decoration: none;
  margin-left:     12px;
}

.cbs-comments-wrapper #cancel-comment-reply-link:hover { color: var(--cbs-accent); }

/* No comments message */
.cbs-comments-wrapper .no-comments {
  color:     var(--cbs-ink-3);
  font-size: .93rem;
  margin:    0 0 28px;
}

/* Cookies consent */
.cbs-comments-wrapper .comment-form-cookies-consent {
  display:     flex;
  align-items: flex-start;
  gap:         10px;
}

.cbs-comments-wrapper .comment-form-cookies-consent input[type="checkbox"] {
  margin-top:  2px;
  accent-color: var(--cbs-accent);
  width:        15px;
  height:       15px;
  flex-shrink:  0;
}

.cbs-comments-wrapper .comment-form-cookies-consent label {
  font-size:      .82rem;
  text-transform: none;
  letter-spacing: 0;
  font-weight:    400;
  color:          var(--cbs-ink-3);
  margin:         0;
}

/* ══════════════════════════════════════════════════════════════════════════════
   SIDEBAR
══════════════════════════════════════════════════════════════════════════════ */
.cbs-single-sidebar {
  position: sticky;
  top:      28px;
}

.cbs-sidebar {
  display:        flex;
  flex-direction: column;
  gap:            20px;
}

.cbs-sidebar__widget {
  background:    var(--cbs-white);
  border:        1px solid var(--cbs-border);
  border-radius: var(--cbs-radius-lg);
  padding:       24px;
  box-shadow:    var(--cbs-shadow-xs);
}

.cbs-sidebar__title {
  font-family:    var(--cbs-font-display);
  font-size:      1rem;
  font-weight:    700;
  color:          var(--cbs-ink);
  margin:         0 0 18px;
  padding-bottom: 12px;
  border-bottom:  2px solid var(--cbs-accent);
  letter-spacing: -.01em;
}

/* Sidebar post list */
.cbs-sidebar__post-list {
  list-style: none;
  margin:     0;
  padding:    0;
  display:    flex;
  flex-direction: column;
  gap: 0;
}

.cbs-sidebar__post-item {
  border-bottom: 1px solid var(--cbs-border-soft);
  padding-bottom: 16px;
  margin-bottom:  16px;
}

.cbs-sidebar__post-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom:  0;
}

.cbs-sidebar__post-link {
  display:         flex;
  gap:             12px;
  align-items:     center;
  text-decoration: none;
  color:           inherit;
  transition:      transform var(--cbs-dur) var(--cbs-ease);
}

.cbs-sidebar__post-link:hover { transform: translateX(4px); }

.cbs-sidebar__post-thumb {
  width:         100px;
  height:        74px;
  flex-shrink:   0;
  border-radius: var(--cbs-radius-sm);
  overflow:      hidden;
  background:    var(--cbs-border-soft);
}

.cbs-sidebar__post-thumb img {
  width:      100%;
  height:     100%;
  object-fit: cover;
  display:    block;
  transition: transform 400ms var(--cbs-ease);
}

.cbs-sidebar__post-link:hover .cbs-sidebar__post-thumb img {
  transform: scale(1.08);
}

.cbs-sidebar__post-placeholder {
  width:           100%;
  height:          100%;
  display:         flex;
  align-items:     center;
  justify-content: center;
}

.cbs-sidebar__post-info {
  flex: 1;
  min-width: 0;
}

.cbs-sidebar__post-title {
  font-size:     .855rem;
  font-weight:   600;
  color:         var(--cbs-ink);
  margin:        0 0 5px;
  line-height:   1.4;
  display:       -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow:      hidden;
  transition:    color var(--cbs-dur) var(--cbs-ease);
}

.cbs-sidebar__post-link:hover .cbs-sidebar__post-title {
  color: var(--cbs-accent);
}

.cbs-sidebar__post-date {
  font-size: .73rem;
  color:     var(--cbs-ink-4);
  display:   block;
}

/* Category list */
.cbs-sidebar__cat-list {
  list-style: none;
  margin:     0;
  padding:    0;
  display:    flex;
  flex-direction: column;
  gap: 2px;
}

.cbs-sidebar__cat-link {
  display:         flex;
  justify-content: space-between;
  align-items:     center;
  padding:         9px 12px;
  border-radius:   var(--cbs-radius);
  text-decoration: none;
  font-size:       .88rem;
  font-weight:     500;
  color:           var(--cbs-ink-2);
  transition:      background  var(--cbs-dur) var(--cbs-ease),
                   color       var(--cbs-dur) var(--cbs-ease),
                   padding-left var(--cbs-dur) var(--cbs-ease);
}

.cbs-sidebar__cat-link:hover {
  background:   var(--cbs-accent-tint);
  color:        var(--cbs-accent);
  padding-left: 16px;
}

.cbs-sidebar__cat-count {
  font-size:     .73rem;
  font-weight:   600;
  background:    var(--cbs-border-soft);
  color:         var(--cbs-ink-3);
  border-radius: var(--cbs-radius-pill);
  padding:       2px 8px;
  min-width:     22px;
  text-align:    center;
  transition:    background var(--cbs-dur) var(--cbs-ease),
                 color      var(--cbs-dur) var(--cbs-ease);
}

.cbs-sidebar__cat-link:hover .cbs-sidebar__cat-count {
  background: var(--cbs-accent);
  color:      var(--cbs-white);
}

.cbs-sidebar__empty {
  font-size:  .88rem;
  color:      var(--cbs-ink-3);
  font-style: italic;
  margin:     0;
}

/* ══════════════════════════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .cbs-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .cbs-card--featured {
    grid-column: 1 / -1;
  }
}

@media (max-width: 900px) {
  .cbs-single-layout {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .cbs-single-sidebar {
    position: static;
  }
  .cbs-sidebar {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .cbs-sidebar__widget {
    flex: 1;
    min-width: 240px;
  }
}

@media (max-width: 768px) {
  .cbs-listing-page,
  .cbs-single-page {
    padding: 36px 0 56px;
  }

  .cbs-grid {
    grid-template-columns: 1fr;
  }

  .cbs-card--featured {
    grid-template-columns: 1fr;
  }

  .cbs-card--featured .cbs-card__media {
    aspect-ratio: 16/9;
    height: auto;
  }

  .cbs-card--featured .cbs-card__body {
    padding: 22px 24px;
  }

  .cbs-card--featured .cbs-card__title {
    font-size: 1.35rem;
  }

  .cbs-article__title {
    font-size: 1.7rem;
  }

  .cbs-author-card {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .cbs-post-nav {
    flex-direction: column;
  }

  .cbs-post-nav__item--next {
    text-align: left;
  }

  .cbs-comments-wrapper .comment-form {
    grid-template-columns: 1fr;
  }

  .cbs-comments-wrapper .comment-form .comment-form-author,
  .cbs-comments-wrapper .comment-form .comment-form-email {
    grid-column: 1 / -1;
  }

  .cbs-sidebar {
    flex-direction: column;
  }
}

@media (max-width: 480px) {
  .cbs-container {
    padding: 0 16px;
  }

  .cbs-card__footer {
    flex-direction: column;
    align-items: flex-start;
  }

  .cbs-article__meta {
    gap: 10px;
  }

  .cbs-comments-wrapper #respond {
    padding: 22px 18px;
  }
}
