/*
 * Vendor Storefront Page Styles
 * Loaded directly from Storefront.cshtml — works on ALL themes.
 * Uses CSS custom properties to pick up the active theme's colors,
 * so the layout is consistent while colors adapt per theme.
 * ---------------------------------------------------------------
 * NOTE: CSS vars + nested SCSS in the same block cause a LibSass
 * compilation bug in Smartstore's Flex base theme. Serving this as
 * plain CSS from the view avoids that entirely.
 */

/* ── Vendor-scoped CSS variables (sourced from theme's Bootstrap vars) ── */
.vendor-storefront-page {
    --vendor-accent: #F1641E;
    --vendor-bg: var(--body-bg, #fff);
    --vendor-color: var(--body-color, #333);
    --vendor-muted: var(--secondary-color, #6c757d);
    --vendor-muted-bg: var(--secondary-bg, #f8f9fa);
    --vendor-border: var(--border-color, #dee2e6);
    --vendor-border-subtle: var(--border-color-translucent, rgba(0, 0, 0, 0.08));
    --vendor-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    --vendor-transition: 0.15s ease;
    --vendor-announce-bg: #fef9e7;
    --vendor-announce-border: #f5e6b8;
    --vendor-announce-color: #6b5900;
    --vendor-announce-icon: #d4a017;
}

/* ── Link reset (prevent theme link-color from bleeding in) ── */
.vendor-storefront-page > a:not(.btn):not(.badge),
.vendor-shop-header a:not(.btn):not(.badge),
.vendor-tabs-nav a:not(.btn):not(.badge):not(.vendor-tab-link),
.vendor-category-sidebar a:not(.btn):not(.badge),
.vendor-announcement a:not(.btn):not(.badge),
.vendor-about-section a:not(.btn):not(.badge) {
    text-decoration: none !important;
    color: inherit;
}
.vendor-storefront-page > a:not(.btn):not(.badge):hover,
.vendor-shop-header a:not(.btn):not(.badge):hover,
.vendor-tabs-nav a:not(.btn):not(.badge):not(.vendor-tab-link):hover,
.vendor-category-sidebar a:not(.btn):not(.badge):hover,
.vendor-announcement a:not(.btn):not(.badge):hover,
.vendor-about-section a:not(.btn):not(.badge):hover {
    text-decoration: none !important;
    color: var(--vendor-accent);
}

/* ── Banner ── */
.vendor-storefront-page .vendor-banner {
    position: relative;
    border-radius: 1rem;
    overflow: hidden;
    max-height: 300px;
}
.vendor-storefront-page .vendor-banner img {
    width: 100%;
    height: 280px;
    object-fit: cover;
    display: block;
}
@media (min-width: 768px) {
    .vendor-storefront-page .vendor-banner img { height: 300px; }
}
.vendor-storefront-page .vendor-banner::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 40%;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.2));
    border-radius: inherit;
    pointer-events: none;
}
.vendor-storefront-page .vendor-banner--default .vendor-banner-placeholder {
    height: 200px;
    background: linear-gradient(135deg, #222 0%, var(--vendor-accent) 100%);
}
@media (min-width: 768px) {
    .vendor-storefront-page .vendor-banner--default .vendor-banner-placeholder { height: 280px; }
}

/* ── Shop Header ── */
.vendor-storefront-page .vendor-shop-header {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1rem 1.5rem;
    margin-top: -2.5rem;
    position: relative;
    z-index: 2;
    background: var(--vendor-bg);
    border-radius: 0.75rem;
    box-shadow: var(--vendor-shadow);
}
@media (min-width: 768px) {
    .vendor-storefront-page .vendor-shop-header {
        margin-top: -3rem;
        padding: 1.25rem 2rem;
    }
}
@media (max-width: 767.98px) {
    .vendor-storefront-page .vendor-shop-header {
        flex-wrap: wrap;
        margin-top: -1.5rem;
        padding: 1rem;
    }
}

.vendor-storefront-page .vendor-logo-wrap { flex-shrink: 0; }

.vendor-storefront-page .vendor-logo {
    width: 90px;
    height: 90px;
    border-radius: 50%;
    overflow: hidden;
    border: 4px solid var(--vendor-bg);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.12);
    background: var(--vendor-bg);
    display: flex;
    align-items: center;
    justify-content: center;
}
.vendor-storefront-page .vendor-logo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.vendor-storefront-page .vendor-logo--placeholder {
    background: var(--vendor-muted-bg);
    color: var(--vendor-muted);
    font-size: 1.75rem;
}
@media (min-width: 768px) {
    .vendor-storefront-page .vendor-logo { width: 100px; height: 100px; }
}
@media (max-width: 767.98px) {
    .vendor-storefront-page .vendor-logo { width: 70px; height: 70px; }
}

.vendor-storefront-page .vendor-header-body {
    flex: 1;
    min-width: 0;
    padding-top: 1.5rem;
}
@media (max-width: 767.98px) {
    .vendor-storefront-page .vendor-header-body { padding-top: 0; }
}

.vendor-storefront-page .vendor-name-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.vendor-storefront-page .vendor-shop-name {
    font-size: 1.4rem;
    font-weight: 700;
    margin: 0;
    line-height: 1.3;
}
@media (min-width: 768px) {
    .vendor-storefront-page .vendor-shop-name { font-size: 1.6rem; }
}

.vendor-storefront-page .vendor-languages {
    display: inline-flex;
    gap: 0.25rem;
}
.vendor-storefront-page .vendor-languages .badge {
    font-size: 0.7rem;
    font-weight: 600;
    padding: 0.2em 0.5em;
}

.vendor-storefront-page .vendor-stats {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.4rem;
    margin-top: 0.35rem;
    font-size: 0.85rem;
    color: var(--vendor-muted);
}
.vendor-storefront-page .vendor-stat {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.15rem 0.5rem;
    background: var(--vendor-muted-bg);
    border-radius: 2rem;
    font-weight: 500;
}
.vendor-storefront-page .vendor-stat-sep {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--vendor-border);
}

.vendor-storefront-page .vendor-header-actions {
    display: flex;
    gap: 0.5rem;
    flex-shrink: 0;
    padding-top: 1.5rem;
}
.vendor-storefront-page .vendor-header-actions .btn {
    text-decoration: none !important;
    white-space: nowrap;
    border-radius: 2rem;
    padding: 0.4rem 1.1rem;
    font-weight: 600;
    font-size: 0.85rem;
}
@media (max-width: 767.98px) {
    .vendor-storefront-page .vendor-header-actions {
        padding-top: 0;
        width: 100%;
    }
    .vendor-storefront-page .vendor-header-actions .btn { flex: 1; }
}
.vendor-storefront-page .vendor-follow-btn {
    transition: all var(--vendor-transition);
}
.vendor-storefront-page .vendor-follow-btn.btn-outline-dark:hover {
    background: var(--vendor-accent);
    border-color: var(--vendor-accent);
    color: #fff;
}

/* ── Announcement ── */
.vendor-storefront-page .vendor-announcement {
    display: flex;
    align-items: flex-start;
    background: var(--vendor-announce-bg);
    border: 1px solid var(--vendor-announce-border);
    border-radius: 0.375rem;
    padding: 0.65rem 1rem;
    margin: 0.75rem 0;
    font-size: 0.9rem;
    color: var(--vendor-announce-color);
    line-height: 1.4;
}
.vendor-storefront-page .vendor-announcement i {
    color: var(--vendor-announce-icon);
    margin-top: 0.15rem;
    flex-shrink: 0;
}

/* ── Search within shop ── */
.vendor-storefront-page .vendor-search-shop {
    margin: 0.75rem 0 0;
    max-width: 480px;
}
.vendor-storefront-page .vendor-search-shop .input-group {
    border: 1px solid var(--vendor-border);
    border-radius: 2rem;
    overflow: hidden;
    background: var(--vendor-bg);
    transition: border-color var(--vendor-transition), box-shadow var(--vendor-transition);
}
.vendor-storefront-page .vendor-search-shop .input-group:focus-within {
    border-color: var(--vendor-accent);
    box-shadow: 0 0 0 2px rgba(241, 100, 30, 0.12);
}
.vendor-storefront-page .vendor-search-shop .form-control {
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding-inline-start: 1.25rem;
    padding-inline-end: 0.5rem;
    height: 42px;
    font-size: 0.9rem;
    background: transparent;
}
.vendor-storefront-page .vendor-search-shop .form-control::placeholder {
    color: var(--vendor-muted);
}
.vendor-storefront-page .vendor-search-shop .btn {
    border: none !important;
    border-radius: 0 !important;
    background: transparent;
    color: var(--vendor-muted);
    padding: 0 1rem;
    font-size: 1rem;
}
.vendor-storefront-page .vendor-search-shop .btn:hover {
    color: var(--vendor-accent);
}

/* ── Tab Navigation ── */
.vendor-storefront-page .vendor-tabs-nav {
    border-bottom: 2px solid var(--vendor-border);
    margin: 1.25rem 0 1.5rem;
}
.vendor-storefront-page .vendor-nav-tabs {
    display: flex;
    flex-wrap: nowrap;
    gap: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    list-style: none;
    padding: 0;
    margin: 0;
}
.vendor-storefront-page .vendor-nav-tabs::-webkit-scrollbar { display: none; }
.vendor-storefront-page .vendor-nav-tabs .vendor-tab-item {
    flex-shrink: 0;
    list-style: none;
}
.vendor-storefront-page .vendor-nav-tabs .vendor-tab-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.7rem 1.1rem;
    color: var(--vendor-muted);
    font-weight: 500;
    font-size: 0.95rem;
    border: none;
    border-bottom: 2px solid transparent;
    border-radius: 0;
    margin-bottom: -2px;
    background: none;
    white-space: nowrap;
    transition: color var(--vendor-transition), border-color var(--vendor-transition);
    text-decoration: none;
}
.vendor-storefront-page .vendor-nav-tabs .vendor-tab-link:hover {
    color: var(--vendor-color);
    border-bottom-color: var(--vendor-border);
    text-decoration: none;
}
.vendor-storefront-page .vendor-nav-tabs .vendor-tab-link.active {
    color: var(--vendor-accent);
    border-bottom-color: var(--vendor-accent);
    font-weight: 600;
}
.vendor-storefront-page .vendor-nav-tabs .vendor-tab-link .tab-count {
    font-size: 0.8rem;
    color: var(--vendor-muted);
    font-weight: 400;
}

