/* Storefront Theme (Original implementation inspired by external reference, not copied) */
:root {
    --sf-bg: #0d1513;
    --sf-bg-alt: #13201b;
    --sf-surface: #182822;
    --sf-surface-alt: #20352d;
    --sf-accent: #d8b64c;
    --sf-accent-rgb: 216, 182, 76;
    --sf-accent-alt: #f1d067;
    --sf-text: #f5f7f6;
    --sf-text-dim: #b9c2bd;
    --sf-danger: #e74c3c;
    --sf-success: #2ecc71;
    --sf-radius-sm: 4px;
    --sf-radius: 8px;
    --sf-radius-lg: 18px;
    --sf-shadow-sm: 0 2px 4px -1px rgba(0, 0, 0, 0.3);
    --sf-shadow: 0 4px 14px -2px rgba(0, 0, 0, 0.45);
    --sf-shadow-lg: 0 12px 28px -6px rgba(0, 0, 0, 0.55);
    --sf-gradient-accent: linear-gradient(
        135deg,
        #d8b64c 0%,
        #c49a25 45%,
        #e6ce72 100%
    );
    --sf-transition: all 0.35s cubic-bezier(0.16, 0.8, 0.42, 1);
    --sf-font-stack: "Poppins", "Figtree", system-ui, -apple-system,
        BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell,
        "Open Sans", sans-serif;
}

html,
body {
    background: var(--sf-bg);
    color: var(--sf-text);
    font-family: var(--sf-font-stack);
}
body {
    line-height: 1.55;
}

/* Light Skin (white background + deep green accents) */
body.sf-light {
    --sf-bg: #ffffff;
    --sf-bg-alt: #ffffff;
    --sf-surface: #f8f9fa;
    --sf-surface-alt: #f0f2f5;
    --sf-text: #1a1a1a;
    --sf-text-dim: #666666;
    --sf-accent: #20352d; /* main brand accent */
    --sf-accent-rgb: 32, 53, 45;
    --sf-accent-hover: #25443a;
    --sf-gradient-accent: linear-gradient(
        135deg,
        #20352d 0%,
        #2c4d42 50%,
        #3e6a5a 100%
    );
    --sf-shadow: 0 8px 20px -8px rgba(0, 0, 0, 0.12);
    --sf-shadow-lg: 0 20px 34px -14px rgba(0, 0, 0, 0.18);
}

/* Announcement Bar */
.sf-announcement {
    background: var(--sf-gradient-accent);
    color: #ffffff;
    font-weight: 600;
    font-size: 0.88rem;
    letter-spacing: 0.3px;
    padding: 0.65rem 0;
    position: relative;
    overflow: hidden;
    text-align: center;
}
.sf-announcement a {
    color: #fff;
    text-decoration: underline;
    margin-left: 0.5rem;
}
.sf-announcement a:hover {
    opacity: 0.85;
}

/* Header */
.sf-header {
    background: var(--sf-bg-alt);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}
.sf-light .sf-header {
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}
.sf-header .sf-top {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    padding: 0.85rem 0;
}
.sf-logo img {
    max-height: 58px;
    filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.55));
}
.sf-search {
    flex: 1;
    position: relative;
}
.sf-search input {
    width: 100%;
    background: var(--sf-surface);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--sf-text);
    padding: 0.75rem 3.25rem 0.75rem 1rem;
    border-radius: var(--sf-radius-lg);
    font-size: 0.95rem;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03);
}
.sf-search input:focus {
    outline: none;
    border-color: var(--sf-accent);
    box-shadow: 0 0 0 3px rgba(var(--sf-accent-rgb), 0.25);
}
.sf-search .icon {
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--sf-accent);
    font-size: 1.1rem;
}
.sf-icons {
    display: flex;
    align-items: center;
    gap: 0.9rem;
}
.sf-icon-btn {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    border-radius: 50%;
    background: var(--sf-surface);
    color: var(--sf-text);
    border: 1px solid rgba(255, 255, 255, 0.08);
    transition: var(--sf-transition);
}
.sf-icon-btn:hover {
    background: var(--sf-accent);
    color: #1a1d18;
    box-shadow: 0 6px 18px -6px rgba(var(--sf-accent-rgb), 0.55);
    transform: translateY(-2px);
}
.sf-icon-btn .badge {
    position: absolute;
    top: 4px;
    right: 4px;
    background: var(--sf-danger);
    font-size: 0.65rem;
    padding: 0.25rem 0.4rem;
    border-radius: 30px;
    font-weight: 600;
}

