.vgl-container {
    width: 100%;
    max-width: var(--vgl-container-max);
    margin-inline: auto;
    /* Gutter on narrow viewports only — at desktop the container is exactly 1200px
       so AdSense / full-bleed modules align with page content. */
    padding-inline: var(--vgl-space-4);
}

@media (min-width: 1024px) {
    .vgl-container {
        padding-inline: 0;
    }
}

.vgl-site {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.vgl-site__main {
    flex: 1;
    padding-block: var(--vgl-space-3);
    padding-top: var(--vgl-space-2);
}

/* Full-width layout */
.vgl-layout--full {
    width: 100%;
}

/* Content + sidebar (2/3 + 1/3) */
.vgl-layout--sidebar {
    display: grid;
    gap: var(--vgl-space-8);
    grid-template-columns: 1fr;
}

@media (min-width: 1024px) {
    .vgl-layout--sidebar {
        grid-template-columns: var(--vgl-content-sidebar-ratio);
        align-items: start;
    }
}

.vgl-layout__content {
    min-width: 0;
}

.vgl-layout__sidebar {
    min-width: 0;
}

/* Product grid */
.vgl-grid {
    display: grid;
    gap: var(--vgl-space-4);
}

.vgl-grid--2 { grid-template-columns: repeat(2, 1fr); }
.vgl-grid--3 { grid-template-columns: repeat(3, 1fr); }
.vgl-grid--4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 1023px) {
    .vgl-grid--3,
    .vgl-grid--4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 479px) {
    .vgl-grid--2,
    .vgl-grid--3,
    .vgl-grid--4 {
        grid-template-columns: 1fr;
    }
}

/* Category / search page: filter sidebar left, results right */
.vgl-layout--category {
    display: grid;
    gap: var(--vgl-space-6);
    grid-template-columns: 1fr;
    grid-template-areas:
        "sidebar"
        "main";
}

.vgl-layout--category > .vgl-filter-sidebar,
.vgl-layout--category > aside.sidebar {
    grid-area: sidebar;
    min-width: 0;
}

.vgl-layout--category > .vgl-category-page__main,
.vgl-layout--category > .vgl-search-results {
    grid-area: main;
    min-width: 0;
}

@media (min-width: 1024px) {
    .vgl-layout--category {
        grid-template-columns: var(--vgl-sidebar-width) minmax(0, 1fr);
        grid-template-areas: "sidebar main";
        align-items: start;
    }
}

/* Navigation */
.vgl-nav__list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--vgl-space-2);
}

.vgl-nav__item a {
    display: block;
    padding: var(--vgl-space-2) var(--vgl-space-3);
    color: var(--vgl-color-text);
    font-weight: 500;
}

.vgl-nav__item a:hover {
    color: var(--vgl-color-primary);
    text-decoration: none;
}

.vgl-nav__submenu {
    position: absolute;
    background: var(--vgl-color-surface);
    border: 1px solid var(--vgl-color-border);
    border-radius: var(--vgl-radius);
    box-shadow: var(--vgl-shadow);
    padding: var(--vgl-space-2);
    min-width: 180px;
    display: none;
}

.vgl-nav__item--has-children {
    position: relative;
}

.vgl-nav__item--has-children:hover .vgl-nav__submenu {
    display: block;
}

/* Footer navigation — world columns with intent submenus */
.vgl-footer .vgl-nav {
    margin-bottom: var(--vgl-space-6);
}

.vgl-footer .vgl-footer-nav__list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--vgl-space-6);
    list-style: none;
    margin: 0;
    padding: 0;
}

.vgl-footer .vgl-footer-nav__list > .vgl-nav__item {
    flex: 1 1 11rem;
    min-width: 10rem;
    max-width: 14rem;
}

.vgl-footer .vgl-footer-nav__list > .vgl-nav__item > a {
    padding: 0 0 var(--vgl-space-2);
    font-weight: 700;
    color: var(--vgl-color-primary);
}

.vgl-footer .vgl-footer-nav__list .vgl-nav__submenu {
    position: static;
    display: block;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
    min-width: 0;
}

.vgl-footer .vgl-footer-nav__list .vgl-nav__submenu .vgl-nav__item a {
    padding: var(--vgl-space-1) 0;
    font-size: var(--vgl-font-size-sm);
    font-weight: 500;
    color: var(--vgl-color-text);
}

.vgl-footer .vgl-footer-nav__list .vgl-nav__submenu .vgl-nav__item a:hover {
    color: var(--vgl-color-primary);
}

.vgl-footer .vgl-footer-nav__list .vgl-nav__submenu .vgl-nav__submenu {
    display: none;
}

/* Footer */
.vgl-footer {
    background: var(--vgl-color-bg-alt);
    border-top: 1px solid var(--vgl-color-border);
    padding-block: var(--vgl-space-8);
    margin-top: var(--vgl-space-12);
}

.vgl-footer__widgets {
    padding-bottom: var(--vgl-space-6);
    margin-bottom: var(--vgl-space-6);
    border-bottom: 1px solid var(--vgl-color-border);
}

.vgl-footer__widgets-grid {
    display: grid;
    gap: var(--vgl-space-6);
    grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 1023px) {
    .vgl-footer__widgets-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 599px) {
    .vgl-footer__widgets-grid {
        grid-template-columns: 1fr;
    }
}

.vgl-widget-zone {
    min-height: 1px;
}

.vgl-footer__bottom {
    display: flex;
    flex-wrap: wrap;
    gap: var(--vgl-space-4);
    justify-content: space-between;
    align-items: center;
    font-size: var(--vgl-font-size-sm);
    color: var(--vgl-color-text-muted);
}

.vgl-footer__bottom .header-social {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: var(--vgl-space-3);
    margin: 0;
    padding: 0;
    list-style: none;
}

.vgl-footer__bottom .header-social li {
    margin: 0;
    padding: 0;
    line-height: 1;
}

.vgl-footer__bottom .header-social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    color: var(--vgl-color-text-muted);
    text-decoration: none;
    transition: color var(--vgl-transition);
}

.vgl-footer__bottom .header-social a:hover {
    color: var(--vgl-color-primary);
}

.vgl-footer__bottom .header-social .vgl-social-icon {
    width: 1.125rem;
    height: 1.125rem;
    fill: currentColor;
}

#back2Top {
    position: fixed;
    bottom: var(--vgl-space-6);
    right: var(--vgl-space-6);
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--vgl-color-primary);
    color: var(--vgl-color-text-inverse);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--vgl-transition);
    z-index: 90;
    transform: rotate(-90deg);
}

#back2Top.visible {
    opacity: 1;
    pointer-events: auto;
}