/* ── Tab content ── */
.vendor-storefront-page .vendor-tab-content { min-height: 200px; }
.vendor-storefront-page .vendor-tab-pane { display: none; }
.vendor-storefront-page .vendor-tab-pane.active { display: block; }

/* ── Items layout (sidebar + grid) ── */
.vendor-storefront-page .vendor-items-layout {
    display: flex;
    gap: 2rem;
}
.vendor-storefront-page .vendor-items-layout:not(.has-sidebar) { display: block; }
@media (max-width: 991.98px) {
    .vendor-storefront-page .vendor-items-layout {
        flex-direction: column;
        gap: 1rem;
    }
}

.vendor-storefront-page .vendor-category-sidebar {
    flex-shrink: 0;
    width: 190px;
    font-size: 0.9rem;
    border-inline-end: 1px solid var(--vendor-border-subtle);
    padding-inline-end: 1rem;
}
@media (max-width: 991.98px) {
    .vendor-storefront-page .vendor-category-sidebar {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        gap: 0.35rem;
        border-inline-end: none;
        padding-inline-end: 0;
        padding-bottom: 0.75rem;
        border-bottom: 1px solid var(--vendor-border-subtle);
    }
}

.vendor-storefront-page .vendor-cat-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.4rem 0.5rem;
    color: var(--vendor-color);
    text-decoration: none !important;
    border-bottom: none;
    border-radius: 0.25rem;
    transition: color var(--vendor-transition), background-color var(--vendor-transition);
}
.vendor-storefront-page .vendor-cat-link:hover {
    color: var(--vendor-accent);
    background: rgba(0, 0, 0, 0.03);
    text-decoration: none !important;
}
.vendor-storefront-page .vendor-cat-link.active {
    font-weight: 600;
    color: var(--vendor-accent);
    background: rgba(241, 100, 30, 0.06);
}
@media (max-width: 991.98px) {
    .vendor-storefront-page .vendor-cat-link {
        padding: 0.35rem 0.75rem;
        border: 1px solid var(--vendor-border);
        border-radius: 1.25rem;
        font-size: 0.85rem;
        background: var(--vendor-bg);
    }
    .vendor-storefront-page .vendor-cat-link.active {
        background: var(--vendor-accent);
        border-color: var(--vendor-accent);
        color: #fff;
    }
    .vendor-storefront-page .vendor-cat-link.active .vendor-cat-count {
        color: rgba(255, 255, 255, 0.7);
    }
}

