/*
 * FILE: assets/css/blog.css
 * Place in: your-theme/assets/css/blog.css
 * Enqueue in functions.php (see functions-blog.php)
 *
 * All classes prefixed coco-blog- / coco-post- / coco-single- / coco-sidebar-
 * Zero conflicts with WooCommerce or theme base CSS.
 */

/* ═══════════════════════════════════════════════════════
   DESIGN TOKENS
═══════════════════════════════════════════════════════ */
:root {
    --cb-pink:      #b56566;
    --cb-pink-dk:   #9e4f50;
    --cb-pink-lt:   #d4888a;
    --cb-cream:     #fff6f5;
    --cb-cream-dk:  #fdecea;
    --cb-border:    #f0e8e8;
    --cb-text:      #1a1a1a;
    --cb-text-muted:#666;
    --cb-radius:    12px;
    --cb-radius-sm: 6px;
    --cb-shadow:    0 4px 24px rgba(181,101,102,.10);
    --cb-shadow-lg: 0 8px 40px rgba(181,101,102,.15);
    --cb-max-w:     1200px;
    --cb-content-w: 720px;
}

/* ═══════════════════════════════════════════════════════
   READING PROGRESS BAR
═══════════════════════════════════════════════════════ */
.coco-reading-bar {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--cb-border);
    z-index: 9999;
    display: none; /* shown via JS on single posts */
}
.coco-reading-bar-fill {
    height: 100%;
    width: 0;
    background: linear-gradient(90deg, var(--cb-pink), var(--cb-pink-lt));
    transition: width .1s linear;
}

/* ═══════════════════════════════════════════════════════
   BLOG ARCHIVE — PAGE WRAPPER
═══════════════════════════════════════════════════════ */
.coco-blog-page {
    background: #fff;
    min-height: 60vh;
}

/* ═══════════════════════════════════════════════════════
   HERO BANNER
═══════════════════════════════════════════════════════ */
.coco-blog-hero {
    background: var(--cb-pink);
    background: linear-gradient(135deg, #c27778 0%, var(--cb-pink) 50%, #9e4f50 100%);
    color: #fff;
    text-align: center;
    padding: 64px 20px 80px;
    position: relative;
    overflow: hidden;
}
.coco-blog-hero::before {
    content: '';
    position: absolute;
    width: 300px; height: 300px;
    border-radius: 50%;
    background: rgba(255,255,255,.06);
    top: -60px; right: -60px;
    pointer-events: none;
}
.coco-blog-hero::after {
    content: '';
    position: absolute;
    width: 200px; height: 200px;
    border-radius: 50%;
    background: rgba(255,255,255,.05);
    bottom: 20px; left: -40px;
    pointer-events: none;
}
.coco-blog-hero-content { position: relative; z-index: 1; max-width: 600px; margin: 0 auto; }
.coco-blog-hero-eyebrow {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    background: rgba(255,255,255,.18);
    border: 1px solid rgba(255,255,255,.3);
    border-radius: 20px;
    padding: 5px 16px;
    margin-bottom: 16px;
}
.coco-blog-hero-title {
    font-size: clamp(1.8rem, 4vw, 2.8rem);
    font-weight: 800;
    line-height: 1.2;
    margin: 0 0 12px;
    letter-spacing: -.02em;
}
.coco-blog-hero-sub {
    font-size: 1rem;
    opacity: .85;
    line-height: 1.6;
    margin: 0;
}
.coco-blog-hero-wave {
    position: absolute;
    bottom: -1px; left: 0; right: 0;
    line-height: 0;
}
.coco-blog-hero-wave svg {
    display: block;
    width: 100%;
    height: 50px;
}

/* ═══════════════════════════════════════════════════════
   CONTAINER
═══════════════════════════════════════════════════════ */
.coco-blog-container {
    max-width: var(--cb-max-w);
    margin: 0 auto;
    padding: 40px 20px 60px;
}

/* ═══════════════════════════════════════════════════════
   FEATURED POST CARD
═══════════════════════════════════════════════════════ */
.coco-blog-featured {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    border-radius: var(--cb-radius);
    overflow: hidden;
    box-shadow: var(--cb-shadow-lg);
    margin-bottom: 48px;
    background: #fff;
    border: 1px solid var(--cb-border);
}
@media (max-width: 767px) {
    .coco-blog-featured { grid-template-columns: 1fr; }
}
.coco-blog-featured-img-wrap {
    position: relative;
    display: block;
    overflow: hidden;
    aspect-ratio: 4/3;
}
.coco-blog-featured-img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
    display: block;
}
.coco-blog-featured-img-wrap:hover .coco-blog-featured-img {
    transform: scale(1.04);
}
.coco-blog-featured-badge {
    position: absolute;
    top: 14px; left: 14px;
    background: var(--cb-pink);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: 4px 12px;
    border-radius: 20px;
}
.coco-blog-featured-body {
    padding: 36px 40px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 14px;
}
@media (max-width: 767px) {
    .coco-blog-featured-body { padding: 24px 20px; }
}
.coco-blog-featured-title {
    font-size: clamp(1.3rem, 2.5vw, 1.8rem);
    font-weight: 700;
    line-height: 1.3;
    margin: 0;
}
.coco-blog-featured-title a {
    color: var(--cb-text);
    text-decoration: none;
    transition: color .2s;
}
.coco-blog-featured-title a:hover { color: var(--cb-pink); }
.coco-blog-featured-exc {
    font-size: .96rem;
    color: var(--cb-text-muted);
    line-height: 1.65;
    margin: 0;
}
.coco-blog-featured-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 4px;
}

