﻿/* ============================================
   Article Header & Meta Ξ²β‚¬β€ Standardized
   ============================================ */
.single-article .entry-header {
    padding: 40px 0 24px;
}

.entry-meta-top {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.entry-meta-top .category-badge {
    display: inline-block;
    padding: 4px 12px;
    background: var(--color-primary);
    color: white;
    font-family: var(--font-body);
    font-size: var(--font-size-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-caps);
    border-radius: 3px;
    text-decoration: none;
}

.entry-meta-top .category-badge:hover {
    background: var(--color-primary-dark);
    color: white;
}

.entry-meta-top .reading-time {
    font-family: var(--font-body);
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-caps);
}

.single-article .entry-title {
    font-family: var(--font-heading);
    font-size: var(--font-size-3xl);
    font-weight: 800;
    line-height: var(--line-height-heading);
    letter-spacing: var(--letter-spacing-tight);
    color: var(--color-text-headline);
    margin: 0 0 16px;
}

.entry-excerpt {
    font-family: var(--font-body);
    font-size: var(--font-size-lg);
    line-height: 1.6;
    color: var(--color-text-muted);
    margin: 0 0 20px;
}

.entry-meta {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    font-family: var(--font-body);
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    padding-top: 16px;
    border-top: 1px solid var(--color-border);
}

.entry-meta .entry-author a {
    color: var(--color-text-headline);
    font-weight: 600;
    text-decoration: none;
}

.entry-meta .entry-author a:hover {
    color: var(--color-primary);
}

.entry-meta .entry-updated {
    color: var(--color-primary);
    font-weight: 600;
}

.entry-thumbnail {
    float: left;
    width: 25%;
    max-width: 300px;
    margin: 0 24px 16px 0;
}

.entry-thumbnail img {
    width: 100%;
    height: auto;
    border-radius: var(--card-radius);
    display: block;
    object-fit: cover;
}

/* Clear float before product-pick sections and major headings */
.entry-content .product-pick-section,
.entry-content .pros-cons-grid,
.entry-content .who-its-for {
    clear: both;
}

/* Clearfix for entry-content */
.entry-content::after {
    content: '';
    display: table;
    clear: both;
}

.entry-footer {
    margin-top: 40px;
    padding-top: 24px;
    border-top: 1px solid var(--color-border);
}

.entry-tags {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    font-family: var(--font-body);
    font-size: var(--font-size-sm);
}

.entry-tags .tags-label {
    font-weight: 600;
    color: var(--color-text-muted);
}

.entry-tags a {
    display: inline-block;
    padding: 4px 10px;
    background: var(--color-bg-alt);
    color: var(--color-text-body);
    border-radius: 3px;
    text-decoration: none;
    font-size: var(--font-size-xs);
    transition: all var(--transition-fast);
}

.entry-tags a:hover {
    background: var(--color-primary);
    color: white;
}

/* Related posts */
.related-posts {
    margin: 48px 0 0;
    padding-top: 40px;
    border-top: 2px solid var(--color-border);
}

.related-title {
    font-family: var(--font-heading);
    font-size: var(--font-size-xl);
    font-weight: 700;
    color: var(--color-text-headline);
    margin: 0 0 24px;
}

.related-card-horizontal {
    margin-bottom: 12px;
}

.related-card-link {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 12px;
    border-radius: var(--card-radius);
    text-decoration: none;
    transition: background var(--transition-fast);
}

.related-card-link:hover {
    background: var(--color-bg-alt);
}

.related-card-image {
    flex-shrink: 0;
    width: 80px;
    height: 56px;
    border-radius: 4px;
    overflow: hidden;
}

.related-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.related-card-placeholder {
    background: var(--color-bg-alt);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
}

.related-card-title {
    font-family: var(--font-heading);
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--color-text-headline);
    margin: 0 0 4px;
    line-height: 1.4;
}

