/**
 * News Category Widget - Signature Theme
 * Primary Color: #F56011 (Orange)
 *
 * Styles for news category sections with featured post and grid layout
 */

/* ==========================================================================
   News Category Section Layout
   ========================================================================== */

.news-category-section {
    padding: var(--spacing-6, 32px) 0;
    background: var(--color-bg-white);
}

.news-category-header {
    max-width: var(--container-max-width, 1440px);
    margin: 0 auto var(--spacing-6, 24px);
    padding-bottom: var(--spacing-3, 12px);
    border-bottom: 2px solid #F56011;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-5, 20px);
}

.news-category-title {
    font-family: var(--font-primary);
    font-size: var(--font-size-24, 24px);
    font-weight: var(--font-weight-bold, 700);
    color: var(--color-text-primary, #3D3D3D);
    margin: 0;
    line-height: var(--line-height-tight, 1.2);
}

.news-category-meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-3, 12px);
    font-family: var(--font-primary);
    font-size: var(--font-size-14, 14px);
    color: var(--color-text-light, #888888);
}

.news-category-count {
    font-weight: var(--font-weight-medium, 500);
    color: #F56011;
}

.news-category-date {
    font-weight: var(--font-weight-regular, 400);
}

.news-category-view-all {
    display: flex;
    align-items: center;
    gap: var(--spacing-2, 8px);
    font-family: var(--font-primary);
    font-size: var(--font-size-14, 14px);
    font-weight: var(--font-weight-medium, 500);
    color: #F56011;
    text-decoration: none;
    padding: var(--spacing-2, 8px) var(--spacing-3, 12px);
    border: 1px solid #F56011;
    border-radius: var(--radius-button, 24px);
    transition: all var(--transition-fast, 0.15s ease);
}

.news-category-view-all:hover {
    background: #F56011;
    color: var(--color-white);
}

.news-category-arrow {
    transition: transform var(--transition-fast, 0.15s ease);
}

.news-category-view-all:hover .news-category-arrow {
    transform: translateX(4px);
}

/* ==========================================================================
   News Category Content Layout
   ========================================================================== */

.news-category-content {
    max-width: var(--container-max-width, 1440px);
    margin: 0 auto var(--spacing-6, 24px);
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: var(--spacing-6, 32px);
}

/* ==========================================================================
   News Category Featured Post
   ========================================================================== */

.news-category-featured-post {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3, 12px);
    margin-bottom: var(--spacing-4, 16px);
}

.news-category-featured-image {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-md, 8px);
    aspect-ratio: 400/280;
}

.news-category-featured-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-normal, 0.3s ease);
}

.news-category-featured-image:hover img {
    transform: scale(1.05);
}

.news-category-featured-content {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2, 8px);
}

.news-category-featured-title {
    font-family: var(--font-primary);
    font-size: var(--font-size-20, 20px);
    font-weight: var(--font-weight-semibold, 600);
    line-height: var(--line-height-normal, 1.5);
    margin: 0;
}

.news-category-featured-link {
    color: var(--color-text-primary, #3D3D3D);
    text-decoration: none;
    transition: color var(--transition-fast, 0.15s ease);
}

.news-category-featured-link:hover {
    color: #F56011;
}

.news-category-featured-excerpt {
    font-family: var(--font-primary);
    font-size: var(--font-size-14, 14px);
    line-height: var(--line-height-normal, 1.5);
    color: var(--color-text-light, #888888);
    margin: 0;
}

.news-category-featured-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-2, 8px);
    align-items: center;
}

.news-category-featured-date {
    font-family: var(--font-primary);
    font-size: var(--font-size-12, 12px);
    color: var(--color-text-light, #888888);
    font-weight: var(--font-weight-regular, 400);
}

.news-category-featured-author {
    font-family: var(--font-primary);
    font-size: var(--font-size-12, 12px);
    color: var(--color-text-light, #888888);
    font-weight: var(--font-weight-medium, 500);
}

/* ==========================================================================
   Featured Post (Large Article)
   ========================================================================== */

.news-category-featured {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3, 12px);
}

.news-category-featured-link {
    text-decoration: none;
    color: inherit;
}

.news-category-featured-image {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-md, 8px);
    aspect-ratio: 342/298;
}

.news-category-featured-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-normal, 0.3s ease);
}

.news-category-featured-link:hover .news-category-featured-img {
    transform: scale(1.05);
}

.news-category-featured-content {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2, 8px);
    flex: 1;
}

.news-category-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-3, 12px);
    align-items: center;
}