/* ═══════════════════════════════════════════════════════
   META SHARED
═══════════════════════════════════════════════════════ */
.coco-blog-meta-row {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.coco-blog-cat-pill {
    display: inline-block;
    background: var(--cb-cream);
    color: var(--cb-pink);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: 3px 12px;
    border-radius: 20px;
    text-decoration: none;
    border: 1px solid rgba(181,101,102,.2);
    transition: background .2s, color .2s;
}
.coco-blog-cat-pill:hover {
    background: var(--cb-pink);
    color: #fff;
}
.coco-blog-date,
.coco-blog-readtime {
    font-size: 12px;
    color: var(--cb-text-muted);
}
.coco-blog-meta-sep { color: var(--cb-border); font-size: 12px; }

/* Author row */
.coco-blog-author {
    display: flex;
    align-items: center;
    gap: 8px;
}
.coco-author-avatar {
    width: 28px !important;
    height: 28px !important;
    border-radius: 50%;
    object-fit: cover;
}
.coco-author-name {
    font-size: 12px;
    font-weight: 500;
    color: var(--cb-text-muted);
}

/* Read button */
.coco-blog-read-btn {
    display: inline-block;
    background: var(--cb-pink);
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    padding: 10px 22px;
    border-radius: 25px;
    text-decoration: none;
    transition: background .2s, transform .2s;
    white-space: nowrap;
}
.coco-blog-read-btn:hover {
    background: var(--cb-pink-dk);
    color: #fff;
    transform: translateY(-1px);
}

/* ═══════════════════════════════════════════════════════
   FILTER TABS
═══════════════════════════════════════════════════════ */
.coco-blog-filter-wrap {
    margin-bottom: 32px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.coco-blog-filter-wrap::-webkit-scrollbar { display: none; }
.coco-blog-filter-tabs {
    display: flex;
    gap: 8px;
    padding-bottom: 4px;
    white-space: nowrap;
}
.coco-blog-filter-tab {
    display: inline-block;
    padding: 8px 20px;
    border-radius: 25px;
    font-size: 13px;
    font-weight: 500;
    color: var(--cb-text-muted);
    text-decoration: none;
    border: 1.5px solid var(--cb-border);
    background: #fff;
    transition: all .2s;
    flex-shrink: 0;
}
.coco-blog-filter-tab:hover {
    border-color: var(--cb-pink);
    color: var(--cb-pink);
}
.coco-blog-filter-tab.is-active {
    background: var(--cb-pink);
    border-color: var(--cb-pink);
    color: #fff;
}

/* ═══════════════════════════════════════════════════════
   LAYOUT: GRID + SIDEBAR
═══════════════════════════════════════════════════════ */
.coco-blog-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 48px;
    align-items: start;
}
@media (max-width: 1023px) {
    .coco-blog-layout {
        grid-template-columns: 1fr;
    }
    .coco-blog-sidebar { order: 2; }
}
.coco-blog-main { min-width: 0; }

/* ═══════════════════════════════════════════════════════
   POST GRID
═══════════════════════════════════════════════════════ */
.coco-blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}
@media (max-width: 900px) {
    .coco-blog-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
    .coco-blog-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════
   POST CARD  (archive + related)
═══════════════════════════════════════════════════════ */
.coco-post-card {
    background: #fff;
    border-radius: var(--cb-radius);
    overflow: hidden;
    border: 1px solid var(--cb-border);
    display: flex;
    flex-direction: column;
    transition: box-shadow .3s, transform .3s;
}
.coco-post-card:hover {
    box-shadow: var(--cb-shadow-lg);
    transform: translateY(-3px);
}
.coco-post-card-img-wrap {
    position: relative;
    display: block;
    overflow: hidden;
    aspect-ratio: 3/2;
    background: var(--cb-cream);
    flex-shrink: 0;
}
.coco-post-card-img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .4s ease;
}
.coco-post-card-img-wrap:hover .coco-post-card-img {
    transform: scale(1.05);
}
.coco-post-card-no-img {
    width: 100%; height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--cb-cream);
}
.coco-post-card-cat-badge {
    position: absolute;
    bottom: 10px; left: 10px;
    background: var(--cb-pink);
    color: #fff;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: 3px 10px;
    border-radius: 20px;
}
.coco-post-card-body {
    padding: 18px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
}
.coco-post-card-meta {
    display: flex;
    align-items: center;
    gap: 6px;
}
.coco-post-card-title {
    font-size: .96rem;
    font-weight: 600;
    line-height: 1.4;
    margin: 0;
}
.coco-post-card-title a {
    color: var(--cb-text);
    text-decoration: none;
    transition: color .2s;
}
.coco-post-card-title a:hover { color: var(--cb-pink); }
.coco-post-card-exc {
    font-size: .84rem;
    color: var(--cb-text-muted);
    line-height: 1.55;
    margin: 0;
    flex: 1;
}
.coco-post-card-more {
    font-size: .84rem;
    font-weight: 600;
    color: var(--cb-pink);
    text-decoration: none;
    margin-top: auto;
    transition: gap .2s;
}
.coco-post-card-more:hover { color: var(--cb-pink-dk); }

