/* ==========================================================================
   Homepage Styles
   ========================================================================== */

/* ---------- Hero — Full Viewport ---------- */

.home-hero {
    position: relative;
    min-height: 100svh;
    min-height: 100vh;
    overflow: hidden;
}

.home-hero > picture > img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
}

.home-hero__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(to right, rgba(26, 58, 15, 0.85), rgba(26, 58, 15, 0.4) 50%, transparent);
    display: flex;
    align-items: center;
}

.home-hero__content {
    position: relative;
    z-index: 2;
    color: var(--color-white);
    max-width: 50ch;
}

.home-hero h1 {
    font-size: var(--text-hero);
    color: var(--color-white);
    margin-bottom: var(--space-4);
}

.home-hero__sub {
    color: rgba(255, 255, 255, 0.9);
    font-size: var(--text-xl);
    margin-bottom: var(--space-8);
}

.hero-badge {
    display: inline-block;
    background-color: var(--color-accent-500);
    color: var(--color-white);
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    margin-bottom: var(--space-6);
}

.home-hero__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: var(--space-4);
}

/* Hero button overrides for dark background */
.home-hero .btn-secondary {
    color: var(--color-white);
    border-color: var(--color-white);
}

.home-hero .btn-secondary:hover {
    background-color: var(--color-white);
    color: var(--color-primary-700);
}

.home-hero .btn-secondary:focus-visible {
    outline-color: var(--color-white);
}

/* Snow canvas z-index — must render above overlay */
.home-hero canvas[aria-hidden] {
    z-index: 10;
}

/* ---------- Trust Bar ---------- */

.home-trust {
    padding-block: var(--space-10);
    border-bottom: 1px solid var(--color-border-light);
}

/* ---------- Products Overview ---------- */

.home-products h2 {
    text-align: center;
    margin-bottom: var(--space-12);
}

.home-products .product-card {
    position: relative;
}

.home-products .product-card h3 a {
    text-decoration: none;
    color: inherit;
}

.home-products .product-card h3 a::after {
    content: '';
    position: absolute;
    inset: 0;
}

.home-products .product-card .btn-ghost {
    pointer-events: none;
}

/* ---------- Two-Column Sections ---------- */

.home-why__grid,
.home-athens__grid,
.home-about__grid {
    display: grid;
    gap: var(--space-12);
    align-items: center;
}

@media (min-width: 768px) {
    .home-why__grid,
    .home-athens__grid,
    .home-about__grid {
        grid-template-columns: 1fr 1fr;
    }
}

.home-why__grid img,
.home-athens__grid img,
.home-about__grid img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: var(--card-radius);
    width: 100%;
    height: auto;
}

/* ---------- Why Natural Fir ---------- */

.home-why__content h2 {
    margin-bottom: var(--space-6);
}

.home-why__content p {
    color: var(--color-text-secondary);
    margin-bottom: var(--space-4);
}

.home-why__content p:last-child {
    margin-bottom: 0;
}

/* ---------- Athens Callout ---------- */

.home-athens {
    background-color: var(--color-primary-100);
}

.home-athens__content h2 {
    margin-bottom: var(--space-2);
}

.home-athens__content .home-athens__sub {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: var(--space-6);
}

.home-athens__content p {
    color: var(--color-text-secondary);
    margin-bottom: var(--space-6);
}

/* ---------- About Snippet ---------- */

.home-about__content h2 {
    margin-bottom: var(--space-4);
}

.home-about__content p {
    color: var(--color-text-secondary);
    margin-bottom: var(--space-6);
}

/* ---------- Gallery Teaser ---------- */

.home-gallery h2 {
    text-align: center;
    margin-bottom: var(--space-8);
}

.home-gallery__grid {
    display: grid;
    gap: var(--space-4);
    grid-template-columns: repeat(2, 1fr);
    margin-bottom: var(--space-8);
}

@media (min-width: 640px) {
    .home-gallery__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.home-gallery__item {
    overflow: hidden;
    border-radius: var(--card-radius);
}

.home-gallery__item img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    width: 100%;
    height: auto;
    transition: transform var(--transition-base);
}

.home-gallery__item:hover img {
    transform: scale(1.05);
}

.home-gallery .text-center {
    text-align: center;
}
