/**
 * Gene Shop Shell Styles
 * Scoped to .holsea-shop-page to prevent pollution.
 */

/* =========================================
   CRITICAL: Override Homepage Fullscreen Lock
   This allows shop pages to scroll normally.
   ========================================= */
body.holsea-shop-page,
body.holsea-shop-page html,
.holsea-shop-page {
    height: auto !important;
    min-height: 100vh;
    overflow: visible !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior: auto !important;
    touch-action: auto !important;
    position: relative !important;
}

html:has(body.holsea-shop-page) {
    height: auto !important;
    overflow: visible !important;
    overflow-y: auto !important;
}

body.holsea-shop-page .holsea-rooms,
body.holsea-shop-page .holsea-room,
body.holsea-shop-page #holsea-viewport {
    display: none !important;
}

/* =========================================
   Variables & Reset
   ========================================= */
.holsea-shop-page {
    --gene-shell-bg: #ffffff;
    --gene-shell-text: #2A2A2A;
    --gene-shell-meta: #6B6B6B;
    --gene-shell-border: rgba(0, 0, 0, 0.08);
    --gene-shell-accent: #B8A88A;
    --gene-font-serif: 'Playfair Display', serif;
    --gene-font-sans: 'Inter', sans-serif;
    --gene-header-height: 80px;
    --gene-header-compact: 60px;
}

/* =========================================
   Header Layout
   ========================================= */
.gene-shop-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid transparent;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    height: var(--gene-header-height);
    display: flex;
    align-items: center;
}

.gene-shop-header.is-compact {
    height: var(--gene-header-compact);
    border-bottom: 1px solid var(--gene-shell-border);
    background: rgba(255, 255, 255, 0.99);
}

.gene-header-inner {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 2rem;
    display: grid;
    grid-template-columns: 200px 1fr 200px;
    align-items: center;
}

/* =========================================
   Brand Block (Left)
   ========================================= */
.gene-brand-block {
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-decoration: none;
}

#gene-brand-logo {
    height: 4vw;
}

.gene-brand-logo {
    height: 32px;
    width: auto;
    object-fit: contain;
    display: block;
    margin-bottom: 4px;
    transition: all 0.3s ease;
}

.gene-shop-header.is-compact .gene-brand-logo {
    height: 26px;
}

.gene-brand-label {
    font-family: var(--gene-font-sans);
    font-size: 0.5rem;
    letter-spacing: 0.25em;
    color: var(--gene-shell-meta);
    text-transform: uppercase;
    line-height: 1;
    margin-left: 2px;
    opacity: 0.8;
}

/* =========================================
   Nav (Center)
   ========================================= */
.gene-header-nav {
    display: flex;
    justify-content: center;
    gap: 3rem;
}

.gene-nav-link {
    font-family: var(--gene-font-sans);
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--gene-shell-text);
    text-decoration: none;
    position: relative;
    padding: 0.5rem 0;
    letter-spacing: 0.02em;
}

.gene-nav-link::after {
    content: '';
    position: absolute;
    bottom: 0px;
    left: 50%;
    width: 0%;
    height: 1px;
    background: var(--gene-shell-text);
    transition: all 0.3s ease;
    transform: translateX(-50%);
    opacity: 0.5;
}

.gene-nav-link:hover::after {
    width: 100%;
}

.gene-nav-separator {
    color: var(--gene-shell-border);
    margin: 0 0.5rem;
    font-weight: 300;
}

/* =========================================
   Utility (Right)
   ========================================= */
.gene-header-utility {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 1.5rem;
}

.gene-utility-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.5rem;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gene-shell-text);
    transition: transform 0.2s ease;
}

.gene-utility-btn:hover {
    transform: translateY(-1px);
}

.gene-utility-icon {
    width: 20px;
    height: 20px;
}

/* Cart Badge */
.gene-cart-badge {
    position: absolute;
    top: -2px;
    right: -4px;
    background: var(--gene-shell-text);
    color: white;
    font-family: var(--gene-font-sans);
    font-size: 10px;
    font-weight: 600;
    height: 16px;
    width: 16px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transform: scale(0);
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.gene-cart-badge.active {
    transform: scale(1);
}

.gene-cart-badge.pulse {
    animation: gene-badge-pulse 0.4s ease;
}

@keyframes gene-badge-pulse {
    0% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.3);
    }

    100% {
        transform: scale(1);
    }
}

/* =========================================
   Drawer (Mobile)
   ========================================= */
.gene-mobile-toggle {
    display: none;
}

.gene-drawer-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.3);
    z-index: 1001;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.gene-drawer {
    position: fixed;
    top: 0;
    left: 0;
    /* Left side drawer for Nav */
    width: 85%;
    max-width: 320px;
    height: 100vh;
    background: white;
    z-index: 1002;
    transform: translateX(-100%);
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    padding: 2rem;
    display: flex;
    flex-direction: column;
}

