/*
 * Homepage Styles - Famoid Blogger Theme
 * Centralized styles for homepage/blog listing pages
 */

/* ==========================================================================
   Hero Section - Featured Post
   ========================================================================== */

.hero-section {
    padding: var(--space-8) 0 var(--space-12);
    background-color: var(--color-bg);
    width: 100%;
}

.hero-section .container {
    max-width: var(--container-xl);
}

.hero-post {
    display: grid;
    gap: var(--space-8);
    align-items: center;
    width: 100%;
}

@media (min-width: 1024px) {
    .hero-post {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-10);
    }
}

.hero-post__image-link {
    display: block;
    text-decoration: none;
}

.hero-post__image {
    position: relative;
    aspect-ratio: 16 / 10;
    border-radius: var(--radius-xl);
    overflow: hidden;
    background-color: var(--color-bg-secondary);
}

.hero-post__image img {
    width: 100%;
    height: 100%;
    object-fit: fill;
    transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.hero-post__image-link:hover .hero-post__image img {
    transform: scale(1.03);
}

.hero-post__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.1) 100%);
    pointer-events: none;
}

.hero-post__content {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.hero-post__category {
    display: inline-flex;
    align-self: flex-start;
    padding: var(--space-2) var(--space-4);
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
    color: var(--color-accent);
    background-color: var(--color-accent-light);
    border-radius: var(--radius-full);
    text-decoration: none;
    transition: var(--transition-fast);
}

.hero-post__category:hover {
    background-color: var(--color-accent);
    color: #ffffff;
}

.hero-post__title {
    font-family: var(--font-heading);
    font-size: var(--text-3xl);
    font-weight: var(--font-bold);
    line-height: var(--leading-tight);
    margin: 0;
}

@media (min-width: 768px) {
    .hero-post__title {
        font-size: var(--text-4xl);
    }
}

@media (min-width: 1024px) {
    .hero-post__title {
        font-size: clamp(2rem, 3vw, 2.75rem);
    }
}

.hero-post__title a {
    color: var(--color-text);
    text-decoration: none;
    transition: var(--transition-fast);
}

.hero-post__title a:hover {
    color: var(--color-accent);
}

.hero-post__excerpt {
    font-family: var(--font-body);
    font-size: var(--text-lg);
    line-height: var(--leading-relaxed);
    color: var(--color-text-secondary);
    margin: 0;
}

.hero-post__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    margin-top: var(--space-4);
    padding-top: var(--space-6);
    border-top: 1px solid var(--color-border-light);
}

.hero-post__author {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    text-decoration: none;
}

.hero-post__avatar {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-full);
    border: 2px solid var(--color-bg);
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.hero-post__author-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.hero-post__author-name {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-text);
    transition: var(--transition-fast);
}

.hero-post__author:hover .hero-post__author-name {
    color: var(--color-accent);
}

.hero-post__date {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    color: var(--color-text-tertiary);
}

.hero-post__separator {
    opacity: 0.5;
}

.hero-post__read-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-5);
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: #ffffff;
    background-color: var(--color-accent);
    border-radius: var(--radius-md);
    text-decoration: none;
    transition: var(--transition-fast);
}

.hero-post__read-btn:hover {
    background-color: var(--color-accent-hover);
    color: #ffffff;
    transform: translateY(-1px);
}

.hero-post__read-btn svg {
    transition: transform var(--transition-fast);
}

.hero-post__read-btn:hover svg {
    transform: translateX(3px);
}

/* ==========================================================================
   Blog Section - Post Grid
   ========================================================================== */

.blog-section {
    padding: var(--space-12) 0 var(--space-16);
    background-color: var(--color-bg-secondary);
    width: 100%;
}

.blog-section .container {
    max-width: var(--container-xl);
}

.blog-section__header {
    text-align: center;
    margin-bottom: var(--space-12);
}

.blog-section__title {
    font-family: var(--font-heading);
    font-size: var(--text-2xl);
    font-weight: var(--font-bold);
    margin: 0 0 var(--space-2);
}

.blog-section__subtitle {
    font-family: var(--font-ui);
    font-size: var(--text-base);
    color: var(--color-text-secondary);
    margin: 0;
}

.blog-grid {
    display: grid;
    gap: var(--space-6);
    grid-template-columns: 1fr;
}

@media (min-width: 640px) {
    .blog-grid {
        grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
        gap: var(--space-8);
    }
}

@media (min-width: 1024px) {
    .blog-grid {
        grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    }
}

/* Limit to 3 columns on very wide screens (default) */
@media (min-width: 1400px) {
    .blog-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .blog-card--large {
        grid-column: span 1;
    }

    .blog-card--large:first-child {
        grid-row: span 2;
    }

    .blog-card--large:first-child .blog-card__image {
        aspect-ratio: 3 / 4;
    }

    .blog-card--large:first-child .blog-card__title {
        font-size: var(--text-2xl);
    }
}

/* ==========================================================================
   Homepage Blog Card (Overrides)
   ========================================================================== */

