/* ==========================================================================
   News Highlight Widget - Signature Theme
   ========================================================================== */

/* ==========================================================================
   Container
   ========================================================================== */

.news-highlight-section {
    padding: var(--spacing-8, 32px) 0;
    background: var(--color-bg-white, #FFFFFF);
}

.news-highlight-container {
    max-width: var(--container-max-width, 1440px);
    margin: 0 auto;
    padding: 0 var(--spacing-6, 24px);
}

/* ==========================================================================
   Header
   ========================================================================== */

.news-highlight-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-5, 20px);
    padding-bottom: var(--spacing-3, 12px);
    border-bottom: 2px solid var(--color-primary, #F56011);
}

.news-highlight-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-highlight-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);
    font-weight: var(--font-weight-medium, 500);
}

.news-highlight-view-all {
    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: var(--color-primary, #F56011);
    text-decoration: none;
    padding: var(--spacing-2, 8px) var(--spacing-3, 12px);
    border: 1px solid var(--color-primary, #F56011);
    border-radius: var(--radius-button, 24px);
    transition: all var(--transition-fast, 0.15s ease);
}

.news-highlight-view-all:hover {
    background: var(--color-primary, #F56011);
    color: var(--color-white);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(245, 96, 17, 0.08);
}

.news-highlight-arrow {
    display: inline-block;
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid currentColor;
    margin-left: var(--spacing-1, 4px);
    transition: transform var(--transition-fast, 0.15s ease);
}

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

/* ==========================================================================
   Featured Article
   ========================================================================== */

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

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

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

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

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

.news-highlight-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-highlight-featured-link {
    text-decoration: none;
    color: var(--color-text-primary, #3D3D3D);
}

.news-highlight-featured-link:hover {
    color: var(--color-primary, #F56011);
}

.news-highlight-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;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.news-highlight-featured-meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-3, 12px);
    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);
}

.news-highlight-featured-author {
    font-weight: var(--font-weight-medium, 500);
    color: var(--color-text-light, #888888);
}

.news-highlight-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);
}

/* ==========================================================================
   Side Articles Grid
   ========================================================================== */

.news-highlight-side-articles {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-4, 16px);
}

.news-highlight-side-article {
    display: flex;
    gap: var(--spacing-3, 12px);
    padding: var(--spacing-3, 12px);
    border: 1px solid var(--color-border-light, #E7E7E7);
    border-radius: var(--radius-md, 8px);
    transition: all var(--transition-fast, 0.15s ease);
}

.news-highlight-side-article:hover {
    border-color: var(--color-primary, #F56011);
    box-shadow: 0 4px 12px rgba(245, 96, 17, 0.08);
    transform: translateY(-2px);
}

.news-highlight-side-article-image {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-sm, 4px);
    aspect-ratio: 16/9;
    width: 120px;
    height: 80px;
}

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

.news-highlight-side-article-image:hover img {
    transform: scale(1.05);
}

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

.news-highlight-side-article-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-highlight-side-article-link {
    color: var(--color-text-primary, #3D3D3D);
    text-decoration: none;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.news-highlight-side-article-link:hover {
    color: var(--color-primary, #F56011);
}

.news-highlight-side-article-meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-2, 8px);
    font-family: var(--font-primary);
    font-size: var(--font-size-11, 11px);
    color: var(--color-text-light, #888888);
    font-weight: var(--font-weight-regular, 400);
}

.news-highlight-side-article-author {
    font-weight: var(--font-weight-medium, 500);
    color: var(--color-text-light, #888888);
}

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

/* ==========================================================================
   Empty State
   ========================================================================== */

.news-highlight-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-highlight-container {
        padding: 0 var(--spacing-5, 20px);
    }
}

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

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

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

/* Mobile adjustments */
@media (max-width: 767px) {
    .news-highlight-section {
        padding: var(--spacing-6, 32px) 0;
    }

    .news-highlight-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-2, 8px);
    }

    .news-highlight-title {
        font-size: var(--font-size-20, 20px);
    }

    .news-highlight-container {
        padding: 0 var(--spacing-4, 16px);
    }

    .news-highlight-content {
        grid-template-columns: 1fr;
    }

    .news-highlight-featured {
        flex-direction: column;
    }

    .news-highlight-side-articles {
        display: grid;
        grid-template-columns: 1fr;
        gap: var(--spacing-3, 12px);
    }
}

@media (max-width: 375px) {
    .news-highlight-header {
        padding-bottom: var(--spacing-4, 16px);
    }

    .news-highlight-title {
        font-size: var(--font-size-18, 18px);
    }
}

/* ==========================================================================
   Accessibility
   ========================================================================== */

.news-highlight-section:focus-within {
    outline: 2px solid var(--color-primary, #F56011);
    outline-offset: 2px;
}

.news-highlight-view-all:focus-visible {
    outline: 2px solid var(--color-primary, #F56011);
    outline-offset: 2px;
    border-radius: var(--radius-button, 24px);
}

/* Skip link for accessibility */
.news-highlight-skip-link {
    position: absolute;
    top: -40px;
    left: 0;
    background: var(--color-primary, #F56011);
    color: var(--color-white);
    padding: 8px 16px;
    text-decoration: none;
    font-weight: var(--font-weight-medium, 500);
    border-radius: var(--radius-button, 24px);
    transition: top var(--transition-fast, 0.15s ease);
}

.news-highlight-skip-link:focus {
    top: 0;
}