.related-card-date {
    font-family: var(--font-body);
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

@media (max-width: 768px) {
    .single-article .entry-title {
        font-size: var(--font-size-2xl);
    }

    .single-article .entry-header {
        padding: 24px 0 16px;
    }

    .entry-meta {
        gap: 10px;
    }

    .entry-thumbnail {
        float: none;
        width: 100%;
        max-width: none;
        margin: 0 0 20px;
    }
}

/* ============================================
   Article Content Ξ²β‚¬β€ Standardized Layout
   These rules enforce uniform typography, spacing,
   and component rendering regardless of GPT output.
   ============================================ */
.entry-content {
    font-family: var(--font-body);
    font-size: var(--font-size-md);
    line-height: 1.75;
    letter-spacing: var(--letter-spacing-normal);
    color: var(--color-text-body);
}

.entry-content p {
    margin: 0 0 1.25em;
}

.entry-content h2 {
    font-family: var(--font-heading);
    font-size: var(--font-size-2xl);
    font-weight: 800;
    line-height: var(--line-height-heading);
    color: var(--color-text-headline);
    margin: 2.5em 0 0.75em;
    padding-top: 1.25em;
    border-top: 2px solid var(--color-border);
    letter-spacing: var(--letter-spacing-tight);
}

/* First h2 in content Ξ²β‚¬β€ no border above */
.entry-content > h2:first-child,
.entry-content > .product-pick-section:first-child > h2 {
    border-top: none;
    padding-top: 0;
    margin-top: 0;
}

.entry-content h3 {
    font-family: var(--font-heading);
    font-size: var(--font-size-xl);
    font-weight: 700;
    line-height: var(--line-height-heading);
    color: var(--color-text-headline);
    margin: 1.75em 0 0.5em;
}

.entry-content h4 {
    font-family: var(--font-heading);
    font-size: var(--font-size-lg);
    font-weight: 700;
    line-height: var(--line-height-heading);
    color: var(--color-text-headline);
    margin: 1.5em 0 0.5em;
}

.entry-content ul,
.entry-content ol {
    margin: 0 0 1.5em 1.5em;
    padding: 0;
}

.entry-content li {
    margin-bottom: 0.5em;
    line-height: 1.65;
}

.entry-content ol {
    list-style: decimal;
}

.entry-content ol li::marker {
    font-weight: 700;
    color: var(--color-primary);
}

.entry-content blockquote {
    margin: 2em 0;
    padding: 20px 24px;
    background: var(--color-bg-alt);
    border-left: 4px solid var(--color-primary);
    font-style: italic;
    font-size: var(--font-size-md);
    color: var(--color-text-body);
}

.entry-content blockquote p:last-child {
    margin-bottom: 0;
}

.entry-content img {
    max-width: 100%;
    height: auto;
    border-radius: var(--card-radius);
}

/* Tables inside article content */
.entry-content table {
    width: 100%;
    border-collapse: collapse;
    margin: 1.5em 0;
    font-size: var(--font-size-base);
}

.entry-content th {
    background: var(--color-bg-alt);
    font-family: var(--font-heading);
    font-weight: 700;
    color: var(--color-text-headline);
    text-align: left;
    padding: 10px 14px;
    border-bottom: 2px solid var(--color-border);
}

.entry-content td {
    padding: 10px 14px;
    border-bottom: 1px solid var(--color-border);
    color: var(--color-text-body);
    vertical-align: top;
}

.entry-content tr:last-child td {
    border-bottom: none;
}

/* Inline product verdict links */
.product-verdict-link {
    color: var(--color-primary);
    text-decoration: none;
    border-bottom: 2px solid rgba(243, 146, 0, 0.3);
    transition: border-color var(--transition-fast), color var(--transition-fast);
}

.product-verdict-link:hover {
    color: var(--color-primary-dark);
    border-bottom-color: var(--color-primary);
}

.product-verdict-link strong {
    font-weight: 700;
    color: inherit;
}

/* ============================================
   Pros & Cons Ξ²β‚¬β€ Two-Column Grid
   ============================================ */
.pros-cons-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin: 20px 0 24px;
}

@media (max-width: 640px) {
    .pros-cons-grid {
        grid-template-columns: 1fr;
    }
}

.pros,
.cons {
    padding: 16px 20px;
    border-radius: var(--card-radius);
}

.pros {
    background: rgba(39, 174, 96, 0.06);
    border: 1px solid rgba(39, 174, 96, 0.2);
}

.cons {
    background: rgba(231, 76, 60, 0.06);
    border: 1px solid rgba(231, 76, 60, 0.2);
}

.pros-label strong,
.cons-label strong {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-caps);
    margin-bottom: 4px;
}

.pros-label strong {
    color: var(--color-pros);
}

.cons-label strong {
    color: var(--color-cons);
}

.pros ul,
.cons ul {
    margin: 8px 0 0;
    padding-left: 18px;
    list-style: none;
}

.pros li,
.cons li {
    position: relative;
    padding-left: 6px;
    margin-bottom: 6px;
    font-size: var(--font-size-base);
    line-height: 1.5;
}

.pros li::before {
    content: '\2713';
    position: absolute;
    left: -18px;
    color: var(--color-pros-icon);
    font-weight: 700;
}

.cons li::before {
    content: '\2717';
    position: absolute;
    left: -18px;
    color: var(--color-cons-icon);
    font-weight: 700;
}