.home .blog-card,
.blog .blog-card {
    display: flex;
    flex-direction: column;
    background-color: var(--color-bg);
    border-radius: var(--radius-xl);
    overflow: hidden;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.home .blog-card:hover,
.blog .blog-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px -12px rgba(0,0,0,0.15);
}

.home .blog-card__image-link,
.blog .blog-card__image-link {
    display: block;
    text-decoration: none;
}

.home .blog-card__image,
.blog .blog-card__image {
    position: relative;
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background-color: var(--color-bg-tertiary);
}

.home .blog-card__image img,
.blog .blog-card__image img {
    width: 100%;
    height: 100%;
    object-fit: fill;
    transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.home .blog-card:hover .blog-card__image img,
.blog .blog-card:hover .blog-card__image img {
    transform: scale(1.05);
}

.home .blog-card__overlay,
.blog .blog-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.05) 100%);
    opacity: 0;
    transition: opacity var(--transition-base);
}

.home .blog-card:hover .blog-card__overlay,
.blog .blog-card:hover .blog-card__overlay {
    opacity: 1;
}

.home .blog-card__placeholder,
.blog .blog-card__placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    color: var(--color-text-tertiary);
}

.home .blog-card__body,
.blog .blog-card__body {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: var(--space-5);
}

.home .blog-card__top,
.blog .blog-card__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    margin-bottom: var(--space-3);
}

.home .blog-card__category,
.blog .blog-card__category {
    font-family: var(--font-ui);
    font-size: 11px;
    font-weight: var(--font-semibold);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
    color: var(--color-accent);
    text-decoration: none;
    transition: var(--transition-fast);
}

.home .blog-card__category:hover,
.blog .blog-card__category:hover {
    text-decoration: underline;
}

.home .blog-card__reading-time,
.blog .blog-card__reading-time {
    font-family: var(--font-ui);
    font-size: 11px;
    color: var(--color-text-tertiary);
}

.home .blog-card__title,
.blog .blog-card__title {
    font-family: var(--font-heading);
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    line-height: var(--leading-snug);
    margin: 0 0 var(--space-3);
    flex-grow: 0;
}

.home .blog-card__title a,
.blog .blog-card__title a {
    color: var(--color-text);
    text-decoration: none;
    transition: var(--transition-fast);
}

.home .blog-card__title a:hover,
.blog .blog-card__title a:hover {
    color: var(--color-accent);
}

.home .blog-card__excerpt,
.blog .blog-card__excerpt {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
    color: var(--color-text-secondary);
    margin: 0 0 var(--space-4);
    flex-grow: 1;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.home .blog-card__footer,
.blog .blog-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: var(--space-4);
    border-top: 1px solid var(--color-border-light);
    margin-top: auto;
}

.home .blog-card__author,
.blog .blog-card__author {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    text-decoration: none;
}

.home .blog-card__avatar,
.blog .blog-card__avatar {
    width: 32px;
    height: 32px;
    border-radius: var(--radius-full);
    border: 2px solid var(--color-bg);
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}

.home .blog-card__author-name,
.blog .blog-card__author-name {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--color-text);
    transition: var(--transition-fast);
}

.home .blog-card__author:hover .blog-card__author-name,
.blog .blog-card__author:hover .blog-card__author-name {
    color: var(--color-accent);
}

.home .blog-card__date,
.blog .blog-card__date {
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    color: var(--color-text-tertiary);
}

/* ==========================================================================
   Pagination Enhancement
   ========================================================================== */

.blog-section .pagination {
    margin-top: var(--space-12);
}

/* ==========================================================================
   Responsive Adjustments
   ========================================================================== */

@media (max-width: 639px) {
    .hero-section {
        padding: var(--space-4) 0 var(--space-8);
    }

    .hero-post__title {
        font-size: var(--text-2xl);
    }

    .hero-post__excerpt {
        font-size: var(--text-base);
    }

    .hero-post__meta {
        flex-direction: column;
        align-items: flex-start;
    }

    .hero-post__read-btn {
        width: 100%;
        justify-content: center;
    }

    .blog-section {
        padding: var(--space-8) 0 var(--space-12);
    }

    .home .blog-card__body,
    .blog .blog-card__body {
        padding: var(--space-4);
    }
}

/* ==========================================================================
   Dark Mode Adjustments
   ========================================================================== */

html[data-theme="dark"] .home .blog-card,
html[data-theme="dark"] .blog .blog-card,
html[data-theme="dark"] .hero-post__image {
    background-color: var(--color-bg-secondary);
}

html[data-theme="dark"] .home .blog-card:hover,
html[data-theme="dark"] .blog .blog-card:hover {
    box-shadow: 0 12px 40px -12px rgba(0,0,0,0.4);
}

@media (prefers-color-scheme: dark) {
    html:not([data-theme="light"]) .home .blog-card,
    html:not([data-theme="light"]) .blog .blog-card,
    html:not([data-theme="light"]) .hero-post__image {
        background-color: var(--color-bg-secondary);
    }

    html:not([data-theme="light"]) .home .blog-card:hover,
    html:not([data-theme="light"]) .blog .blog-card:hover {
        box-shadow: 0 12px 40px -12px rgba(0,0,0,0.4);
    }
}
