/*
 * CraftBook UK Magazine — Article & Archive Styles
 * Covers: article hero (image behind title), article body, about strip,
 * archives, author page, 404, search, pages, category hero with image,
 * full-width page template.
 * @package CraftBook_Magazine
 */

/* ==========================================================================
   ARTICLE HERO — FEATURED IMAGE BEHIND TITLE
   ========================================================================== */

.cbm-article-hero-wrap {
    position:            relative;
    width:               100%;
    min-height:          clamp(340px, 50vh, 580px);
    display:             flex;
    align-items:         flex-end;
    background-size:     cover;
    background-position: center;
    background-repeat:   no-repeat;
    overflow:            hidden;
}

/* Gradient overlay — dark at bottom, lighter at top */
.cbm-article-hero__overlay {
    position:   absolute;
    inset:      0;
    background: linear-gradient(
        to top,
        rgba(10, 18, 35, 0.92) 0%,
        rgba(10, 18, 35, 0.65) 40%,
        rgba(10, 18, 35, 0.25) 70%,
        rgba(10, 18, 35, 0.08) 100%
    );
}

.cbm-article-hero__content {
    position:       relative;
    z-index:        1;
    width:          100%;
    padding-top:    var(--cbm-space-10);
    padding-bottom: var(--cbm-space-10);
}

/* Breadcrumbs on hero — white text */
.cbm-article-hero__content .cbm-breadcrumbs,
.cbm-article-hero__content .cbm-breadcrumbs a {
    color: rgba(255,255,255,0.6);
}
.cbm-article-hero__content .cbm-breadcrumbs .cbm-breadcrumbs__current { color: rgba(255,255,255,0.85); }
.cbm-article-hero__content .cbm-breadcrumbs a:hover { color: var(--cbm-accent); }

.cbm-article-hero__badge { margin-bottom: var(--cbm-space-4); }

/* Override badge on hero — white/translucent */
.cbm-article-hero__content .cbm-badge {
    background:   rgba(255,255,255,0.15);
    color:        #fff;
    border:       1px solid rgba(255,255,255,0.3);
    backdrop-filter: blur(4px);
}

/* Title */
.cbm-article-hero__title {
    font-family:    var(--cbm-font-heading);
    font-size:      clamp(1.75rem, 5vw, 3rem);
    font-weight:    var(--cbm-weight-black);
    line-height:    var(--cbm-leading-tight);
    letter-spacing: var(--cbm-tracking-tight);
    color:          #ffffff;
    margin-bottom:  var(--cbm-space-5);
    text-shadow:    0 2px 8px rgba(0,0,0,0.3);
}

/* Meta bar on hero */
.cbm-article-hero__meta {
    display:     flex;
    align-items: center;
    flex-wrap:   wrap;
    gap:         var(--cbm-space-3);
    font-size:   var(--cbm-text-sm);
    color:       rgba(255,255,255,0.75);
    padding-top: var(--cbm-space-4);
    border-top:  1px solid rgba(255,255,255,0.2);
}
.cbm-article-hero__meta-item    { display: flex; align-items: center; gap: var(--cbm-space-2); }
.cbm-article-hero__meta-sep     { opacity: 0.45; }
.cbm-article-hero__avatar       { width: 32px; height: 32px; border-radius: var(--cbm-radius-pill); border: 2px solid rgba(255,255,255,0.3); object-fit: cover; }
.cbm-article-hero__author-link  { color: rgba(255,255,255,0.9); text-decoration: none; font-weight: var(--cbm-weight-semibold); }
.cbm-article-hero__author-link:hover { color: var(--cbm-accent); }
.cbm-article-hero__reading-time { display: flex; align-items: center; gap: var(--cbm-space-1); }
.cbm-article-hero__clock-icon   { width: 14px; height: 14px; opacity: 0.7; }
.cbm-article-hero__updated      { font-style: italic; }

