
    .category-page.svelte-3qy6mm {
        --app-primary: var(--c-primary, #113511);
        --app-accent: #ffcc00; /* AppColors.accentYellow */
        --app-bg: #f8f9fa; /* AppColors.background */
        min-height: 100vh;
        background: var(--app-bg);
        display: flex;
        flex-direction: column;
    }

    /* Top Curved Header */
    .app-header-container.svelte-3qy6mm {
        position: sticky;
        top: 0;
        z-index: 40;
        background: var(--app-primary);
        padding-top: max(8px, env(safe-area-inset-top));
    }

    .app-header.svelte-3qy6mm {
        padding: 4px 4px 16px 4px; /* Bottom padding creates space before curve */
    }

    .header-row.svelte-3qy6mm {
        display: flex;
        align-items: center;
    }

    .back-btn.svelte-3qy6mm {
        background: transparent;
        border: none;
        color: var(--app-accent);
        width: 44px;
        height: 44px;
        display: flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        flex-shrink: 0;
    }

    .main-tabs-scroll.svelte-3qy6mm {
        display: flex;
        overflow-x: auto;
        flex: 1;
        gap: 16px;
        padding: 0 12px;
        scrollbar-width: none;
        align-items: center;
    }

    .main-tabs-scroll.svelte-3qy6mm::-webkit-scrollbar {
        display: none;
    }

    .main-tab.svelte-3qy6mm {
        background: transparent;
        border: none;
        color: white;
        font-size: 18px;
        font-weight: 600;
        white-space: nowrap;
        cursor: pointer;
        padding: 8px 4px;
        position: relative;
        opacity: 0.8;
        transition: all 0.2s;
    }

    .main-tab.active.svelte-3qy6mm {
        color: var(--app-accent);
        font-weight: 700;
        opacity: 1;
    }

    .main-tab.active.svelte-3qy6mm::after {
        content: "";
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        height: 3px;
        background-color: var(--app-accent);
        border-radius: 3px 3px 0 0;
    }

    .main-tab-shimmer.svelte-3qy6mm {
        width: 80px;
        height: 30px;
        background: rgba(255, 255, 255, 0.2);
        border-radius: 12px;
        animation: svelte-3qy6mm-pulse 1.5s infinite;
    }

    /* Overlapping curve magic */
    .header-curve.svelte-3qy6mm {
        position: absolute;
        bottom: -1px;
        left: 0;
        right: 0;
        height: 24px;
        background: var(--app-bg);
        border-radius: 24px 24px 0 0;
        box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.05); /* Optional subtile inner shadow equivalent */
    }

    .content-wrapper.svelte-3qy6mm {
        flex: 1;
        display: flex;
        flex-direction: column;
        position: relative;
        z-index: 10;
        background: var(--app-bg); /* Continuous background below curve */
    }

    /* Subcategories Pill Bar */
    .sub-tabs-container.svelte-3qy6mm {
        position: sticky;
        top: 70px; /* Needs to sit right below the curved header */
        z-index: 39;
        background: var(--app-bg);
        box-shadow: 0 4px 10px rgba(0, 0, 0, 0.03);
    }

    /* Magic to ensure sticky works correctly against the fixed header size. 
       Usually JS tracks header height, but CSS sticky is relative to scrolling container. */

    .sub-tabs-scroll.svelte-3qy6mm {
        display: flex;
        gap: 8px;
        overflow-x: auto;
        padding: 12px 16px;
        scrollbar-width: none;
    }

    .sub-tabs-scroll.svelte-3qy6mm::-webkit-scrollbar {
        display: none;
    }

    .sub-tab.svelte-3qy6mm {
        white-space: nowrap;
        padding: 8px 16px;
        border-radius: 12px;
        background: #ebebeb;
        color: var(--app-primary);
        border: none;
        font-size: 14px;
        font-weight: 600;
        cursor: pointer;
        transition: all 0.2s;
    }

    .sub-tab.active.svelte-3qy6mm {
        background: var(--app-accent); /* #FFCC00 */
        font-weight: 700;
    }

    /* Categories Flow */
    .products-scroll-area.svelte-3qy6mm {
        padding-bottom: 100px; /* Floating buttons space */
    }

    .subcat-section.svelte-3qy6mm {
        scroll-margin-top: 140px; /* Avoid header occlusion when jumped */
    }

    .subcat-header.svelte-3qy6mm {
        padding: 24px 16px 12px 16px;
        background: var(--app-bg);
    }

    .subcat-header.svelte-3qy6mm h2:where(.svelte-3qy6mm) {
        font-size: 20px;
        font-weight: 800;
        color: var(--app-primary);
        margin: 0;
    }

    .grid-padding.svelte-3qy6mm {
        padding: 0 8px; /* Slightly less padding so cards touch edges like grid */
    }

    /* Error & Loading States */
    .loading-state.svelte-3qy6mm {
        padding: 20px;
    }

    .skeleton-pill-row.svelte-3qy6mm {
        display: flex;
        gap: 8px;
        margin-bottom: 24px;
    }

    .skeleton-pill.svelte-3qy6mm {
        width: 80px;
        height: 32px;
        background: #e0e0e0;
        border-radius: 12px;
        animation: svelte-3qy6mm-pulse 1.5s infinite;
    }

    .skeleton-grid.svelte-3qy6mm {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
        gap: 16px;
    }

    .skeleton-card.svelte-3qy6mm {
        height: 200px;
        background: #f0f0f0;
        border-radius: 16px;
        animation: svelte-3qy6mm-pulse 1.5s infinite;
    }

    .empty-state.svelte-3qy6mm {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        padding: 80px 20px;
        color: #999;
    }

    .empty-state.svelte-3qy6mm p:where(.svelte-3qy6mm) {
        font-size: 18px;
        font-weight: 600;
        margin: 16px 0 24px;
        color: var(--app-primary);
    }

    .retry-btn.svelte-3qy6mm {
        background: var(--app-primary);
        color: white;
        border: none;
        padding: 10px 24px;
        border-radius: 8px;
        font-weight: 600;
        cursor: pointer;
    }

    @keyframes svelte-3qy6mm-pulse {
        0%,
        100% {
            opacity: 1;
        }
        50% {
            opacity: 0.6;
        }
    }