.news-category-date {
    font-family: var(--font-primary);
    font-size: var(--font-size-14, 14px);
    color: var(--color-text-light, #888888);
    font-weight: var(--font-weight-regular, 400);
}

.news-category-tag {
    font-family: var(--font-primary);
    font-size: var(--font-size-12, 12px);
    font-weight: var(--font-weight-semibold, 600);
    color: #F56011;
    text-decoration: none;
    padding: 4px 8px;
    background: rgba(245, 96, 17, 0.1);
    border-radius: var(--radius-sm, 4px);
    transition: all var(--transition-fast, 0.15s ease);
}

.news-category-tag:hover {
    background: #F56011;
    color: var(--color-white);
}

.news-category-featured-heading {
    font-family: var(--font-primary);
    font-size: var(--font-size-20, 20px);
    font-weight: var(--font-weight-semibold, 600);
    line-height: var(--line-height-normal, 1.5);
    margin: 0;
}

.news-category-featured-heading a {
    color: var(--color-text-primary, #3D3D3D);
    text-decoration: none;
    transition: color var(--transition-fast, 0.15s ease);
}

.news-category-featured-heading a:hover {
    color: #F56011;
}

.news-category-featured-summary {
    font-family: var(--font-primary);
    font-size: var(--font-size-14, 14px);
    line-height: var(--line-height-normal, 1.5);
    color: var(--color-text-light, #888888);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ==========================================================================
   News Category Grid
   ========================================================================== */

.news-category-posts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--spacing-4, 16px);
}

.news-category-post-card {
    display: flex;
    gap: var(--spacing-3, 12px);
    align-items: flex-start;
    padding: var(--spacing-3, 12px);
    border: 1px solid var(--color-border-light, #F0F0F0);
    border-radius: var(--radius-md, 8px);
    transition: all var(--transition-fast, 0.15s ease);
}

.news-category-post-card:hover {
    border-color: #F56011;
    box-shadow: 0 4px 12px rgba(245, 96, 17, 0.08);
}

.news-category-post-link {
    text-decoration: none;
    color: inherit;
    display: flex;
    gap: var(--spacing-3, 12px);
    align-items: flex-start;
}

.news-category-post-image {
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-sm, 4px);
    aspect-ratio: 200/140;
    width: 200px;
    height: 140px;
}

.news-category-post-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-fast, 0.15s ease);
}

.news-category-post-link:hover .news-category-post-image img {
    transform: scale(1.05);
}

.news-category-post-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2, 8px);
    min-width: 0;
}

.news-category-post-title {
    font-family: var(--font-primary);
    font-size: var(--font-size-14, 14px);
    font-weight: var(--font-weight-medium, 500);
    line-height: var(--line-height-normal, 1.5);
    margin: 0;
}

.news-category-post-link {
    color: var(--color-text-primary, #3D3D3D);
    text-decoration: none;
    transition: color var(--transition-fast, 0.15s ease);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.news-category-post-link:hover {
    color: #F56011;
}

.news-category-post-meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-2, 8px);
}

.news-category-post-date {
    font-family: var(--font-primary);
    font-size: var(--font-size-12, 12px);
    color: var(--color-text-light, #888888);
    font-weight: var(--font-weight-regular, 400);
}

/* ==========================================================================
   News Category Footer
   ========================================================================== */

.news-category-footer {
    text-align: center;
    padding-top: var(--spacing-5, 20px);
    border-top: 1px solid var(--color-border-light, #F0F0F0);
    margin-top: var(--spacing-5, 20px);
}

.news-category-more-link {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-2, 8px);
    font-family: var(--font-primary);
    font-size: var(--font-size-14, 14px);
    font-weight: var(--font-weight-medium, 500);
    color: #F56011;
    text-decoration: none;
    padding: var(--spacing-3, 12px) var(--spacing-4, 16px);
    border: 1px solid #F56011;
    border-radius: var(--radius-button, 24px);
    transition: all var(--transition-fast, 0.15s ease);
}

.news-category-more-link:hover {
    background: #F56011;
    color: var(--color-white);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(245, 96, 17, 0.2);
}

.news-category-more-arrow {
    font-size: var(--font-size-16, 16px);
    transition: transform var(--transition-fast, 0.15s ease);
}

.news-category-more-link:hover .news-category-more-arrow {
    transform: translateX(4px);
}

/* ==========================================================================
   News Category Empty State
   ========================================================================== */

.news-category-empty {
    text-align: center;
    padding: var(--spacing-8, 32px);
    color: var(--color-text-light, #888888);
    font-family: var(--font-primary);
    font-size: var(--font-size-16, 16px);
}

/* ==========================================================================
   Responsive Design - Mobile First
   ========================================================================== */

/* Tablet (768px and up) */
@media (min-width: 768px) {
    .news-category-section {
        padding: var(--spacing-10, 40px) 0;
    }

    .news-category-container {
        padding: 0 var(--spacing-5, 20px);
    }

    .news-category-title {
        font-size: var(--font-size-28, 28px);
    }
}

/* Desktop (1024px and up) */
@media (min-width: 1024px) {
    .news-category-container {
        padding: 0 var(--spacing-6, 24px);
    }

    .news-category-title {
        font-size: var(--font-size-32, 32px);
    }
}

/* Large Desktop (1280px and up) */
@media (min-width: 1280px) {
    .news-category-container {
        padding: 0 var(--spacing-7, 28px);
    }
}

/* Ultra Wide (1440px and up) */
@media (min-width: 1440px) {
    .news-category-container {
        padding: 0 var(--spacing-8, 32px);
    }
}