/* ============================================
   "Who It's For" Callout
   ============================================ */
.who-its-for {
    margin: 16px 0 20px;
    padding: 14px 20px;
    background: var(--color-bg-alt);
    border-left: 4px solid var(--color-secondary);
    border-radius: 0 var(--card-radius) var(--card-radius) 0;
    font-size: var(--font-size-base);
    line-height: 1.6;
    color: var(--color-text-body);
}

.who-its-for .who-label {
    font-weight: 700;
    color: var(--color-secondary);
}

/* ============================================
   Product Pick Sections - Colorful Labels
   ============================================ */
/* Product Pick Section Container */
.product-pick-section {
    margin: 32px 0 24px;
    padding: 20px 24px;
    border-radius: var(--card-radius);
    border-left: 5px solid;
}

/* Pick label (Our Pick: / Runner-Up: / Budget Pick:) never wraps */
.product-pick-section .pick-label {
    white-space: nowrap;
    flex-shrink: 0;    /* never compress the label */
}

/* The h2 heading wraps gracefully: label stays on one line, product name flows */
.product-pick-section > h2,
.product-pick-section > h3 {
    flex-wrap: wrap;   /* let product name wrap to next line if needed */
}

/* Our Pick - Premium Blue */
.product-pick-section.our-pick {
    background: linear-gradient(135deg, rgba(243, 146, 0, 0.08) 0%, rgba(243, 146, 0, 0.04) 100%);
    border-left-color: var(--color-primary);
}

.product-pick-section.our-pick > h3,
.product-pick-section.our-pick > h2 {
    color: #8B5A00; /* Darker orange for label */
    margin-top: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 800;
}

/* Product name after colon should be lighter */
.product-pick-section.our-pick > h3 .product-name,
.product-pick-section.our-pick > h2 .product-name {
    color: var(--color-primary);
    font-weight: 600;
}

.product-pick-section.our-pick > h3::before,
.product-pick-section.our-pick > h2::before {
    content: 'π†';
}

/* Runner-Up - Secondary Gold */
.product-pick-section.runner-up {
    background: linear-gradient(135deg, rgba(247, 147, 30, 0.08) 0%, rgba(247, 147, 30, 0.04) 100%);
    border-left-color: var(--color-secondary);
}

.product-pick-section.runner-up > h3,
.product-pick-section.runner-up > h2 {
    color: #b36b00; /* Darker orange/gold for label */
    margin-top: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 800;
}

/* Product name after colon should be lighter */
.product-pick-section.runner-up > h3 .product-name,
.product-pick-section.runner-up > h2 .product-name {
    color: var(--color-secondary);
    font-weight: 600;
}

.product-pick-section.runner-up > h3::before,
.product-pick-section.runner-up > h2::before {
    content: 'π¥';
}

/* Budget Pick - Green */
.product-pick-section.budget-pick {
    background: linear-gradient(135deg, rgba(76, 175, 80, 0.08) 0%, rgba(76, 175, 80, 0.04) 100%);
    border-left-color: #4CAF50;
}

.product-pick-section.budget-pick > h3,
.product-pick-section.budget-pick > h2 {
    color: #1b5e20; /* Darker green for label */
    margin-top: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 800;
}

/* Product name after colon should be lighter */
.product-pick-section.budget-pick > h3 .product-name,
.product-pick-section.budget-pick > h2 .product-name {
    color: #2E7D32;
    font-weight: 600;
}

.product-pick-section.budget-pick > h3::before,
.product-pick-section.budget-pick > h2::before {
    content: 'π’°';
}

/* How We Tested - Teal/Info */
.product-pick-section.how-tested {
    background: linear-gradient(135deg, rgba(0, 150, 136, 0.08) 0%, rgba(0, 150, 136, 0.04) 100%);
    border-left-color: #00796B;
}