.vendor-storefront-page .vendor-cat-count {
    font-size: 0.8rem;
    color: var(--vendor-muted);
    margin-inline-start: 0.5rem;
}
.vendor-storefront-page .vendor-cat-group { margin-top: 0.75rem; }
@media (max-width: 991.98px) {
    .vendor-storefront-page .vendor-cat-group {
        margin-top: 0;
        display: contents;
    }
}
.vendor-storefront-page .vendor-cat-group-title {
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--vendor-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.35rem 0.5rem 0.15rem;
}
@media (max-width: 991.98px) {
    .vendor-storefront-page .vendor-cat-group-title { display: none; }
}

.vendor-storefront-page .vendor-items-main {
    flex: 1;
    min-width: 0;
}

/* ── Featured products ── */
.vendor-storefront-page .vendor-featured-products h4 {
    font-size: 1.1rem;
    font-weight: 600;
}

/* ── About section ── */
.vendor-storefront-page .vendor-about-section { max-width: 800px; }
.vendor-storefront-page .vendor-about-section .vendor-about-details {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 2rem;
}
.vendor-storefront-page .vendor-about-section .vendor-about-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.95rem;
}
.vendor-storefront-page .vendor-about-section .vendor-about-item i {
    width: 1.25rem;
    text-align: center;
    color: var(--vendor-muted);
}
.vendor-storefront-page .vendor-about-section .vendor-about-stats {
    background: var(--vendor-muted-bg);
    border-radius: 0.5rem;
    padding: 1.5rem;
    margin-top: 1.5rem;
}