/* Account Dropdown */
.sf-account-dropdown {
    position: relative;
}
.sf-dropdown-menu {
    position: absolute;
    top: 100%;
    right: 0;
    margin-top: 0.75rem;
    min-width: 280px;
    background: #fff;
    border-radius: var(--sf-radius);
    box-shadow: 0 12px 28px -6px rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(0, 0, 0, 0.08);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.25s cubic-bezier(0.16, 0.8, 0.42, 1);
    z-index: 1000;
}
.sf-dropdown-menu.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.sf-dropdown-menu::before {
    content: '';
    position: absolute;
    top: -6px;
    right: 12px;
    width: 12px;
    height: 12px;
    background: #fff;
    border-left: 1px solid rgba(0, 0, 0, 0.08);
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    transform: rotate(45deg);
}
.sf-dropdown-header {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    display: flex;
    align-items: center;
    gap: 0.85rem;
}
.sf-dropdown-header i {
    font-size: 2.2rem;
    color: var(--sf-accent);
}
.sf-dropdown-header div {
    flex: 1;
    min-width: 0;
}
.sf-dropdown-header strong {
    display: block;
    font-size: 0.95rem;
    font-weight: 600;
    color: #1a1a1a;
    margin-bottom: 0.2rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.sf-dropdown-header small {
    display: block;
    font-size: 0.75rem;
    color: #6c757d;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.sf-dropdown-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1.25rem;
    color: #495057;
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 500;
    transition: all 0.2s ease;
}
.sf-dropdown-item i {
    font-size: 1.1rem;
    color: var(--sf-accent);
    width: 20px;
    text-align: center;
}
.sf-dropdown-item:hover {
    background: var(--sf-surface);
    color: var(--sf-accent);
}
.sf-dropdown-divider {
    height: 1px;
    background: rgba(0, 0, 0, 0.06);
    margin: 0.5rem 0;
}

/* Category Nav */
.sf-category-nav {
    background: var(--sf-surface);
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}
.sf-light .sf-category-nav {
    border-top: 1px solid rgba(0, 0, 0, 0.06);
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}
.sf-category-nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
}
.sf-category-nav li a {
    display: block;
    padding: 0.85rem 1.1rem;
    font-size: 0.85rem;
    font-weight: 500;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    color: var(--sf-text-dim);
    position: relative;
    transition: var(--sf-transition);
}
.sf-category-nav li a:hover,
.sf-category-nav li.active a {
    color: var(--sf-accent);
}
.sf-category-nav li a:after {
    content: "";
    position: absolute;
    left: 1.1rem;
    right: 1.1rem;
    bottom: 0.45rem;
    height: 2px;
    border-radius: 2px;
    background: var(--sf-gradient-accent);
    transform: scaleX(0);
    transform-origin: left;
    transition: var(--sf-transition);
}
.sf-category-nav li a:hover:after,
.sf-category-nav li.active a:after {
    transform: scaleX(1);
}

