/* ==========================================================================
   Homepage Styles — Thmanyah Spine Layout
   ========================================================================== */

/* ── Page base (warm beige background) ── */
.home .site-content,
.front-page .site-content {
    background: var(--color-bg);
}

/* ══════════════════════════════════════════
   HERO CARD (Full-width single article)
══════════════════════════════════════════ */
.hp-hero {
    margin: var(--space-2xl) 0;
}

.hp-hero__link {
    display: block;
    text-decoration: none;
    color: inherit;
}

.hp-hero__inner {
    display: grid;
    grid-template-columns: 1fr;
    background: var(--color-bg-card);
    border-radius: var(--radius-xl);
    overflow: hidden;
    transition: box-shadow var(--transition);
}

.hp-hero__inner:hover {
    box-shadow: var(--shadow);
}

.hp-hero__thumb {
    position: relative;
    width: 100%;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: var(--color-bg-alt);
}

.hp-hero__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease;
}

.hp-hero__link:hover .hp-hero__img {
    transform: scale(1.03);
}

.hp-hero__body {
    padding: var(--space-xl) var(--space-2xl);
}

.hp-hero__cat {
    display: inline-block;
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    color: var(--color-primary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--space-md);
}

.hp-hero__title {
    font-size: var(--fs-3xl);
    line-height: var(--lh-tight);
    color: var(--color-text);
    margin-bottom: var(--space-md);
    transition: color var(--transition-fast);
}

.hp-hero__link:hover .hp-hero__title {
    color: var(--color-primary);
}

.hp-hero__excerpt {
    font-size: var(--fs-lg);
    color: var(--color-text-secondary);
    line-height: var(--lh-relaxed);
    margin-bottom: var(--space-xl);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.hp-hero__meta {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--fs-sm);
    color: var(--color-text-light);
}

.hp-hero__avatar {
    width: 32px;
    height: 32px;
    border-radius: var(--radius-full);
    object-fit: cover;
}

.hp-hero__author {
    color: var(--color-text);
    font-weight: var(--fw-medium);
}

.hp-hero__dot { opacity: 0.4; }

/* Desktop hero: split 60/40 */
@media (min-width: 960px) {
    .hp-hero__inner {
        grid-template-columns: 60% 40%;
    }

    .hp-hero__thumb {
        aspect-ratio: auto;
    }

    .hp-hero__title {
        font-size: var(--fs-4xl);
    }
}

/* ══════════════════════════════════════════
   CATEGORY TABS (Pill filter bar)
══════════════════════════════════════════ */
.hp-tabs {
    display: flex;
    gap: var(--space-sm);
    flex-wrap: wrap;
    margin-bottom: var(--space-2xl);
}

.hp-tab {
    padding: 7px 18px;
    border-radius: var(--radius-full);
    font-size: var(--fs-sm);
    font-weight: var(--fw-medium);
    color: var(--color-text-secondary);
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    transition: all var(--transition-fast);
    cursor: pointer;
}

.hp-tab:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.hp-tab.active {
    background: var(--color-primary);
    color: var(--color-text-white);
    border-color: var(--color-primary);
}

/* ══════════════════════════════════════════
   SPINE LAYOUT (Two-column Thmanyah grid)
══════════════════════════════════════════ */
.hp-spine {
    margin-bottom: var(--space-3xl);
}

.hp-spine__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
}

/* On desktop: two columns that mirror each other */
@media (min-width: 768px) {
    .hp-spine__grid {
        grid-template-columns: 1fr 1px 1fr;
        gap: 0;
    }

    .hp-spine__divider {
        background: var(--color-border);
        align-self: stretch;
    }
}

.hp-spine__col {
    display: flex;
    flex-direction: column;
}

/* ── Spine Card ── */
.card-spine {
    border-bottom: 1px solid var(--color-border-light);
}

.card-spine:last-child {
    border-bottom: none;
}

.card-spine__link {
    display: flex;
    align-items: center;
    gap: var(--space-lg);
    padding: var(--space-lg) var(--space-xl);
    text-decoration: none;
    color: inherit;
    transition: background var(--transition-fast);
}

.card-spine__link:hover {
    background: rgba(0,0,0,0.02);
    color: inherit;
}