/* ── Reviews ── */
.vendor-storefront-page .vendor-review-list .vendor-review-item:last-child {
    border-bottom: none !important;
}
.vendor-storefront-page .vendor-review-stars {
    font-size: 1.1rem;
    letter-spacing: 1px;
}

/* ── Layout variants ── */
.vendor-storefront-page.vendor-layout-no-sidebar .vendor-search-shop,
.vendor-storefront-page.vendor-layout-full-width .vendor-search-shop {
    max-width: 560px;
}
.vendor-storefront-page.vendor-layout-full-width .vendor-banner {
    border-radius: 0;
    margin-inline: -1rem;
}

/* ── Mobile responsive ── */
@media (max-width: 767.98px) {
    .vendor-storefront-page .vendor-banner {
        border-radius: 0;
        max-height: 180px;
    }
    .vendor-storefront-page .vendor-banner img { height: 180px; }
    .vendor-storefront-page .vendor-banner--default .vendor-banner-placeholder { height: 120px; }
    .vendor-storefront-page .vendor-shop-name { font-size: 1.15rem; }
    .vendor-storefront-page .vendor-search-shop { max-width: 100%; }
    .vendor-storefront-page .vendor-nav-tabs .vendor-tab-link {
        padding: 0.55rem 0.85rem;
        font-size: 0.9rem;
    }
}