/* Hero Slider (placeholder structure) */
/* Old split hero retained for reference but we favor full-screen carousel */
.sf-hero {
    position: relative;
    min-height: 480px;
    background: radial-gradient(circle at 30% 30%, #1d2f28, #0d1513);
    display: flex;
    align-items: stretch;
    overflow: hidden;
}
.sf-hero .sf-hero-content {
    width: 50%;
    padding: 4.5rem 3.5rem 4rem 5%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.sf-hero .sf-hero-content h1 {
    font-size: clamp(2.4rem, 4.8vw, 3.65rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: 0.5px;
    background: linear-gradient(135deg, #e9d386, #d8b64c 45%, #a98212 80%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}
.sf-hero .sf-hero-content p {
    font-size: 1.05rem;
    max-width: 540px;
    margin-top: 1.2rem;
    color: var(--sf-text-dim);
}
.sf-cta-group {
    margin-top: 2.2rem;
    display: flex;
    gap: 1rem;
}
.sf-btn {
    border: none;
    cursor: pointer;
    font-weight: 600;
    letter-spacing: 0.4px;
    padding: 0.85rem 2rem;
    font-size: 0.9rem;
    border-radius: 6px;
    position: relative;
    overflow: hidden;
    transition: var(--sf-transition);
    text-decoration: none;
    display: inline-block;
}
.sf-btn-primary {
    background: var(--sf-accent);
    color: #fff;
}
.sf-btn-primary:hover {
    background: var(--sf-accent-hover);
    transform: translateY(-2px);
    box-shadow: 0 8px 20px -6px rgba(var(--sf-accent-rgb), 0.5);
}
.sf-btn-outline {
    background: transparent;
    color: var(--sf-accent);
    border: 2px solid var(--sf-accent);
}
.sf-btn-outline:hover {
    background: var(--sf-accent);
    color: #fff;
    border-color: var(--sf-accent);
}
.sf-hero .sf-hero-media {
    width: 50%;
    position: relative;
}
.sf-hero .slide-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: brightness(0.82) contrast(1.05);
    animation: fadeSlide 1.1s ease;
    transition: opacity 0.9s ease;
}
@keyframes fadeSlide {
    from {
        opacity: 0;
        transform: scale(1.05);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

/* Full-screen hero carousel */
.sf-hero-full {
    position: relative;
    width: 100%;
    height: 75vh;
    min-height: 520px;
}
.sf-hero-full .carousel,
.sf-hero-full .carousel-inner,
.sf-hero-full .carousel-item {
    height: 100%;
}
.sf-hero-full .carousel-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.sf-hero-full .carousel-caption {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
    max-width: 860px;
    padding: 3rem 2.5rem;
    background: rgba(255, 255, 255, 0.92);
    border-radius: 8px;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
}
.sf-hero-full .carousel-caption h5 {
    font-size: clamp(2.2rem, 4.8vw, 3.8rem);
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    line-height: 1.2;
    color: #1a1d18;
    margin-bottom: 1rem;
}
.sf-hero-full .carousel-caption p {
    font-size: 0.95rem;
    max-width: 640px;
    margin: 0 auto 1.5rem;
    color: #3a4550;
    letter-spacing: 0.3px;
    line-height: 1.6;
}
.sf-hero-full .carousel-caption .sf-cta-group {
    display: flex;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
}
.sf-hero-full .carousel-indicators {
    bottom: 5px;
}
.sf-hero-full .carousel-indicators [data-bs-target] {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.25);
    border: none;
    margin: 0 5px;
}
.sf-hero-full .carousel-indicators .active {
    background: var(--sf-accent);
}
.sf-hero-full .carousel-control-prev,
.sf-hero-full .carousel-control-next {
    width: auto;
}
.sf-hero-full .carousel-control-prev-icon,
.sf-hero-full .carousel-control-next-icon {
    width: 50px;
    height: 50px;
    background-color: rgba(255, 255, 255, 0.85);
    border-radius: 50%;
    background-size: 50%;
    filter: none;
}
.sf-hero-full .carousel-control-prev-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23333'%3e%3cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/%3e%3c/svg%3e");
}
.sf-hero-full .carousel-control-next-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23333'%3e%3cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}

/* Section Headings */
.sf-section {
    padding: 3.5rem 0 2.5rem;
    position: relative;
}
.sf-section-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 1.75rem;
}
.sf-section-header h2 {
    font-size: 1.65rem;
    font-weight: 600;
    letter-spacing: 0.6px;
    margin: 0;
    position: relative;
}
.sf-section-header h2:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -6px;
    width: 56px;
    height: 3px;
    background: var(--sf-gradient-accent);
    border-radius: 3px;
}
.sf-section-header .desc {
    flex: 1 1 300px;
    font-size: 0.85rem;
    color: var(--sf-text-dim);
    max-width: 520px;
}
.sf-view-all {
    font-size: 0.75rem;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.7px;
    color: var(--sf-accent);
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}
.sf-view-all:hover {
    color: var(--sf-accent-alt);
}

/* Product Grid */
.sf-products {
    display: grid;
    gap: 1.25rem;
    grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 1200px) {
    .sf-products {
        grid-template-columns: repeat(4, 1fr);
    }
}
@media (max-width: 960px) {
    .sf-products {
        grid-template-columns: repeat(3, 1fr);
    }
}
@media (max-width: 680px) {
    .sf-products {
        grid-template-columns: repeat(2, 1fr);
    }
}
.sf-product-card {
    background: #ffffff;
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: var(--sf-radius);
    padding: 0.85rem 0.85rem 1.05rem;
    position: relative;
    display: flex;
    flex-direction: column;
    transition: var(--sf-transition);
    overflow: hidden;
}

.sf-product-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--sf-shadow);
}
/* New product card structure */
.sf-card-media {
    position: relative;
}
.sf-card-media .thumb {
    display: block;
    width: 100%;
    aspect-ratio: 3/4;
    background: #ffffff;
    border-radius: var(--sf-radius);
    overflow: hidden;
}
.sf-card-media .thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: var(--sf-transition);
}
.sf-product-card:hover .sf-card-media .thumb img {
    transform: scale(1.06);
}