/* Right column: image on LEFT side (RTL natural order) */
.card-spine--right .card-spine__link {
    flex-direction: row;
    padding: var(--space-lg) var(--space-md) var(--space-lg) var(--space-xl);
}

/* Left column: image on RIGHT side (text on left side of page center) */
.card-spine--left .card-spine__link {
    flex-direction: row-reverse;
    padding: var(--space-lg) var(--space-xl) var(--space-lg) var(--space-md);
}

.card-spine__thumb {
    flex-shrink: 0;
    width: var(--card-spine-img);
    height: var(--card-spine-img);
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--color-bg-alt);
}

.card-spine__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.card-spine__link:hover .card-spine__img {
    transform: scale(1.06);
}

.card-spine__img--placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--color-bg-alt), var(--color-border));
}

.card-spine__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

/* Left body aligns text to the right (RTL natural) */
.card-spine__body--left {
    text-align: right;
}

.card-spine__cat {
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    color: var(--color-primary);
}

.card-spine__title {
    font-size: var(--fs-base);
    font-weight: var(--fw-semibold);
    line-height: var(--lh-normal);
    color: var(--color-text);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    transition: color var(--transition-fast);
}

.card-spine__link:hover .card-spine__title {
    color: var(--color-primary);
}

.card-spine__meta {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: var(--fs-xs);
    color: var(--color-text-light);
    flex-wrap: wrap;
}

.card-spine__dot { opacity: 0.5; }

/* ══════════════════════════════════════════
   FEATURED CARDS (3-col featured row)
══════════════════════════════════════════ */
.hp-featured {
    margin-bottom: var(--space-3xl);
}

.hp-featured__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

@media (min-width: 640px) {
    .hp-featured__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 960px) {
    .hp-featured__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.card-featured {
    background: var(--color-bg-card);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: box-shadow var(--transition), transform var(--transition);
}

.card-featured:hover {
    box-shadow: var(--shadow);
    transform: translateY(-4px);
}

.card-featured__link {
    display: flex;
    flex-direction: column;
    height: 100%;
    text-decoration: none;
    color: inherit;
}

.card-featured__thumb {
    width: 100%;
    aspect-ratio: 16/10;
    overflow: hidden;
    background: var(--color-bg-alt);
    position: relative;
}

.card-featured__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.card-featured:hover .card-featured__img {
    transform: scale(1.05);
}

.card-featured__img--placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--color-bg-alt), var(--color-border));
}

.card-featured__body {
    padding: var(--space-lg);
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.card-featured__cat {
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    color: var(--color-primary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.card-featured__title {
    font-size: var(--fs-md);
    font-weight: var(--fw-semibold);
    line-height: var(--lh-normal);
    color: var(--color-text);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    transition: color var(--transition-fast);
    flex: 1;
}

.card-featured__link:hover .card-featured__title {
    color: var(--color-primary);
}

.card-featured__meta {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: var(--fs-xs);
    color: var(--color-text-light);
    flex-wrap: wrap;
    margin-top: auto;
}

.card-featured__avatar {
    width: 22px;
    height: 22px;
    border-radius: var(--radius-full);
    object-fit: cover;
}

.card-featured__dot { opacity: 0.4; }

/* ══════════════════════════════════════════
   SECTION HEADERS
══════════════════════════════════════════ */
.hp-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-xl);
    padding-bottom: var(--space-md);
    border-bottom: 2px solid var(--color-text);
}

.hp-section-head__title {
    font-size: var(--fs-xl);
    font-weight: var(--fw-bold);
    color: var(--color-text);
}

.hp-section-head__link {
    font-size: var(--fs-sm);
    font-weight: var(--fw-medium);
    color: var(--color-primary);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 4px;
    transition: opacity var(--transition-fast);
}

.hp-section-head__link:hover {
    opacity: 0.75;
}

/* ══════════════════════════════════════════
   LOAD MORE
══════════════════════════════════════════ */
.hp-load-more {
    display: flex;
    justify-content: center;
    padding: var(--space-2xl) 0 var(--space-4xl);
}

#hpLoadMoreBtn {
    min-width: 180px;
}

/* ══════════════════════════════════════════
   HORIZONTAL DIVIDER (Spine center line)
══════════════════════════════════════════ */
.hp-spine__divider {
    display: none;
}

@media (min-width: 768px) {
    .hp-spine__divider {
        display: block;
    }
}