.product-pick-section.how-tested > h3,
.product-pick-section.how-tested > h2 {
    color: #00796B;
    margin-top: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.product-pick-section.how-tested > h3::before,
.product-pick-section.how-tested > h2::before {
    content: 'π”¬';
}

/* What to Look For - Purple */
.product-pick-section.what-to-look {
    background: linear-gradient(135deg, rgba(156, 39, 176, 0.08) 0%, rgba(156, 39, 176, 0.04) 100%);
    border-left-color: #7B1FA2;
}

.product-pick-section.what-to-look > h3,
.product-pick-section.what-to-look > h2 {
    color: #7B1FA2;
    margin-top: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.product-pick-section.what-to-look > h3::before,
.product-pick-section.what-to-look > h2::before {
    content: 'π‘€';
}

/* Quick Verdict - Dark teal */
.product-pick-section.quick-verdict {
    background: linear-gradient(135deg, rgba(30, 30, 30, 0.05) 0%, rgba(30, 30, 30, 0.02) 100%);
    border-left-color: #333;
}

.product-pick-section.quick-verdict > h3,
.product-pick-section.quick-verdict > h2 {
    color: #1A1A2E;
    margin-top: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.product-pick-section.quick-verdict > h3::before,
.product-pick-section.quick-verdict > h2::before {
    content: 'β΅';
}

/* Pros & Cons styling (inside product-pick-section) */
.product-pick-section .pros-cons-grid {
    margin: 16px 0 20px;
}

.product-pick-section .pros,
.product-pick-section .cons {
    background: rgba(255, 255, 255, 0.6);
}

.product-pick-section .who-its-for {
    background: rgba(255, 255, 255, 0.5);
}

/* Product cards inside colored sections */
.product-pick-section [class*="geo-product"],
.product-pick-section .wp-block-shortcode,
.product-pick-section .product-card {
    margin-top: 24px;
    margin-bottom: 8px;
    border-radius: var(--card-radius);
}

/* Mobile responsive for product pick sections */
@media (max-width: 768px) {
    .product-pick-section {
        margin: 24px 0 18px;
        padding: 16px 18px;
    }
    
    .product-pick-section > h3,
    .product-pick-section > h2 {
        font-size: 1.25rem;
    }

    .product-pick-section > h2 .product-name {
        display: none;
    }

    .product-pick-section > h2 .pick-colon {
        display: none;
    }
}

/* ============================================
   Buttons - Global Standard
   ============================================ */
.button,
.btn,
button,
input[type="submit"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: var(--touch-target);
    padding: 12px 24px;
    font-family: var(--font-body);
    font-size: var(--font-size-sm);
    font-weight: 600;
    line-height: 1.4;
    text-decoration: none;
    border: 2px solid transparent;
    border-radius: var(--card-radius);
    cursor: pointer;
    transition: all var(--transition-base);
}

.button-primary,
.btn-primary {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: white;
}

.button-primary:hover,
.btn-primary:hover {
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
    color: white;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(243, 146, 0, 0.3);
}

.button-secondary,
.btn-secondary {
    background: var(--color-secondary);
    border-color: var(--color-secondary);
    color: white;
}

.button-secondary:hover,
.btn-secondary:hover {
    background: var(--color-secondary-dark);
    border-color: var(--color-secondary-dark);
    color: white;
    transform: translateY(-1px);
}

.button-outline,
.btn-outline {
    background: transparent;
    border: 2px solid var(--color-border);
    color: var(--color-text-body);
}

.button-outline:hover,
.btn-outline:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}

/* Read More link - unified style across all templates */
.read-more-link,
.post-item-link,
.archive-item-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-primary);
    text-decoration: none;
    transition: color var(--transition-base), gap var(--transition-base);
    white-space: nowrap;
}

.read-more-link:hover,
.post-item-link:hover,
.archive-item-link:hover {
    color: var(--color-primary-dark);
    gap: 8px;
}

/* Mobile: ensure all interactive elements meet 44px touch target */
@media (max-width: 768px) {
    .button,
    .btn,
    button,
    input[type="submit"],
    .read-more-link,
    .post-item-link,
    .archive-item-link {
        min-height: var(--touch-target);
    }
}

/* ============================================
   Internal Links & Recommendations
   ============================================ */
.auto-internal-link {
    color: var(--color-secondary);
    text-decoration: underline;
    text-decoration-color: var(--color-primary);
    text-underline-offset: 2px;
    transition: color var(--transition-fast);
}

.auto-internal-link:hover {
    color: var(--color-primary);
}

.inline-recommendations {
    margin: 32px 0;
    padding: 20px 24px;
    background: var(--color-bg-alt);
    border-left: 3px solid var(--color-primary);
    border-radius: 0 var(--card-radius) var(--card-radius) 0;
}

.inline-rec-label {
    font-family: var(--font-body);
    font-size: var(--font-size-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-caps);
    color: var(--color-text-muted);
    margin: 0 0 12px;
}

.inline-rec-link {
    display: block;
    font-family: var(--font-heading);
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--color-secondary);
    text-decoration: none;
    padding: 6px 0;
    transition: color var(--transition-fast);
}

.inline-rec-link:hover {
    color: var(--color-primary);
}

.inline-rec-link + .inline-rec-link {
    border-top: 1px solid var(--color-border);
    margin-top: 6px;
    padding-top: 12px;
}