.sf-card-actions {
    position: absolute;
    top: 12px;
    right: 12px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    z-index: 2;
}
.sf-card-actions .icon {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.96);
    color: #1f2937;
    border: 1px solid rgba(0, 0, 0, 0.06);
    box-shadow: var(--sf-shadow-sm);
    transition: var(--sf-transition);
}
.sf-card-actions .icon:hover {
    background: var(--sf-accent);
    color: #fff;
    border-color: var(--sf-accent);
    transform: translateY(-2px);
}

.sf-quick-add {
    width: 100%;
    margin-top: 0.75rem;
    padding: 0.6rem 1rem;
    background: transparent;
    color: var(--sf-accent);
    border: 2px solid var(--sf-accent);
    border-radius: 4px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 0.8rem;
    transition: var(--sf-transition);
}
.sf-quick-add:hover {
    background: var(--sf-accent);
    color: #fff;
}

.sf-card-body {
    text-align: center;
    padding-top: 0.85rem;
}
.sf-card-body .title {
    font-size: 0.92rem;
    font-weight: 600;
    margin: 0 0 0.4rem;
    min-height: 2.2em;
    line-height: 1.2;
}
.sf-card-body .price {
    font-size: 0.95rem;
    font-weight: 700;
    color: #111827;
    margin-bottom: 0.5rem;
}
.sf-card-body .installment {
    color: #4b5563;
    line-height: 1.35;
    margin-bottom: 0.75rem;
}
.sf-card-body .installment .method {
    display: inline-block;
    font-size: 0.72rem;
    background: #e5f3ee;
    color: var(--sf-accent);
    border: 1px solid rgba(var(--sf-accent-rgb), 0.25);
    padding: 0.1rem 0.35rem;
    border-radius: 6px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.sf-card-body .sizes {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}
.sf-card-body .size-btn {
    background: transparent;
    color: #111827;
    border: 1px solid rgba(0, 0, 0, 0.14);
    padding: 0.45rem 0.7rem;
    font-size: 0.8rem;
    border-radius: 6px;
    transition: var(--sf-transition);
}
.sf-card-body .size-btn:hover {
    border-color: var(--sf-accent);
    color: var(--sf-accent);
}

/* Newsletter */
.sf-newsletter {
    background: var(--sf-surface-alt);
    padding: 3rem 2.2rem;
    border-radius: var(--sf-radius-lg);
    box-shadow: var(--sf-shadow);
    position: relative;
    overflow: hidden;
}
.sf-newsletter h3 {
    font-size: 1.45rem;
    margin-bottom: 0.85rem;
    font-weight: 600;
}
.sf-newsletter p {
    font-size: 0.85rem;
    color: var(--sf-text-dim);
    max-width: 560px;
}
.sf-newsletter form {
    margin-top: 1.4rem;
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}
.sf-newsletter input {
    flex: 1 1 240px;
    background: var(--sf-surface);
    border: 1px solid rgba(255, 255, 255, 0.08);
    padding: 0.75rem 1rem;
    color: var(--sf-text);
    font-size: 0.85rem;
    border-radius: var(--sf-radius);
}
.sf-newsletter input:focus {
    outline: none;
    border-color: var(--sf-accent);
    box-shadow: 0 0 0 3px rgba(var(--sf-accent-rgb), 0.25);
}

/* Footer */
.sf-footer {
    background: #0b120f;
    margin-top: 3rem;
    padding: 4rem 0 2.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    font-size: 0.8rem;
}
.sf-light .sf-footer {
    background: #f7fbf9;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}
.sf-footer .cols {
    display: grid;
    gap: 2.25rem;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}
.sf-footer h4 {
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.6px;
    text-transform: uppercase;
    margin-bottom: 1rem;
    position: relative;
}
.sf-footer h4:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -6px;
    width: 34px;
    height: 2px;
    background: var(--sf-gradient-accent);
    border-radius: 2px;
}
.sf-footer ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.sf-footer li {
    margin-bottom: 0.55rem;
}
.sf-footer a {
    color: var(--sf-text-dim);
    text-decoration: none;
    transition: var(--sf-transition);
}
.sf-footer a:hover {
    color: var(--sf-accent);
}
.sf-footer .brand {
    max-width: 200px;
    margin-bottom: 0.9rem;
}
.sf-under {
    margin-top: 3rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    padding-top: 1.25rem;
    align-items: center;
}
.sf-light .sf-under {
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}
.sf-under p {
    margin: 0;
    font-size: 0.7rem;
    color: var(--sf-text-dim);
}
.sf-social {
    display: flex;
    gap: 0.55rem;
}
.sf-social a {
    width: 34px;
    height: 34px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sf-surface);
    border-radius: 50%;
    color: var(--sf-text-dim);
    font-size: 0.85rem;
    border: 1px solid rgba(255, 255, 255, 0.06);
    transition: var(--sf-transition);
}
.sf-light .sf-social a {
    border-color: rgba(0, 0, 0, 0.06);
}
.sf-social a:hover {
    background: var(--sf-accent);
    color: #1a1d18;
    transform: translateY(-3px);
}