/* ═══════════════════════════════════════════════════════
   PAGINATION
═══════════════════════════════════════════════════════ */
.coco-blog-paging { margin-top: 40px; }
.coco-blog-paging ul {
    display: flex;
    gap: 6px;
    list-style: none;
    margin: 0;
    padding: 0;
    flex-wrap: wrap;
}
.coco-blog-paging ul li a,
.coco-blog-paging ul li span {
    display: 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: 1.5px solid var(--cb-border);
    color: var(--cb-text-muted);
    transition: all .2s;
}
.coco-blog-paging ul li a:hover { border-color: var(--cb-pink); color: var(--cb-pink); }
.coco-blog-paging ul li span.current {
    background: var(--cb-pink);
    border-color: var(--cb-pink);
    color: #fff;
}

/* Empty state */
.coco-blog-empty {
    text-align: center;
    padding: 60px 20px;
    color: var(--cb-text-muted);
    font-size: 1.05rem;
}

/* ═══════════════════════════════════════════════════════
   SIDEBAR
═══════════════════════════════════════════════════════ */
.coco-blog-sidebar {
    position: sticky;
    top: 80px; /* below sticky header */
}
.coco-sidebar { display: flex; flex-direction: column; gap: 24px; }
.coco-sidebar-widget {
    background: #fff;
    border: 1px solid var(--cb-border);
    border-radius: var(--cb-radius);
    padding: 22px 20px;
}
.coco-sidebar-widget-title {
    font-size: .82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--cb-text-muted);
    margin: 0 0 14px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--cb-cream-dk);
}