.gene-drawer.is-open {
    transform: translateX(0);
}

.gene-drawer-overlay.is-open {
    opacity: 1;
    pointer-events: auto;
}

.gene-drawer-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 3rem;
}

.gene-drawer-nav {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.gene-drawer-link {
    font-family: var(--gene-font-serif);
    font-size: 1.5rem;
    color: var(--gene-shell-text);
    text-decoration: none;
}

/* =========================================
   Search Overlay
   ========================================= */
.gene-search-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 300px;
    /* Partial overlay */
    background: white;
    z-index: 999;
    transform: translateY(-100%);
    transition: transform 0.3s ease;
    border-bottom: 1px solid var(--gene-shell-border);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.05);
}

.gene-search-overlay.is-open {
    transform: translateY(0);
    padding-top: var(--gene-header-height);
    /* Clear header */
}

.gene-search-input {
    width: 100%;
    max-width: 600px;
    border: none;
    border-bottom: 1px solid var(--gene-shell-border);
    font-family: var(--gene-font-serif);
    font-size: 1.5rem;
    padding: 1rem 0;
    outline: none;
    text-align: center;
}

.gene-search-input::placeholder {
    color: var(--gene-shell-meta);
    opacity: 0.5;
}

/* =========================================
   Footer Layout
   ========================================= */
.gene-shop-footer {
    background: #FAFAFA;
    padding: 6rem 0 2rem;
    margin-top: 0;
    /* Let main content dictate margin */
    border-top: 1px solid var(--gene-shell-border);
}

.gene-footer-inner {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 2rem;
}

/* Ritual Note */
.gene-ritual-note {
    text-align: center;
    margin-bottom: 5rem;
}

.gene-ritual-text {
    font-family: var(--gene-font-serif);
    font-size: 1.8rem;
    color: var(--gene-shell-text);
    margin-bottom: 0.5rem;
    letter-spacing: 0.02em;
}

.gene-ritual-brand {
    font-family: var(--gene-font-sans);
    font-size: 0.75rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--gene-shell-meta);
}

/* Link Matrix */
.gene-link-matrix {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
    padding-bottom: 4rem;
    padding-top: 4rem;
    border-top: 1px solid var(--gene-shell-border);
    border-bottom: 1px solid var(--gene-shell-border);
}

.gene-matrix-col h4 {
    font-family: var(--gene-font-sans);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--gene-shell-text);
    margin-bottom: 1.5rem;
    font-weight: 600;
}

.gene-matrix-col ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.gene-matrix-col li {
    margin-bottom: 0.8rem;
}

.gene-matrix-col a {
    text-decoration: none;
    color: var(--gene-shell-meta);
    font-family: var(--gene-font-sans);
    font-size: 0.9rem;
    transition: color 0.3s;
}

.gene-matrix-col a:hover {
    color: var(--gene-shell-text);
}

/* Company Info Block */
.gene-company-block {
    text-align: center;
    padding: 3rem 0;
    border-bottom: 1px solid var(--gene-shell-border);
    color: var(--gene-shell-meta);
    font-family: var(--gene-font-sans);
}

.gene-company-name {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--gene-shell-text);
    margin-bottom: 1rem;
    letter-spacing: 0.05em;
}

.gene-company-details {
    font-size: 0.8rem;
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.gene-company-details .separator {
    color: var(--gene-shell-border);
}

.gene-company-address {
    font-size: 0.8rem;
    opacity: 0.8;
}

/* Bottom Bar */
.gene-footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 2rem;
    font-family: var(--gene-font-sans);
    font-size: 0.75rem;
    color: var(--gene-shell-meta);
}

.gene-trust-row {
    letter-spacing: 0.1em;
}

/* =========================================
   Mobile Logic
   ========================================= */
@media (max-width: 900px) {
    .gene-header-inner {
        padding: 0 1.5rem;
        grid-template-columns: 1fr 1fr;
        /* Logo | Utility */
    }

    .gene-header-nav {
        display: none;
        /* Hide on mobile, show drawer */
    }

    .gene-mobile-toggle {
        display: block;
        margin-left: 1rem;
    }

    .gene-brand-block {
        align-items: flex-start;
    }

    .gene-header-utility {
        justify-content: flex-end;
    }

    .gene-search-overlay.is-open {
        padding-top: 1rem;
        height: 120px;
    }

    .gene-search-input {
        font-size: 1.1rem;
    }

    .gene-link-matrix {
        grid-template-columns: 1fr;
        gap: 3rem;
        text-align: center;
    }

    .gene-footer-bottom {
        flex-direction: column;
        gap: 1rem;
    }
}