/* ── No featured image: text-only header ── */
.cbm-article-header--no-hero {
    background:     var(--cbm-bg);
    padding-top:    var(--cbm-space-10);
}
.cbm-article-header__text-only {
    padding-bottom: var(--cbm-space-4);
}
.cbm-article-header__badge { margin-bottom: var(--cbm-space-4); }
.cbm-article-header__title {
    font-family:    var(--cbm-font-heading);
    font-size:      clamp(1.75rem, 5vw, 3rem);
    font-weight:    var(--cbm-weight-black);
    line-height:    var(--cbm-leading-tight);
    letter-spacing: var(--cbm-tracking-tight);
    color:          var(--cbm-text-heading);
    margin-bottom:  var(--cbm-space-6);
}
.cbm-article-header__meta {
    display: flex; align-items: center; flex-wrap: wrap; gap: var(--cbm-space-4);
    padding: var(--cbm-space-5) 0; border-top: 1px solid var(--cbm-border); border-bottom: 1px solid var(--cbm-border);
    font-size: var(--cbm-text-sm); color: var(--cbm-text-muted);
}
.cbm-article-header__meta-item { display: flex; align-items: center; gap: var(--cbm-space-2); }
.cbm-article-header__meta-item--sep::before { content: '·'; margin-right: var(--cbm-space-1); opacity: 0.4; }
.cbm-article-header__meta-icon { width: 16px; height: 16px; opacity: 0.55; flex-shrink: 0; }
.cbm-article-header__avatar { width: 32px; height: 32px; border-radius: var(--cbm-radius-pill); border: 2px solid var(--cbm-border); object-fit: cover; }
.cbm-article-header__author-link { color: var(--cbm-text); font-weight: var(--cbm-weight-semibold); text-decoration: none; }
.cbm-article-header__author-link:hover { color: var(--cbm-accent); }

/* ==========================================================================
   ARTICLE BODY
   ========================================================================== */

.cbm-single-wrap { background: var(--cbm-bg); min-height: 60vh; }
.cbm-article     { padding-bottom: var(--cbm-space-16); }
.cbm-article__body { padding-top: var(--cbm-space-8); padding-bottom: var(--cbm-space-10); }