/* Search */
.coco-sidebar-search {
    display: flex;
    gap: 0;
    border: 1.5px solid var(--cb-border);
    border-radius: 8px;
    overflow: hidden;
}
.coco-sidebar-search-input {
    flex: 1;
    border: none;
    outline: none;
    padding: 9px 12px;
    font-size: 13px;
    background: transparent;
}
.coco-sidebar-search-btn {
    background: var(--cb-pink);
    color: #fff;
    border: none;
    padding: 0 14px;
    cursor: pointer;
    display: flex;
    align-items: center;
    transition: background .2s;
}
.coco-sidebar-search-btn:hover { background: var(--cb-pink-dk); }

/* Newsletter */
.coco-sidebar-newsletter {
    background: var(--cb-cream);
    border-color: rgba(181,101,102,.15);
    position: relative;
    overflow: hidden;
    text-align: center;
}
.coco-sidebar-nl-glow {
    position: absolute;
    top: -40px; right: -40px;
    width: 120px; height: 120px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(181,101,102,.18) 0%, transparent 70%);
    pointer-events: none;
}
.coco-sidebar-nl-title { color: var(--cb-pink) !important; border-color: rgba(181,101,102,.2) !important; }
.coco-sidebar-nl-sub { font-size: 13px; color: var(--cb-text-muted); margin: 0 0 14px; }
.coco-sidebar-nl-form { display: flex; flex-direction: column; gap: 8px; }
.coco-sidebar-nl-input {
    border: 1.5px solid rgba(181,101,102,.25);
    border-radius: 8px;
    padding: 10px 12px;
    font-size: 13px;
    outline: none;
    background: #fff;
    transition: border-color .2s;
}
.coco-sidebar-nl-input:focus { border-color: var(--cb-pink); }
.coco-sidebar-nl-btn {
    background: var(--cb-pink);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 11px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background .2s;
}
.coco-sidebar-nl-btn:hover { background: var(--cb-pink-dk); }
.coco-sidebar-nl-fine { font-size: 10px; color: var(--cb-text-muted); margin: 6px 0 0; }

/* Categories */
.coco-sidebar-cats { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.coco-sidebar-cat-item {}
.coco-sidebar-cat-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 10px;
    border-radius: 8px;
    text-decoration: none;
    font-size: 13px;
    color: var(--cb-text);
    transition: background .15s, color .15s;
}
.coco-sidebar-cat-link:hover { background: var(--cb-cream); color: var(--cb-pink); }
.coco-sidebar-cat-count {
    font-size: 11px;
    background: var(--cb-cream-dk);
    color: var(--cb-pink);
    padding: 1px 7px;
    border-radius: 10px;
    font-weight: 600;
}

