/* ── BWS Blog Styles ──────────────────────────────────────────────────────── */

/* Single post hero */
.bws-post-hero {
    display: grid;
    grid-template-columns: 5fr 7fr;
    gap: 52px;
    align-items: center;
    margin-bottom: 52px;
}
@media (max-width: 991px) {
    .bws-post-hero { grid-template-columns: 1fr; gap: 28px; }
}

.bws-post-hero__text {
    padding-right: clamp(0px, 3vw, 48px);
}

.bws-post-hero__title {
    font-size: clamp(28px, 4vw, 42px);
    font-weight: 700;
    line-height: 1.1;
    color: var(--c-dark, #101811);
    margin-bottom: 22px;
}

.bws-post-hero__img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    border-radius: 20px;
    box-shadow: 0 10px 30px rgba(0,0,0,.05);
    cursor: zoom-in;
}

/* Breadcrumb */
.bws-breadcrumb {
    list-style: none;
    padding: 0;
    margin: 0 0 24px;
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    font-size: 13px;
    color: #666;
}
.bws-breadcrumb li + li::before { content: '›'; margin-right: 4px; }
.bws-breadcrumb a { color: #666; text-decoration: none; }
.bws-breadcrumb a:hover { color: var(--c-green, #2ecc71); }
.bws-breadcrumb li:last-child { color: #111; font-weight: 600; }

/* Author meta */
.bws-post-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
}
.bws-post-meta__avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    overflow: hidden;
    background: linear-gradient(135deg, #e2e8f0, #f1f5f9);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 14px;
    color: #374151;
    flex-shrink: 0;
    border: 1px solid rgba(255,255,255,.8);
}
.bws-post-meta__avatar img { width: 100%; height: 100%; object-fit: cover; }
.bws-post-meta__author { font-size: 15px; font-weight: 600; color: #111; }
.bws-post-meta__date   { font-size: 15px; color: #666; font-weight: 500; }
.bws-post-meta__reads  { font-size: 14px; color: #aaa; }

/* Category badge */
.bws-post-cat-badge {
    display: inline-block;
    padding: 5px 14px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    background: #f4f5f7;
    border-radius: 9999px;
    color: #111;
    text-decoration: none;
    transition: background .15s;
}
.bws-post-cat-badge:hover { background: var(--c-green, #2ecc71); color: #fff; }

/* Layout: share sidebar + content — constrained to readable width */
.bws-post-body {
    display: flex;
    gap: 40px;
    align-items: flex-start;
    max-width: 860px;
}
.bws-post-share-sidebar {
    width: 72px;
    flex-shrink: 0;
    display: block; /* always visible on desktop */
}
.bws-post-content-col { flex: 1; min-width: 0; }

/* Share sidebar — sticky within the article scroll area */
.bws-share-inner {
    position: sticky;
    top: 20px;
    padding-top: 8px;
}

/* Hide share sidebar on mobile, show mobile bar instead */
@media (max-width: 991px) {
    .bws-post-share-sidebar { display: none; }
    .bws-mobile-share { display: flex; }
}
@media (min-width: 992px) {
    .bws-mobile-share { display: none; }
}

/* Reading progress ring */
.bws-progress-wrap {
    width: 72px;
    height: 72px;
    position: relative;
    margin-bottom: 20px;
}
.bws-progress-wrap svg { display: block; }
.bws-progress-ring { transform: rotate(-90deg); transform-origin: center; }
.bws-ring-bg       { stroke: #eaeaea; }
.bws-ring-fill     { stroke: var(--c-green, #2ecc71); transition: stroke-dashoffset .1s linear; }
.bws-progress-text {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    line-height: 1.2;
}
.bws-progress-text strong { font-size: 12px; font-weight: 700; color: #111; }
.bws-progress-text span   { font-size: 9px; font-weight: 600; text-transform: uppercase; color: #aaa; letter-spacing: .04em; }

/* Share icons */
.bws-share-icons {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}
.bws-share-icons a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #f4f5f7;
    color: #555;
    transition: background .15s, color .15s;
}
.bws-share-icons a:hover { background: var(--c-green, #2ecc71); color: #fff; }

/* Copy link button */
.bws-copy-btn { position: relative; }
.bws-copy-btn .bws-check-icon { display: none; }
.bws-copy-btn.copied .bws-copy-icon { display: none; }
.bws-copy-btn.copied .bws-check-icon { display: inline; color: #22c55e; }
.bws-copy-tooltip {
    position: absolute;
    bottom: calc(100% + 6px);
    left: 50%;
    transform: translateX(-50%) translateY(4px);
    background: #222;
    color: #fff;
    font-size: 10px;
    white-space: nowrap;
    padding: 3px 7px;
    border-radius: 4px;
    pointer-events: none;
    opacity: 0;
    transition: opacity .2s, transform .2s;
}
.bws-copy-btn.copied .bws-copy-tooltip { opacity: 1; transform: translateX(-50%) translateY(-2px); }

/* Article content */
.bws-post-article {
    font-size: 16.5px;
    line-height: 1.8;
    color: #333;
}
.bws-post-article h2 {
    font-size: 24px;
    font-weight: 700;
    margin: 40px 0 14px;
    color: var(--c-dark, #101811);
    line-height: 1.25;
}
.bws-post-article h3 {
    font-size: 19px;
    font-weight: 600;
    margin: 30px 0 10px;
    color: var(--c-dark, #101811);
}
.bws-post-article p  { margin: 0 0 20px; }
.bws-post-article ul,
.bws-post-article ol { margin: 0 0 20px; padding-left: 24px; }
.bws-post-article li { margin-bottom: 8px; }
.bws-post-article a  { color: var(--c-green, #2ecc71); text-decoration: underline; text-underline-offset: 3px; }
.bws-post-article a:hover { opacity: .8; }
.bws-post-article strong { color: var(--c-dark, #101811); }
.bws-post-article blockquote {
    border-left: 3px solid var(--c-green, #2ecc71);
    margin: 24px 0;
    padding: 12px 0 12px 20px;
    font-style: italic;
    color: #555;
}

.bws-post-figure { margin: 28px 0; }
.bws-post-img {
    width: 100%;
    border-radius: 12px;
    cursor: zoom-in;
    display: block;
}

/* Post divider */
.bws-post-divider { border: none; border-top: 1px solid #f0f0f0; margin: 32px 0 0; }

/* Mobile share bar */
.bws-mobile-share {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    border-top: 1px solid #eee;
    padding-top: 20px;
    margin-top: 28px;
}
.bws-mobile-share__label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: #aaa;
    letter-spacing: .05em;
}
.bws-mobile-share-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #f4f5f7;
    color: #555;
    transition: background .15s, color .15s;
}
.bws-mobile-share-btn:hover { background: var(--c-green, #2ecc71); color: #fff; }

/* Lightbox */
#bws-lightbox {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(0,0,0,.88);
    align-items: center;
    justify-content: center;
    padding: 20px;
    box-sizing: border-box;
}
#bws-lightbox.active { display: flex; flex-direction: column; }
#bws-lb-close {
    position: absolute;
    top: 16px; right: 20px;
    background: none; border: none;
    color: #fff; font-size: 28px;
    cursor: pointer; padding: 4px 10px; opacity: .8;
}
#bws-lb-close:hover { opacity: 1; }
#bws-lb-prev, #bws-lb-next {
    position: absolute;
    top: 50%; transform: translateY(-50%);
    background: rgba(255,255,255,.15); border: none;
    color: #fff; font-size: 28px;
    cursor: pointer; padding: 8px 14px;
    border-radius: 50%;
    display: none;
}
#bws-lb-prev { left: 12px; }
#bws-lb-next { right: 12px; }
#bws-lb-prev:hover, #bws-lb-next:hover { background: rgba(255,255,255,.3); }
#bws-lb-img {
    max-width: 100%; max-height: 90vh;
    object-fit: contain;
    border-radius: 6px;
    box-shadow: 0 20px 60px rgba(0,0,0,.5);
    display: block;
}
#bws-lb-caption {
    color: #ccc; font-size: 13px;
    text-align: center;
    margin-top: 10px; margin-bottom: 0;
    max-width: 600px;
}

/* Blog archive / category pages */

/* Category page wrapper — off-white background */
.bws-category-page { background: #fafafa; }
.bws-category-page .bws-page-wrap { background: #fafafa; }

/* Category page header */
.bws-cat-header { margin: 28px 0 32px; }
.bws-cat-desc {
    font-size: 15px;
    color: #6b7280;
    max-width: 640px;
    margin: 0;
    line-height: 1.6;
}

/* Card feed — single column, max readable width, centred */
.bws-blog-grid {
    display: flex;
    flex-direction: column;
    gap: 0;
    max-width: 780px;
}

/* Card */
.bws-blog-card {
    background: #fff;
    color: inherit;
    display: flex;
    flex-direction: column;
    border-bottom: 1px solid #e5e7eb;
    padding-bottom: 28px;
    margin-bottom: 28px;
}
.bws-blog-card:last-child { border-bottom: none; margin-bottom: 0; }

/* Image area with overlay badges */
.bws-blog-card__media {
    position: relative;
    overflow: hidden;
    border-radius: 12px;
    margin-bottom: 18px;
    background: #f3f4f6;
}
.bws-blog-card__img-link { display: block; }
.bws-blog-card__img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    display: block;
    transition: transform .3s;
}
.bws-blog-card__img--placeholder {
    width: 100%;
    aspect-ratio: 16 / 10;
    background: #e5e7eb;
}
.bws-blog-card__media:hover .bws-blog-card__img { transform: scale(1.03); }

/* Read-time pill — top left over image */
.bws-blog-card__readtime {
    position: absolute;
    top: 10px;
    left: 10px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    border-radius: 20px;
    padding: 4px 9px;
    font-size: 11px;
    font-weight: 600;
    color: #111827;
    line-height: 1;
}
.bws-blog-card__readtime svg { flex-shrink: 0; }

/* Category badge — bottom left over image, shown on card hover */
.bws-blog-card__cat-badge {
    position: absolute;
    bottom: 10px;
    left: 10px;
    background: var(--c-green, #2ecc71);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    padding: 3px 8px;
    border-radius: 4px;
    text-decoration: none;
    margin: 0;
    line-height: 1;
}
.bws-blog-card__cat-badge a { color: #fff; text-decoration: none; }
.bws-blog-card__cat-badge a:hover { color: #fff; }

/* Card body */
.bws-blog-card__body { display: flex; flex-direction: column; flex: 1; }

/* Date + meta row */
.bws-blog-card__meta {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #6b7280;
    margin-bottom: 6px;
}

/* Title */
.bws-blog-card__title {
    font-size: 17px;
    font-weight: 700;
    line-height: 1.35;
    margin: 0 0 10px;
}
.bws-blog-card__title a { color: #111827; text-decoration: none; }
.bws-blog-card__title a:hover { color: var(--c-green, #2ecc71); }

/* Excerpt */
.bws-blog-card__excerpt {
    font-size: 13.5px;
    color: #6b7280;
    line-height: 1.6;
    margin-bottom: 14px;
    flex: 1;
}

/* Read more text link */
.bws-blog-card__readmore {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12.5px;
    font-weight: 600;
    color: var(--c-green, #2ecc71);
    text-decoration: none;
    margin-top: auto;
    transition: gap .15s;
}
.bws-blog-card__readmore:hover { gap: 8px; color: #27ae60; }

/* Pagination */
.bws-pagination { margin: 48px 0 0; display: flex; justify-content: flex-start; }
.bws-pagination .page-numbers {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 3px;
    align-items: center;
}
.bws-pagination .page-numbers li a,
.bws-pagination .page-numbers li span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 10px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    border: 1px solid #e5e7eb;
    color: #111827;
    background: #fff;
    transition: background .15s, color .15s, border-color .15s, box-shadow .15s;
}
.bws-pagination .page-numbers li a:hover {
    background: #f3f9f5;
    border-color: var(--c-green, #2ecc71);
    color: var(--c-green, #2ecc71);
    box-shadow: 0 0 0 3px rgba(46,204,113,.10);
}
.bws-pagination .page-numbers li span.current {
    background: var(--c-green, #2ecc71);
    border-color: var(--c-green, #2ecc71);
    color: #fff;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(46,204,113,.30);
}
.bws-pagination .page-numbers li span.dots {
    border-color: transparent;
    background: none;
    color: #aaa;
}

@media (max-width: 767px) {
    .bws-post-hero { gap: 20px; }
    .bws-blog-grid { max-width: 100%; }
}

/* ── Blog category archive layout ─────────────────────────────────────────── */

.bws-blog-archive-wrap {
    padding: 28px 0 64px;
}

.bws-blog-archive-wrap > .bws-breadcrumb {
    width: 100%;
    margin: 0 0 24px;
}

.bws-blog-archive-wrap > .bws-breadcrumb .bws-breadcrumb__inner {
    max-width: none;
    width: 100%;
    margin: 0;
    padding-left: 0;
    padding-right: 0;
    justify-content: flex-start;
    text-align: left;
}

/* Override WP constrained layout padding on the archive wrap */
.bws-blog-archive-wrap > .bws-breadcrumb,
.bws-blog-archive-wrap > .wp-block-query-title,
.bws-blog-archive-wrap > .wp-block-term-description,
.bws-blog-archive-wrap > .wp-block-columns {
    padding-left: 0;
    padding-right: 0;
}

/* Category title */
.bws-blog-archive-wrap .wp-block-query-title {
    font-size: clamp(22px, 3.5vw, 32px) !important;
    font-weight: 700 !important;
    color: var(--c-dark, #101811);
    line-height: 1.2;
}

/* Category description */
.bws-blog-archive-wrap .wp-block-term-description {
    font-size: 15px;
    color: #6b7280;
    margin-bottom: 24px;
}

/* Columns block: don't let WP add extra gap */
.bws-blog-archive-wrap > .wp-block-columns {
    gap: 48px !important;
    align-items: flex-start;
    margin-top: 0;
    flex-wrap: nowrap !important;
}

/* Force correct splits — desktop only */
@media (min-width: 1024px) {
    /* 67/33 split on archive listing columns (blog + category pages) */
    .bws-blog-archive-wrap > .wp-block-columns:not(.bws-single-hero):not(.bws-single-body) > .wp-block-column:first-child {
        flex: 0 0 67% !important;
        max-width: 67%;
    }
    .bws-blog-archive-wrap > .wp-block-columns:not(.bws-single-hero):not(.bws-single-body) > .wp-block-column:last-child {
        flex: 0 0 33% !important;
        max-width: 33%;
    }

    /* 3-col single post body: share | content | sidebar */
    .bws-single-body > .bws-single-share-col {
        flex: 0 0 88px !important;
        max-width: 88px !important;
        align-self: stretch !important;
    }
    .bws-single-body > .bws-single-post-main {
        flex: 1 1 0 !important;
        max-width: none !important;
    }
    .bws-single-body > .bws-blog-archive-sidebar {
        flex: 0 0 260px !important;
        max-width: 260px !important;
    }

    /* 42/58 split on single post hero */
    .bws-single-hero > .wp-block-column:first-child {
        flex: 0 0 42% !important;
        max-width: 42%;
    }
    .bws-single-hero > .wp-block-column:last-child {
        flex: 0 0 58% !important;
        max-width: 58%;
    }
}
}

/* ── 2-column post grid ────────────────────────────────────────────────────── */

/* Post grid — layout injected via render_block filter (inline style on ul).
   CSS here handles resets and mobile override only. */
.bws-blog-grid--2col.wp-block-post-template {
    margin: 0;
    padding: 0;
    list-style: none;
}

.bws-blog-grid--2col.wp-block-post-template > li {
    margin: 0;
    padding: 0;
    min-width: 0;
}

/* ── Compact card (wp:group wrapping each post) ────────────────────────────── */

.bws-blog-card--compact {
    background: #fff;
    border-radius: 12px;
    border-bottom: none !important;
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
    box-shadow: 0 1px 4px rgba(0,0,0,.06);
    overflow: hidden;
    transition: box-shadow .2s, transform .2s;
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    height: 100%;
}
.bws-blog-card--compact:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,.10);
    transform: translateY(-2px);
}

/* Image area */
.bws-blog-card--compact .bws-blog-card__media {
    margin-bottom: 0 !important;
    padding: 0 !important;
    border-radius: 0 !important;
    overflow: hidden;
}
.bws-blog-card--compact .bws-blog-card__media .wp-block-post-featured-image {
    margin: 0;
    line-height: 0;
}
.bws-blog-card--compact .bws-blog-card__media .wp-block-post-featured-image a,
.bws-blog-card--compact .bws-blog-card__media .wp-block-post-featured-image img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    transition: transform .3s;
}
.bws-blog-card--compact:hover .bws-blog-card__media img { transform: scale(1.03); }

/* No-image placeholder */
.bws-blog-card--compact .bws-blog-card__media .wp-block-post-featured-image:empty {
    aspect-ratio: 16 / 9;
    background: #e5e7eb;
}

/* Text body */
.bws-blog-card--compact .bws-blog-card__body {
    padding: 14px 16px 16px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    flex: 1;
}

/* Date */
.bws-blog-card--compact .bws-blog-card__meta.wp-block-post-date {
    font-size: 10px !important;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #6b7280;
    margin-bottom: 5px !important;
    line-height: 1.4;
}
.bws-blog-card--compact .bws-blog-card__meta.wp-block-post-date a { color: inherit; text-decoration: none; }

/* Title */
.bws-blog-card--compact .bws-blog-card__title.wp-block-post-title {
    font-size: 15px !important;
    font-weight: 700 !important;
    line-height: 1.35 !important;
    margin: 0 0 8px !important;
    color: #111827;
}
.bws-blog-card--compact .bws-blog-card__title.wp-block-post-title a {
    color: #111827;
    text-decoration: none;
}
.bws-blog-card--compact .bws-blog-card__title.wp-block-post-title a:hover {
    color: var(--c-green, #2ecc71);
}

/* Excerpt */
.bws-blog-card--compact .bws-blog-card__excerpt.wp-block-post-excerpt {
    font-size: 12.5px !important;
    color: #6b7280;
    line-height: 1.55;
    margin: 0 !important;
}
.bws-blog-card--compact .bws-blog-card__excerpt .wp-block-post-excerpt__excerpt {
    margin: 0 0 8px;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.bws-blog-card--compact .bws-blog-card__excerpt .wp-block-post-excerpt__more-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    font-weight: 600;
    color: var(--c-green, #2ecc71);
    text-decoration: none;
}
.bws-blog-card--compact .bws-blog-card__excerpt .wp-block-post-excerpt__more-link:hover {
    color: #27ae60;
}

/* Pagination */
.bws-blog-archive-wrap .bws-pagination {
    margin-top: 32px;
}

/* ── Sidebar ────────────────────────────────────────────────────────────────── */

.bws-blog-archive-sidebar {
    position: sticky;
    top: 88px;
    align-self: flex-start;
}

.bws-blog-sidebar-widget {
    background: #fff;
    border-radius: 12px;
    border: 1px solid #e5e7eb;
    padding: 20px;
}

.bws-blog-sidebar-title {
    font-size: 13px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: #6b7280 !important;
    margin: 0 0 14px !important;
    padding-bottom: 10px;
    border-bottom: 1px solid #f0f0f0;
}

/* WP categories block list */
.bws-blog-cat-list.wp-block-categories-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.bws-blog-cat-list.wp-block-categories-list li {
    margin: 0 !important;
    padding: 0 !important;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-radius: 8px;
    transition: background .15s;
}
.bws-blog-cat-list.wp-block-categories-list li:hover {
    background: #f3f9f5;
}
.bws-blog-cat-list.wp-block-categories-list li a {
    flex: 1;
    padding: 8px 10px;
    text-decoration: none;
    color: #374151;
    font-size: 13.5px;
    font-weight: 500;
    transition: color .15s;
}
.bws-blog-cat-list.wp-block-categories-list li a:hover {
    color: var(--c-green, #2ecc71);
}
.bws-blog-cat-list.wp-block-categories-list li .bws-blog-cat-link__count {
    padding-right: 10px;
}
/* Post count in parens — style the whole link item; count is in the link text */
.bws-blog-cat-list.wp-block-categories-list li .wp-block-categories__post-count {
    font-size: 11px;
    font-weight: 600;
    background: #f3f4f6;
    color: #6b7280;
    border-radius: 20px;
    padding: 2px 7px;
    margin-left: 6px;
}

.bws-blog-no-posts {
    color: #6b7280;
    font-size: 15px;
    grid-column: 1 / -1;
}

/* ── Share / reading-progress sidebar ─────────────────────────────────────── */

.bws-post-share-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    position: sticky;
    top: 100px;
    padding-top: 8px;
}

.bws-reading-progress-container {
    position: relative;
    width: 80px;
    height: 80px;
    flex-shrink: 0;
}

.bws-reading-ring-svg {
    display: block;
    transform: rotate(-90deg);
}

.bws-reading-progress-text {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1px;
}

#bws-read-time-mins {
    font-weight: 700;
    font-size: 12px;
    color: #111;
    line-height: 1.2;
}

.bws-rpt-label {
    font-size: 9px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: #999;
}

.bws-share-icons {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

.bws-share-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #f0f4f1;
    color: #3a4a3e;
    text-decoration: none;
    transition: background .18s, color .18s, transform .15s;
}

.bws-share-btn:hover {
    background: var(--c-green, #2ecc71);
    color: #fff;
    transform: scale(1.1);
}

#bws-copy-link .bws-check-icon { display: none; }
#bws-copy-link.copied .bws-copy-icon { display: none; }
#bws-copy-link.copied .bws-check-icon { display: flex; color: #22c55e; animation: bws-pop-in .2s ease; }
#bws-copy-link.copied .bws-copy-tooltip { opacity: 1; transform: translateX(-50%) translateY(-4px); }

.bws-copy-tooltip {
    position: absolute;
    bottom: calc(100% + 6px);
    left: 50%;
    transform: translateX(-50%) translateY(4px);
    background: #222;
    color: #fff;
    font-size: 10px;
    white-space: nowrap;
    padding: 3px 7px;
    border-radius: 4px;
    pointer-events: none;
    opacity: 0;
    transition: opacity .2s, transform .2s;
    z-index: 10;
}

@keyframes bws-pop-in {
    0%   { transform: scale(.5); }
    70%  { transform: scale(1.2); }
    100% { transform: scale(1); }
}

/* ── Single post layout ────────────────────────────────────────────────────── */

.bws-single-post-wrap {
    padding-top: 24px;
}

/* Hero row */
.bws-single-hero {
    gap: 44px !important;
    align-items: center !important;
    margin-bottom: 40px !important;
}

.bws-single-hero__text {
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.bws-single-breadcrumb {
    margin-bottom: 14px !important;
}

.bws-single-cat-terms.wp-block-post-terms {
    margin: 0 0 10px !important;
}
.bws-single-cat-terms.wp-block-post-terms a {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: #fff;
    background: var(--c-green, #2ecc71);
    padding: 3px 10px;
    border-radius: 4px;
    text-decoration: none;
}
.bws-single-cat-terms.wp-block-post-terms a:hover {
    background: #27ae60;
}

.bws-single-post-title.wp-block-post-title {
    font-size: clamp(22px, 3.5vw, 36px) !important;
    font-weight: 800 !important;
    line-height: 1.15 !important;
    color: var(--c-dark, #101811);
    margin: 0 0 16px !important;
}

.bws-single-post-meta {
    gap: 8px !important;
    margin: 0 !important;
}
.bws-single-post-meta .wp-block-post-date {
    font-size: 13px;
    color: #6b7280;
}

/* Featured image */
.bws-single-hero__img-col .bws-single-post-hero-img.wp-block-post-featured-image {
    margin: 0;
}
.bws-single-hero__img-col .bws-single-post-hero-img.wp-block-post-featured-image img {
    border-radius: 16px;
    width: 100%;
    object-fit: cover;
    display: block;
}

/* Body columns */
.bws-single-body {
    gap: 48px !important;
    align-items: flex-start !important;
}

.bws-single-post-main {
    min-width: 0;
}

/* ── Blog page hero ────────────────────────────────────────────────────────── */

.bws-blog-page-hero {
    margin: 28px 0 28px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--c-border, #dde8de);
}

.bws-blog-page-title {
    font-size: clamp(24px, 4vw, 38px) !important;
    font-weight: 800 !important;
    color: var(--c-dark, #101811);
    line-height: 1.15;
    margin: 0 0 12px !important;
}

.bws-blog-page-desc {
    font-size: 16px;
    color: #4b5563;
    line-height: 1.65;
    max-width: 680px;
    margin: 0 !important;
}

/* ── Sidebar CTA widget ────────────────────────────────────────────────────── */

.bws-blog-sidebar-cta {
    background: var(--c-dark, #101811);
    border-radius: 12px;
    padding: 20px;
    margin-top: 16px;
}

.bws-blog-sidebar-cta__eyebrow {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--c-green, #2ecc71);
    margin: 0 0 8px;
}

.bws-blog-sidebar-cta__text {
    font-size: 13px;
    color: rgba(255,255,255,.75);
    line-height: 1.55;
    margin: 0 0 14px;
}

.bws-blog-sidebar-cta__btn {
    display: block;
    text-align: center;
    background: var(--c-green, #2ecc71);
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    padding: 10px 16px;
    border-radius: 8px;
    text-decoration: none;
    transition: background .15s;
}
.bws-blog-sidebar-cta__btn:hover {
    background: #27ae60;
    color: #fff;
}

.bws-blog-sidebar-cta__bonus {
    margin: 0 0 14px;
    border-top: 1px solid rgba(255,255,255,.12);
    padding-top: 12px;
}

.bws-blog-sidebar-cta__bonus-label {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--c-amber, #f5a623);
    margin: 0 0 8px;
}

.bws-blog-sidebar-cta__bonus-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4px 8px;
}

.bws-blog-sidebar-cta__bonus-row {
    display: contents;
}

.bws-blog-sidebar-cta__bonus-qty {
    font-size: 12px;
    color: rgba(255,255,255,.65);
}

.bws-blog-sidebar-cta__bonus-free {
    font-size: 12px;
    color: var(--c-green, #2ecc71);
    font-weight: 600;
}

/* ── Responsive ────────────────────────────────────────────────────────────── */

@media (max-width: 1023px) {
    /* Sidebar sits after posts in DOM order — no override needed */
    .bws-blog-archive-sidebar {
        position: static;
    }
    .bws-blog-archive-wrap {
        padding-left: 20px;
        padding-right: 20px;
    }
    .bws-blog-archive-wrap > .bws-breadcrumb,
    .bws-blog-archive-wrap > .wp-block-query-title,
    .bws-blog-archive-wrap > .wp-block-term-description,
    .bws-blog-archive-wrap > .wp-block-columns,
    .bws-blog-archive-wrap > .bws-blog-page-hero {
        padding-left: 0;
        padding-right: 0;
    }
    .bws-blog-archive-wrap > .wp-block-columns {
        flex-direction: column !important;
    }
    .bws-blog-archive-wrap > .wp-block-columns > .wp-block-column {
        width: 100% !important;
    }
    .bws-blog-page-desc {
        font-size: 15px;
    }

    /* Single post: stack hero — image first, then text */
    .bws-single-hero {
        flex-direction: column-reverse !important;
        margin-bottom: 28px !important;
    }
    .bws-single-hero > .wp-block-column {
        width: 100% !important;
    }
    .bws-single-body {
        flex-direction: column !important;
    }
    .bws-single-body > .wp-block-column {
        width: 100% !important;
    }

    /* Share col: slot between content and sidebar, hide read time ring */
    .bws-single-post-main      { order: 1; }
    .bws-single-share-col      { order: 2; }
    .bws-blog-archive-sidebar  { order: 3; }

    .bws-post-share-wrap {
        position: static;
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
        padding: 14px 16px;
        background: #f7faf8;
        border-radius: 12px;
        gap: 8px;
    }
    .bws-reading-progress-container {
        display: none;
    }
    .bws-share-icons {
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
    }
}

@media (max-width: 767px) {
    .bws-blog-grid--2col.wp-block-post-template {
        grid-template-columns: 1fr !important; /* override the inline style set by PHP filter */
    }
    .bws-blog-archive-wrap {
        padding: 20px 16px 48px;
    }
    .bws-blog-archive-wrap > .bws-breadcrumb,
    .bws-blog-archive-wrap > .wp-block-query-title,
    .bws-blog-archive-wrap > .wp-block-term-description,
    .bws-blog-archive-wrap > .wp-block-columns,
    .bws-blog-archive-wrap > .bws-blog-page-hero {
        padding-left: 0;
        padding-right: 0;
    }
    .bws-blog-page-hero {
        margin-top: 0;
    }
}