/* Tags */
.cbm-article__tags { display: flex; align-items: flex-start; gap: var(--cbm-space-4); padding: var(--cbm-space-6) 0; border-top: 1px solid var(--cbm-border); flex-wrap: wrap; }
.cbm-article__tags-label { display: flex; align-items: center; gap: var(--cbm-space-2); font-size: var(--cbm-text-sm); font-weight: var(--cbm-weight-semibold); color: var(--cbm-text-muted); white-space: nowrap; flex-shrink: 0; }
.cbm-article__tags-label svg { width: 16px; height: 16px; opacity: 0.6; }
.cbm-article__tags-list { display: flex; flex-wrap: wrap; gap: var(--cbm-space-2); }
.cbm-tag-pill { display: inline-block; padding: var(--cbm-space-1) var(--cbm-space-4); font-size: var(--cbm-text-xs); font-weight: var(--cbm-weight-semibold); color: var(--cbm-text-muted); background: var(--cbm-surface-raised); border: 1px solid var(--cbm-border); border-radius: var(--cbm-radius-pill); text-decoration: none; transition: var(--cbm-transition); }
.cbm-tag-pill:hover { background: var(--cbm-accent); border-color: var(--cbm-accent); color: #fff; text-decoration: none; }

/* Share */
.cbm-article__share { display: flex; align-items: center; gap: var(--cbm-space-5); padding: var(--cbm-space-6) 0; border-top: 1px solid var(--cbm-border); flex-wrap: wrap; }
.cbm-article__share-label { font-size: var(--cbm-text-sm); font-weight: var(--cbm-weight-semibold); color: var(--cbm-text-muted); white-space: nowrap; flex-shrink: 0; }
.cbm-share { display: flex; align-items: center; gap: var(--cbm-space-3); flex-wrap: wrap; }
.cbm-share__label { font-size: var(--cbm-text-sm); color: var(--cbm-text-muted); font-weight: var(--cbm-weight-semibold); }
.cbm-share__link { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; background: var(--cbm-surface-raised); border: 1px solid var(--cbm-border); border-radius: var(--cbm-radius); color: var(--cbm-text-muted); text-decoration: none; transition: var(--cbm-transition); }
.cbm-share__link:hover { background: var(--cbm-primary); border-color: var(--cbm-primary); color: #fff; text-decoration: none; }
.cbm-share__link svg { width: 18px; height: 18px; }

/* Author box */
.cbm-author-box { display: flex; gap: var(--cbm-space-6); align-items: flex-start; background: var(--cbm-surface-raised); border: 1px solid var(--cbm-border); border-left: 4px solid var(--cbm-accent); border-radius: 0 var(--cbm-radius-lg) var(--cbm-radius-lg) 0; padding: var(--cbm-space-8); margin-top: var(--cbm-space-10); margin-bottom: var(--cbm-space-4); }
.cbm-author-box__avatar { width: 72px; height: 72px; border-radius: var(--cbm-radius-pill); object-fit: cover; flex-shrink: 0; border: 3px solid var(--cbm-surface); box-shadow: var(--cbm-shadow-sm); }
.cbm-author-box__content { flex: 1; min-width: 0; }
.cbm-author-box__role { font-size: var(--cbm-text-xs); font-weight: var(--cbm-weight-black); letter-spacing: var(--cbm-tracking-caps); text-transform: uppercase; color: var(--cbm-accent); margin-bottom: var(--cbm-space-1); }
.cbm-author-box__name { font-family: var(--cbm-font-heading); font-size: var(--cbm-text-xl); margin-bottom: var(--cbm-space-3); }
.cbm-author-box__name a { color: var(--cbm-text-heading); text-decoration: none; }
.cbm-author-box__name a:hover { color: var(--cbm-accent); }
.cbm-author-box__bio { font-size: var(--cbm-text-base); color: var(--cbm-text-muted); line-height: var(--cbm-leading-relaxed); margin-bottom: var(--cbm-space-4); }
.cbm-author-box__links { display: flex; flex-wrap: wrap; gap: var(--cbm-space-3); }

/* Post navigation */
.cbm-post-nav { display: grid; grid-template-columns: 1fr 1fr; gap: var(--cbm-space-4); padding: var(--cbm-space-8) 0; border-top: 1px solid var(--cbm-border); margin-top: var(--cbm-space-4); }
.cbm-post-nav__item { display: flex; flex-direction: column; gap: var(--cbm-space-2); padding: var(--cbm-space-4); background: var(--cbm-surface-raised); border: 1px solid var(--cbm-border); border-radius: var(--cbm-radius-md); transition: var(--cbm-transition); }
.cbm-post-nav__item:hover { border-color: var(--cbm-accent); background: var(--cbm-surface); }
.cbm-post-nav__item--next { text-align: right; }
.cbm-post-nav__label { display: flex; align-items: center; gap: var(--cbm-space-2); font-size: var(--cbm-text-xs); font-weight: var(--cbm-weight-bold); letter-spacing: var(--cbm-tracking-caps); text-transform: uppercase; color: var(--cbm-text-muted); }
.cbm-post-nav__item--next .cbm-post-nav__label { justify-content: flex-end; }
.cbm-post-nav__arrow--prev { transform: rotate(180deg); }
.cbm-post-nav__link { font-family: var(--cbm-font-heading); font-size: var(--cbm-text-base); font-weight: var(--cbm-weight-bold); color: var(--cbm-text-heading); text-decoration: none; line-height: var(--cbm-leading-snug); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.cbm-post-nav__link:hover { color: var(--cbm-accent); }

/* Related posts */
.cbm-related { background: var(--cbm-surface-raised); padding-top: var(--cbm-space-12); padding-bottom: var(--cbm-space-12); margin-top: var(--cbm-space-4); border-top: 1px solid var(--cbm-border); }
.cbm-related__grid { display: grid; grid-template-columns: 1fr; gap: var(--cbm-grid-gap); }

/* ==========================================================================
   ABOUT STRIP
   ========================================================================== */

.cbm-about-strip {
    background:     var(--cbm-bg);
    border-top:     1px solid var(--cbm-border);
    border-bottom:  1px solid var(--cbm-border);
    padding-top:    var(--cbm-space-12);
    padding-bottom: var(--cbm-space-12);
}

.cbm-about-strip__inner {
    display:     grid;
    grid-template-columns: 1fr;
    gap:         var(--cbm-space-10);
    align-items: center;
}

.cbm-about-strip__eyebrow {
    font-family:    var(--cbm-font-body);
    font-size:      var(--cbm-text-xs);
    font-weight:    var(--cbm-weight-black);
    letter-spacing: var(--cbm-tracking-caps);
    text-transform: uppercase;
    color:          var(--cbm-accent);
    margin-bottom:  var(--cbm-space-2);
}

.cbm-about-strip__heading {
    font-family:   var(--cbm-font-heading);
    font-size:     clamp(1.5rem, 3vw, 2.441rem);
    font-weight:   var(--cbm-weight-bold);
    color:         var(--cbm-text-heading);
    line-height:   var(--cbm-leading-snug);
    margin-bottom: var(--cbm-space-4);
}

.cbm-about-strip__desc {
    font-size:     var(--cbm-text-md);
    color:         var(--cbm-text-muted);
    line-height:   var(--cbm-leading-relaxed);
    max-width:     600px;
    margin-bottom: var(--cbm-space-6);
}

.cbm-about-strip__actions {
    display:  flex;
    flex-wrap: wrap;
    gap:      var(--cbm-space-3);
}

.cbm-about-strip__topics {
    display:        flex;
    flex-direction: column;
    gap:            var(--cbm-space-4);
}

.cbm-about-strip__topics-label {
    font-size:      var(--cbm-text-xs);
    font-weight:    var(--cbm-weight-bold);
    letter-spacing: var(--cbm-tracking-caps);
    text-transform: uppercase;
    color:          var(--cbm-text-muted);
    margin:         0;
}

.cbm-about-strip__topic-list {
    display:  flex;
    flex-wrap: wrap;
    gap:      var(--cbm-space-3);
}

/* ==========================================================================
   CATEGORY ARCHIVE HERO — with optional background image
   ========================================================================== */

.cbm-category-page { background: var(--cbm-bg); }

.cbm-category-hero {
    padding:    var(--cbm-space-12) 0;
    background: var(--cbm-primary);
    color:      #fff;
    position:   relative;
    overflow:   hidden;
    background-size:     cover;
    background-position: center;
    background-repeat:   no-repeat;
}

/* Colour variants when no image */
.cbm-category-hero--technology:not(.cbm-category-hero--has-image) { background: var(--cbm-cat-technology); }
.cbm-category-hero--business:not(.cbm-category-hero--has-image)   { background: var(--cbm-cat-business);   }
.cbm-category-hero--creativity:not(.cbm-category-hero--has-image) { background: var(--cbm-cat-creativity); }
.cbm-category-hero--society:not(.cbm-category-hero--has-image)    { background: var(--cbm-cat-society);    }

/* Overlay for image version */
.cbm-category-hero__overlay {
    position: absolute;
    inset:    0;
    background: linear-gradient( to right, rgba(10,18,35,0.82) 0%, rgba(10,18,35,0.55) 60%, rgba(10,18,35,0.3) 100% );
    display:  none;
}
.cbm-category-hero--has-image .cbm-category-hero__overlay { display: block; }

/* Subtle stripe pattern when no image */
.cbm-category-hero:not(.cbm-category-hero--has-image)::before {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient( -45deg, transparent, transparent 20px, rgba(255,255,255,0.03) 20px, rgba(255,255,255,0.03) 40px );
    pointer-events: none;
}

.cbm-category-hero__inner { position: relative; z-index: 1; }

.cbm-category-hero .cbm-breadcrumbs,
.cbm-category-hero .cbm-breadcrumbs a { color: rgba(255,255,255,0.6); }
.cbm-category-hero .cbm-breadcrumbs__current { color: rgba(255,255,255,0.9); }
.cbm-category-hero .cbm-breadcrumbs a:hover { color: var(--cbm-accent); }

.cbm-category-hero__label { display: inline-block; font-size: var(--cbm-text-xs); font-weight: var(--cbm-weight-black); letter-spacing: var(--cbm-tracking-caps); text-transform: uppercase; color: rgba(255,255,255,0.6); margin-bottom: var(--cbm-space-3); }
.cbm-category-hero__title { font-family: var(--cbm-font-heading); font-size: clamp(2rem, 6vw, 3.5rem); font-weight: var(--cbm-weight-black); color: #fff; letter-spacing: var(--cbm-tracking-tight); margin-bottom: var(--cbm-space-4); }
.cbm-category-hero__desc { font-size: var(--cbm-text-md); color: rgba(255,255,255,0.8); max-width: 600px; line-height: var(--cbm-leading-relaxed); margin-bottom: var(--cbm-space-4); }
.cbm-category-hero__count { font-size: var(--cbm-text-sm); color: rgba(255,255,255,0.55); margin: 0; }

.cbm-category-page__content { padding-top: var(--cbm-space-10); padding-bottom: var(--cbm-space-16); }

/* ==========================================================================
   ARCHIVE, AUTHOR, SEARCH, 404
   ========================================================================== */

.cbm-archive-page { padding-top: var(--cbm-space-10); padding-bottom: var(--cbm-space-16); }
.cbm-archive-header { margin-bottom: var(--cbm-space-10); padding-bottom: var(--cbm-space-8); border-bottom: 2px solid var(--cbm-border); }
.cbm-archive-header__title { font-family: var(--cbm-font-heading); font-size: clamp(1.75rem, 4vw, 2.44rem); font-weight: var(--cbm-weight-bold); color: var(--cbm-text-heading); margin-bottom: var(--cbm-space-3); }
.cbm-archive-header__title em { font-style: italic; color: var(--cbm-accent); }
.cbm-archive-header__badge { margin-bottom: var(--cbm-space-3); }
.cbm-archive-header__desc { font-size: var(--cbm-text-md); color: var(--cbm-text-muted); max-width: 600px; line-height: var(--cbm-leading-relaxed); margin-top: var(--cbm-space-4); }
.cbm-archive-header__count { font-size: var(--cbm-text-sm); color: var(--cbm-text-muted); margin-top: var(--cbm-space-4); }

/* Uniform grid — all cards same size */
.cbm-archive-grid { display: grid; grid-template-columns: 1fr; gap: var(--cbm-grid-gap); }

.cbm-no-results { text-align: center; padding: var(--cbm-space-16) 0; }
.cbm-no-results__text { font-size: var(--cbm-text-lg); color: var(--cbm-text-muted); margin-bottom: var(--cbm-space-8); }
.cbm-no-results__categories { margin-top: var(--cbm-space-6); }
.cbm-no-results__categories-label { font-size: var(--cbm-text-sm); color: var(--cbm-text-muted); margin-bottom: var(--cbm-space-3); }
.cbm-no-results__categories-list { display: flex; flex-wrap: wrap; gap: var(--cbm-space-2); justify-content: center; }

/* Author page */
.cbm-author-page { padding-top: var(--cbm-space-10); padding-bottom: var(--cbm-space-16); }
.cbm-author-profile { display: flex; gap: var(--cbm-space-8); align-items: flex-start; margin-bottom: var(--cbm-space-12); padding-bottom: var(--cbm-space-10); border-bottom: 2px solid var(--cbm-border); flex-wrap: wrap; }
.cbm-author-profile__avatar { width: 120px; height: 120px; border-radius: var(--cbm-radius-pill); object-fit: cover; border: 4px solid var(--cbm-surface-raised); box-shadow: var(--cbm-shadow); flex-shrink: 0; }
.cbm-author-profile__role { font-size: var(--cbm-text-xs); font-weight: var(--cbm-weight-black); letter-spacing: var(--cbm-tracking-caps); text-transform: uppercase; color: var(--cbm-accent); margin-bottom: var(--cbm-space-2); }
.cbm-author-profile__name { font-family: var(--cbm-font-heading); font-size: clamp(1.75rem, 4vw, 2.44rem); font-weight: var(--cbm-weight-bold); color: var(--cbm-text-heading); margin-bottom: var(--cbm-space-4); }
.cbm-author-profile__bio { font-size: var(--cbm-text-md); color: var(--cbm-text-muted); max-width: 600px; line-height: var(--cbm-leading-relaxed); margin-bottom: var(--cbm-space-4); }
.cbm-author-profile__meta { display: flex; align-items: center; gap: var(--cbm-space-5); flex-wrap: wrap; }
.cbm-author-profile__count { font-size: var(--cbm-text-sm); color: var(--cbm-text-muted); font-weight: var(--cbm-weight-semibold); }
.cbm-author-profile__link { display: flex; align-items: center; gap: var(--cbm-space-2); font-size: var(--cbm-text-sm); font-weight: var(--cbm-weight-semibold); color: var(--cbm-accent); text-decoration: none; }
.cbm-author-profile__link:hover { color: var(--cbm-accent-hover); }
.cbm-author-articles__heading { font-family: var(--cbm-font-heading); font-size: var(--cbm-text-2xl); margin-bottom: var(--cbm-space-8); padding-bottom: var(--cbm-space-4); border-bottom: 2px solid var(--cbm-border); }

/* 404 */
.cbm-404 { display: flex; align-items: center; justify-content: center; min-height: 70vh; padding: var(--cbm-space-16) 0; text-align: center; }
.cbm-404__inner { max-width: 560px; display: flex; flex-direction: column; align-items: center; gap: var(--cbm-space-6); }
.cbm-404__number { font-family: var(--cbm-font-heading); font-size: clamp(5rem, 20vw, 10rem); font-weight: var(--cbm-weight-black); color: var(--cbm-border-strong); line-height: 1; letter-spacing: var(--cbm-tracking-tight); user-select: none; }
.cbm-404__title { font-family: var(--cbm-font-heading); font-size: var(--cbm-text-3xl); color: var(--cbm-text-heading); }
.cbm-404__message { font-size: var(--cbm-text-md); color: var(--cbm-text-muted); line-height: var(--cbm-leading-relaxed); margin: 0; }
.cbm-404__search { width: 100%; max-width: 440px; }
.cbm-404__topic-list { display: flex; flex-wrap: wrap; gap: var(--cbm-space-2); justify-content: center; }
.cbm-404__topics-label { font-size: var(--cbm-text-sm); color: var(--cbm-text-muted); font-weight: var(--cbm-weight-semibold); }

/* Standard page */
.cbm-page-article { padding-bottom: var(--cbm-space-16); }
.cbm-page-article__header { padding-top: var(--cbm-space-10); padding-bottom: var(--cbm-space-8); }
.cbm-page-article__title { font-family: var(--cbm-font-heading); font-size: clamp(1.75rem, 5vw, 3rem); font-weight: var(--cbm-weight-black); color: var(--cbm-text-heading); margin-top: var(--cbm-space-5); margin-bottom: var(--cbm-space-6); }
.cbm-page-article__body { padding-top: var(--cbm-space-4); padding-bottom: var(--cbm-space-10); }

/* Full-width page template body */
.cbm-page-article__body--fullwidth .entry-content { max-width: var(--cbm-max-width); margin: 0 auto; }
.cbm-page-article__body--fullwidth iframe,
.cbm-page-article__body--fullwidth embed,
.cbm-page-article__body--fullwidth object { width: 100%; max-width: 100%; border: none; display: block; }

/* Search form */
.cbm-search-results__form { margin-top: var(--cbm-space-6); max-width: 480px; }
.search-form { display: flex; border: 1px solid var(--cbm-border); border-radius: var(--cbm-radius); overflow: hidden; background: var(--cbm-surface); }
.search-form label { flex: 1; display: block; }
.search-form .search-field { width: 100%; padding: var(--cbm-space-3) var(--cbm-space-4); font-family: var(--cbm-font-body); font-size: var(--cbm-text-base); color: var(--cbm-text); background: transparent; border: none; outline: none; }
.search-form .search-field::placeholder { color: var(--cbm-text-muted); }
.search-form .search-submit { padding: 0 var(--cbm-space-4); background: var(--cbm-accent); color: #fff; border: none; font-family: var(--cbm-font-body); font-weight: var(--cbm-weight-semibold); cursor: pointer; transition: background 0.2s ease; white-space: nowrap; font-size: var(--cbm-text-sm); }
.search-form .search-submit:hover { background: var(--cbm-accent-hover); }

/* ==========================================================================
   DARK MODE
   ========================================================================== */

[data-theme="dark"] .cbm-about-strip { background: var(--cbm-bg); border-color: var(--cbm-border); }
[data-theme="dark"] .cbm-article-header--no-hero { background: var(--cbm-bg); }
[data-theme="dark"] .cbm-author-box { background: var(--cbm-surface); border-color: var(--cbm-border); }
[data-theme="dark"] .cbm-post-nav__item { background: var(--cbm-surface); border-color: var(--cbm-border); }
[data-theme="dark"] .cbm-related { background: var(--cbm-surface); border-color: var(--cbm-border); }
[data-theme="dark"] .cbm-tag-pill { background: var(--cbm-surface); border-color: var(--cbm-border); }
[data-theme="dark"] .cbm-share__link { background: var(--cbm-surface); border-color: var(--cbm-border); }
[data-theme="dark"] .search-form { background: var(--cbm-surface); border-color: var(--cbm-border); }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (min-width: 768px) {
    .cbm-article-hero-wrap { min-height: clamp(400px, 55vh, 620px); }
    .cbm-related__grid { grid-template-columns: repeat(2, 1fr); }
    .cbm-archive-grid  { grid-template-columns: repeat(2, 1fr); }
    .cbm-about-strip__inner { grid-template-columns: 2fr 1fr; }
}

@media (min-width: 1024px) {
    .cbm-article-hero-wrap { min-height: clamp(440px, 58vh, 640px); }
    .cbm-related__grid { grid-template-columns: repeat(3, 1fr); }
    .cbm-archive-grid  { grid-template-columns: repeat(3, 1fr); }
    .cbm-post-nav      { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 767px) {
    .cbm-author-box    { flex-direction: column; gap: var(--cbm-space-4); }
    .cbm-post-nav      { grid-template-columns: 1fr; }
    .cbm-post-nav__item--next { text-align: left; }
    .cbm-post-nav__item--next .cbm-post-nav__label { justify-content: flex-start; }
    .cbm-author-profile { flex-direction: column; align-items: center; text-align: center; }
    .cbm-author-profile__meta { justify-content: center; }
    .cbm-article-hero__meta { flex-direction: column; align-items: flex-start; gap: var(--cbm-space-2); }
    .cbm-article-hero__meta-sep { display: none; }
}

@media (prefers-reduced-motion: reduce) {
    .cbm-tag-pill, .cbm-share__link, .cbm-post-nav__item { transition: none; }
}