/* Recent posts */
.coco-sidebar-recent { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.coco-sidebar-recent-item { display: flex; gap: 12px; align-items: flex-start; }
.coco-sidebar-recent-img-wrap { flex-shrink: 0; }
.coco-sidebar-recent-img {
    width: 56px; height: 56px;
    object-fit: cover;
    border-radius: 8px;
    display: block;
}
.coco-sidebar-recent-info { display: flex; flex-direction: column; gap: 4px; }
.coco-sidebar-recent-title {
    font-size: 13px;
    font-weight: 500;
    color: var(--cb-text);
    text-decoration: none;
    line-height: 1.4;
    transition: color .2s;
}
.coco-sidebar-recent-title:hover { color: var(--cb-pink); }

/* Tags */
.coco-sidebar-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.coco-tag-pill {
    display: inline-block;
    background: var(--cb-cream);
    color: var(--cb-pink);
    font-size: 11px;
    font-weight: 500;
    padding: 4px 12px;
    border-radius: 20px;
    text-decoration: none;
    border: 1px solid rgba(181,101,102,.15);
    transition: background .2s, color .2s;
}
.coco-tag-pill:hover { background: var(--cb-pink); color: #fff; }

/* Shop CTA */
.coco-sidebar-shop-cta {
    text-align: center;
    background: linear-gradient(160deg, var(--cb-cream) 0%, #fde8e8 100%);
    border-color: rgba(181,101,102,.15);
}
.coco-sidebar-shop-img {
    width: 80px; height: auto;
    display: block;
    margin: 0 auto 12px;
    border-radius: 8px;
}
.coco-sidebar-shop-title { font-size: .95rem; font-weight: 700; margin: 0 0 6px; color: var(--cb-text); }
.coco-sidebar-shop-desc { font-size: 12px; color: var(--cb-text-muted); margin: 0 0 14px; line-height: 1.5; }
.coco-sidebar-shop-btn {
    display: inline-block;
    background: var(--cb-pink);
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    padding: 9px 20px;
    border-radius: 20px;
    text-decoration: none;
    transition: background .2s;
}
.coco-sidebar-shop-btn:hover { background: var(--cb-pink-dk); color: #fff; }

/* ═══════════════════════════════════════════════════════
   SINGLE POST
═══════════════════════════════════════════════════════ */
.coco-single-wrap { background: #fff; }
.coco-single-container {
    max-width: var(--cb-max-w);
    margin: 0 auto;
    padding: 32px 20px 60px;
}

/* Breadcrumb */
.coco-breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    font-size: 12px;
    color: var(--cb-text-muted);
    margin-bottom: 20px;
}
.coco-breadcrumb a { color: var(--cb-text-muted); text-decoration: none; transition: color .2s; }
.coco-breadcrumb a:hover { color: var(--cb-pink); }
.coco-breadcrumb span:last-child { color: var(--cb-text); font-weight: 500; }

/* Single header */
.coco-single-header { max-width: var(--cb-content-w); margin: 0 auto 28px; }
.coco-single-meta-top { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
.coco-single-title {
    font-size: clamp(1.6rem, 3.5vw, 2.4rem);
    font-weight: 800;
    line-height: 1.25;
    letter-spacing: -.025em;
    margin: 0 0 20px;
    color: var(--cb-text);
}
.coco-single-byline {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 0;
    border-top: 1px solid var(--cb-border);
    border-bottom: 1px solid var(--cb-border);
    flex-wrap: wrap;
}
.coco-single-byline-info { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.coco-byline-name { font-size: 13px; font-weight: 600; color: var(--cb-text); }
.coco-byline-meta { font-size: 12px; color: var(--cb-text-muted); }
.coco-author-avatar { border-radius: 50%; object-fit: cover; }

/* Share buttons */
.coco-single-share { display: flex; align-items: center; gap: 6px; margin-left: auto; }
.coco-share-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px; height: 32px;
    border-radius: 50%;
    border: 1.5px solid var(--cb-border);
    background: #fff;
    color: var(--cb-text-muted);
    text-decoration: none;
    cursor: pointer;
    transition: all .2s;
}
.coco-share-btn:hover { border-color: var(--cb-pink); color: var(--cb-pink); }

/* Featured image */
.coco-single-thumb {
    max-width: 860px;
    margin: 0 auto 40px;
    border-radius: var(--cb-radius);
    overflow: hidden;
    box-shadow: var(--cb-shadow);
}
.coco-single-thumb-img { width: 100%; height: auto; display: block; }

/* Single layout: content + sidebar */
.coco-single-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 48px;
    align-items: start;
}
@media (max-width: 1023px) {
    .coco-single-layout { grid-template-columns: 1fr; }
    .coco-single-sidebar { order: 2; position: static; }
}

/* Article content typography */
.coco-single-content { min-width: 0; }
.coco-single-body {
    font-size: 1.02rem;
    line-height: 1.8;
    color: var(--cb-text);
    max-width: var(--cb-content-w);
}
.coco-single-body h2 { font-size: 1.5rem; font-weight: 700; margin: 2em 0 .6em; color: var(--cb-text); }
.coco-single-body h3 { font-size: 1.2rem; font-weight: 600; margin: 1.8em 0 .5em; }
.coco-single-body p  { margin: 0 0 1.2em; }
.coco-single-body ul, .coco-single-body ol { margin: 0 0 1.2em 1.4em; }
.coco-single-body li { margin-bottom: .4em; }
.coco-single-body blockquote {
    border-left: 4px solid var(--cb-pink);
    padding: 12px 20px;
    background: var(--cb-cream);
    border-radius: 0 8px 8px 0;
    margin: 1.5em 0;
    font-style: italic;
    color: var(--cb-text-muted);
}
.coco-single-body img { max-width: 100%; border-radius: 8px; margin: .5em 0; }
.coco-single-body a { color: var(--cb-pink); }
.coco-single-body a:hover { color: var(--cb-pink-dk); }

/* Tags */
.coco-single-tags { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; margin: 32px 0; }
.coco-tags-label { font-size: 12px; font-weight: 600; color: var(--cb-text-muted); text-transform: uppercase; letter-spacing: .06em; }

/* Author box */
.coco-author-box {
    display: flex;
    gap: 18px;
    padding: 24px;
    background: var(--cb-cream);
    border-radius: var(--cb-radius);
    margin: 36px 0;
    border: 1px solid rgba(181,101,102,.12);
}
.coco-author-box-avatar { border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.coco-author-box-info { display: flex; flex-direction: column; gap: 6px; }
.coco-author-box-name { font-size: 1rem; font-weight: 700; margin: 0; color: var(--cb-text); }
.coco-author-box-bio  { font-size: .9rem; color: var(--cb-text-muted); margin: 0; line-height: 1.55; }

/* Post nav */
.coco-post-nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin: 36px 0;
    padding-top: 24px;
    border-top: 1px solid var(--cb-border);
}
.coco-post-nav-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 14px 18px;
    border-radius: 10px;
    border: 1.5px solid var(--cb-border);
    text-decoration: none;
    transition: border-color .2s, box-shadow .2s;
}
.coco-post-nav-item:hover { border-color: var(--cb-pink); box-shadow: 0 2px 12px rgba(181,101,102,.1); }
.coco-post-nav-next { text-align: right; }
.coco-post-nav-label { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; color: var(--cb-pink); }
.coco-post-nav-title { font-size: 13px; font-weight: 500; color: var(--cb-text); line-height: 1.4; }
@media (max-width: 520px) {
    .coco-post-nav { grid-template-columns: 1fr; }
    .coco-post-nav-next { text-align: left; }
}

/* ═══════════════════════════════════════════════════════
   RELATED POSTS
═══════════════════════════════════════════════════════ */
.coco-related-posts {
    margin-top: 60px;
    padding-top: 40px;
    border-top: 2px solid var(--cb-cream-dk);
}
.coco-related-title {
    font-size: 1.3rem;
    font-weight: 700;
    margin: 0 0 28px;
    color: var(--cb-text);
}
.coco-related-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
@media (max-width: 767px) { .coco-related-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .coco-related-grid { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════
   COMMENTS (WordPress native override)
═══════════════════════════════════════════════════════ */
.coco-single-comments { margin-top: 40px; padding-top: 32px; border-top: 1px solid var(--cb-border); }
.coco-single-comments .comment-respond { margin-top: 32px; }
.coco-single-comments input[type="text"],
.coco-single-comments input[type="email"],
.coco-single-comments textarea {
    border: 1.5px solid var(--cb-border);
    border-radius: 8px;
    padding: 10px 14px;
    font-size: 14px;
    outline: none;
    width: 100%;
    box-sizing: border-box;
    transition: border-color .2s;
}
.coco-single-comments input:focus,
.coco-single-comments textarea:focus { border-color: var(--cb-pink); }
.coco-single-comments input[type="submit"] {
    background: var(--cb-pink);
    color: #fff;
    border: none;
    border-radius: 25px;
    padding: 11px 28px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: background .2s;
}
.coco-single-comments input[type="submit"]:hover { background: var(--cb-pink-dk); }