/* Mobile category nav toggle */
.sf-cat-toggle {
    display: none;
    background: var(--sf-surface);
    border: 1px solid rgba(0, 0, 0, 0.06);
    color: var(--sf-text);
    border-radius: var(--sf-radius);
    padding: 0.6rem 0.8rem;
    font-weight: 600;
}
@media (max-width: 860px) {
    .sf-cat-toggle {
        display: inline-flex;
        align-items: center;
        gap: 0.5rem;
    }
    .sf-category-nav {
        display: none;
    }
    .sf-category-nav.expanded {
        display: block;
    }
    .sf-category-nav ul {
        flex-direction: column;
    }
}

/* Category Grid (Shop by Category) */
.sf-category-grid {
    display: grid;
    gap: 1.25rem;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.sf-category-card {
    position: relative;
    aspect-ratio: 4/3;
    border-radius: var(--sf-radius);
    overflow: hidden;
    transition: var(--sf-transition);
}
.sf-category-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: var(--sf-transition);
}
.sf-category-card:hover img {
    transform: scale(1.08);
}
.sf-category-card .overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.2));
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 1.5rem;
}
.sf-category-card h3 {
    font-size: 1.3rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.sf-category-card .sf-btn {
    font-size: 0.75rem;
    padding: 0.6rem 1.2rem;
    align-self: flex-start;
}

/* Product Detail Page */
.sf-breadcrumbs { padding:1rem 0; font-size:.85rem; color: var(--sf-text-dim); border-bottom:1px solid rgba(0,0,0,.06); }
.sf-breadcrumbs a { color: var(--sf-accent); text-decoration:none; }
.sf-breadcrumbs a:hover { text-decoration:underline; }

.sf-product-detail { padding:2.5rem 0; }
.product-grid { display:grid; grid-template-columns:1fr 1fr; gap:3rem; margin-bottom:3rem; }
@media (max-width:960px){ .product-grid { grid-template-columns:1fr; gap:2rem; } }

.product-gallery .main-image { background:#f8f9fa; border-radius: var(--sf-radius); overflow:hidden; margin-bottom:1rem; }
.product-gallery .main-image img { width:100%; height:auto; display:block; }
.product-gallery .thumbnail-list { display:flex; gap:.75rem; }
.product-gallery .thumb { width:80px; height:80px; border:2px solid transparent; border-radius: var(--sf-radius); overflow:hidden; cursor:pointer; transition: var(--sf-transition); }
.product-gallery .thumb:hover, .product-gallery .thumb.active { border-color: var(--sf-accent); }
.product-gallery .thumb img { width:100%; height:100%; object-fit:cover; }

.product-info .vendor { font-size:.85rem; color: var(--sf-text-dim); margin-bottom:.5rem; }
.product-info .vendor a { color: var(--sf-accent); text-decoration:none; }
.product-title { font-size:2rem; font-weight:700; margin:0 0 1rem; line-height:1.2; }
.product-meta { display:flex; gap:1.5rem; font-size:.85rem; color: var(--sf-text-dim); margin-bottom:1rem; padding-bottom:1rem; border-bottom:1px solid rgba(0,0,0,.06); }
.product-meta .stock.in-stock strong { color: var(--sf-success); }
.product-price { margin-bottom:1rem; }
.product-price .price { font-size:1.8rem; font-weight:700; color:#111827; }
.stock-alert { background:#fff3cd; color:#856404; padding:.75rem 1rem; border-radius: var(--sf-radius); font-size:.9rem; margin-bottom:1.5rem; display:flex; align-items:center; gap:.5rem; }

.option-group { margin-bottom:1.5rem; }
.option-group label { display:block; font-weight:600; margin-bottom:.75rem; }
.size-options { display:flex; gap:.5rem; flex-wrap:wrap; }
.size-opt { background: transparent; color:#111827; border:1px solid rgba(0,0,0,.2); padding:.6rem 1rem; font-size:.9rem; border-radius:6px; transition: var(--sf-transition); min-width:50px; }
.size-opt:hover, .size-opt.active { border-color: var(--sf-accent); background: var(--sf-accent); color:#fff; }

.quantity-group { margin-bottom:1.5rem; }
.quantity-group label { display:block; font-weight:600; margin-bottom:.75rem; }
.qty-control { display:flex; align-items:center; gap:.5rem; }
.qty-btn { width:40px; height:40px; background: var(--sf-surface); border:1px solid rgba(0,0,0,.1); font-size:1.2rem; font-weight:600; border-radius:6px; transition: var(--sf-transition); }
.qty-btn:hover { background: var(--sf-accent); color:#fff; border-color: var(--sf-accent); }
.qty-control input { width:80px; height:40px; text-align:center; border:1px solid rgba(0,0,0,.1); border-radius:6px; font-size:1rem; font-weight:600; }

.product-actions { display:flex; gap:1rem; margin-bottom:1rem; }
.btn-add-cart { flex:1; background: var(--sf-accent); color:#fff; padding:1rem 2rem; font-size:1rem; font-weight:700; border:none; border-radius:6px; text-transform:uppercase; letter-spacing:.05em; transition: var(--sf-transition); }
.btn-add-cart:hover { background: var(--sf-accent-hover); transform:translateY(-2px); box-shadow: var(--sf-shadow); }
.btn-wishlist { width:56px; height:56px; display:flex; align-items:center; justify-content:center; background: transparent; border:2px solid var(--sf-accent); color: var(--sf-accent); border-radius:6px; font-size:1.2rem; transition: var(--sf-transition); }
.btn-wishlist:hover { background: var(--sf-accent); color:#fff; }

.btn-buy-now { width:100%; background: transparent; color: var(--sf-accent); border:2px solid var(--sf-accent); padding:1rem 2rem; font-size:1rem; font-weight:700; border-radius:6px; text-transform:uppercase; letter-spacing:.05em; margin-bottom:2rem; transition: var(--sf-transition); }
.btn-buy-now:hover { background: var(--sf-accent); color:#fff; }

.product-features { margin-bottom:2rem; }
.feature-item { display:flex; gap:1rem; padding:1rem 0; border-bottom:1px solid rgba(0,0,0,.06); }
.feature-item:last-child { border-bottom:none; }
.feature-item i { font-size:1.5rem; color: var(--sf-accent); margin-top:.2rem; }
.feature-item strong { display:block; margin-bottom:.25rem; }
.feature-item p { margin:0; font-size:.85rem; color: var(--sf-text-dim); }
.feature-item a { color: var(--sf-accent); }

.product-share { display:flex; align-items:center; gap:1rem; padding-top:1rem; border-top:1px solid rgba(0,0,0,.06); }
.product-share strong { font-weight:600; }
.share-btn { width:38px; height:38px; display:flex; align-items:center; justify-content:center; background: var(--sf-surface); border-radius:50%; color: var(--sf-text); transition: var(--sf-transition); }
.share-btn:hover { background: var(--sf-accent); color:#fff; transform:translateY(-2px); }

.product-tabs { margin-bottom:3rem; }
.tab-nav { list-style:none; margin:0; padding:0; display:flex; gap:0; border-bottom:2px solid rgba(0,0,0,.1); }
.tab-nav li a { display:block; padding:1rem 2rem; font-weight:600; text-transform:uppercase; letter-spacing:.05em; color: var(--sf-text-dim); text-decoration:none; border-bottom:3px solid transparent; margin-bottom:-2px; transition: var(--sf-transition); }
.tab-nav li.active a, .tab-nav li a:hover { color: var(--sf-accent); border-bottom-color: var(--sf-accent); }
.tab-content { padding:2rem 0; }
.tab-pane { display:none; }
.tab-pane.active { display:block; }
.tab-pane h3 { font-size:1.3rem; font-weight:600; margin-bottom:1rem; }
.tab-pane ul { padding-left:1.5rem; }
.tab-pane li { margin-bottom:.5rem; }

.related-section { margin-top:3rem; padding-top:3rem; border-top:1px solid rgba(0,0,0,.06); }
.related-section h2 { font-size:1.8rem; font-weight:600; text-align:center; margin-bottom:2rem; text-transform:uppercase; letter-spacing:.05em; }

/* Collection Page */
.sf-collection-page { padding:2rem 0; }
.collection-layout { display:grid; grid-template-columns:280px 1fr; gap:2.5rem; }
@media (max-width:960px){ .collection-layout { grid-template-columns:1fr; } }

.collection-sidebar { background: var(--sf-surface); border-radius: var(--sf-radius); padding:1.5rem; position:sticky; top:1rem; max-height:calc(100vh - 2rem); overflow-y:auto; }
@media (max-width:960px){ 
    .collection-sidebar { position:fixed; left:0; top:0; bottom:0; width:300px; z-index:1000; background:#fff; transform:translateX(-100%); transition: var(--sf-transition); box-shadow: var(--sf-shadow-lg); max-height:100vh; }
    .collection-sidebar.active { transform:translateX(0); }
}
.mobile-filter-header { display:none; justify-content:space-between; align-items:center; padding-bottom:1rem; border-bottom:1px solid rgba(0,0,0,.06); margin-bottom:1rem; }
@media (max-width:960px){ .mobile-filter-header { display:flex; } }
.mobile-filter-header h3 { margin:0; font-size:1.2rem; font-weight:600; }
.close-filters { background:none; border:none; font-size:2rem; line-height:1; color: var(--sf-text-dim); }

.filter-group { margin-bottom:2rem; padding-bottom:1.5rem; border-bottom:1px solid rgba(0,0,0,.06); }
.filter-group:last-child { border-bottom:none; }
.filter-title { font-size:.85rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; margin-bottom:1rem; }
.filter-options { display:flex; flex-direction:column; gap:.75rem; }
.filter-checkbox { display:flex; align-items:center; gap:.5rem; cursor:pointer; font-size:.9rem; }
.filter-checkbox input { width:18px; height:18px; cursor:pointer; }
.filter-checkbox:hover { color: var(--sf-accent); }

.price-range { display:flex; flex-direction:column; gap:.75rem; }
.price-inputs { display:flex; align-items:center; gap:.5rem; }
.price-input { flex:1; padding:.5rem; border:1px solid rgba(0,0,0,.1); border-radius:4px; font-size:.85rem; }

.collection-main { flex:1; }
.collection-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:2rem; padding-bottom:1.5rem; border-bottom:1px solid rgba(0,0,0,.06); flex-wrap:wrap; gap:1rem; }
.collection-info h1 { font-size:2rem; font-weight:600; margin:0 0 .5rem; text-transform:uppercase; letter-spacing:.05em; }
.product-count { color: var(--sf-text-dim); font-size:.9rem; margin:0; }

.collection-controls { display:flex; align-items:center; gap:1rem; }
.mobile-filter-btn { display:none; background: var(--sf-accent); color:#fff; border:none; padding:.6rem 1.2rem; border-radius:4px; font-weight:600; }
@media (max-width:960px){ .mobile-filter-btn { display:block; } }

.sort-dropdown { display:flex; align-items:center; gap:.75rem; }
.sort-dropdown label { font-size:.85rem; font-weight:600; white-space:nowrap; }
.sort-dropdown select { padding:.5rem 1rem; border:1px solid rgba(0,0,0,.1); border-radius:4px; font-size:.85rem; background:#fff; }

.collection-pagination { margin-top:3rem; display:flex; justify-content:center; }
.collection-pagination .pagination { gap:.5rem; }
.collection-pagination .page-link { color: var(--sf-accent); border:1px solid rgba(0,0,0,.1); padding:.5rem 1rem; border-radius:4px; }
.collection-pagination .page-item.active .page-link { background: var(--sf-accent); color:#fff; border-color: var(--sf-accent); }
.collection-pagination .page-link:hover { background: var(--sf-surface); }

/* Utilities */
.sf-container {
    width: 100%;
    max-width: 1340px;
    margin: 0 auto;
    padding: 0 1.35rem;
}
.mt-2 {
    margin-top: 0.5rem;
}
.mt-3 {
    margin-top: 1rem;
}
.mb-2 {
    margin-bottom: 0.5rem;
}
.mb-3 {
    margin-bottom: 1rem;
}
.mb-4 {
    margin-bottom: 1.35rem;
}
.pt-2 {
    padding-top: 0.5rem;
}
.pb-2 {
    padding-bottom: 0.5rem;
}
.py-4 {
    padding-top: 2rem;
    padding-bottom: 2rem;
}
.text-accent {
    color: var(--sf-accent);
}

/* Responsive */
@media (max-width: 1080px) {
    .sf-hero {
        flex-direction: column;
        min-height: unset;
    }
    .sf-hero .sf-hero-content,
    .sf-hero .sf-hero-media {
        width: 100%;
    }
    .sf-hero .sf-hero-content {
        padding: 3.5rem 2rem 3rem;
    }
}
@media (max-width: 860px) {
    .sf-header .sf-top {
        flex-wrap: wrap;
    }
    .sf-search {
        order: 3;
        width: 100%;
    }
    .sf-icons {
        margin-left: auto;
    }
    .sf-category-nav ul {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    .sf-category-nav li a {
        white-space: nowrap;
    }
    .sf-products {
        grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    }
}
@media (max-width: 580px) {
    .sf-hero .sf-hero-content h1 {
        font-size: 2.3rem;
    }
    .sf-cta-group {
        flex-wrap: wrap;
    }
}
