/* Discover Premium Design System - Compact Modern Edition
 * ================================================
 * Imports variables.css for all design tokens
 * Follows ifinsta Design System v1.0 specifications
 * Optimized for information density and screen real estate
 */

/* Import design system variables (must be loaded first) */
@import url("variables.87da44d63365.css");

/* ==========================================================================
   LEGACY VARIABLE MAPPINGS (for backward compatibility)
   Maps old --discover-* variables to --ifinsta-* system variables
   ========================================================================== */
:root {
    /* Primary Colors - using design system indigo */
    --discover-primary: var(--ifinsta-primary-600);
    --discover-primary-soft: var(--ifinsta-primary-alpha-08);

    /* Background Colors */
    --discover-bg: var(--ifinsta-bg);
    --discover-bg-alt: var(--ifinsta-bg-secondary);

    /* Text Colors */
    --discover-text: var(--ifinsta-text);
    --discover-text-muted: var(--ifinsta-text-muted);

    /* Border Colors */
    --discover-border: var(--ifinsta-border);

    /* Glassmorphism */
    --discover-glass-bg: var(--ifinsta-glass-bg);
    --discover-glass-border: var(--ifinsta-glass-border);

    /* Typography */
    --discover-font: var(--ifinsta-font-family);

    /* Shadows - using system shadows */
    --discover-shadow-sm: var(--ifinsta-shadow-xs);
    --discover-shadow: var(--ifinsta-shadow-sm);
    --discover-shadow-lg: var(--ifinsta-shadow-md);
    --discover-shadow-premium: var(--ifinsta-shadow-lg);

    /* Border Radius - compact design */
    --discover-radius: var(--ifinsta-radius-md);
    --discover-radius-lg: var(--ifinsta-radius-lg);
    --discover-radius-full: var(--ifinsta-radius-full);

    /* Breakpoints - reference system breakpoints */
    --discover-mobile: var(--ifinsta-bp-sm);
    --discover-tablet: var(--ifinsta-bp-lg);

    /* Compact Spacing Scale */
    --discover-space-xs: var(--ifinsta-space-1);
    --discover-space-sm: var(--ifinsta-space-2);
    --discover-space-md: var(--ifinsta-space-3);
    --discover-space-lg: var(--ifinsta-space-4);
    --discover-space-xl: var(--ifinsta-space-6);

    /* Compact Grid */
    --discover-grid-gap: var(--ifinsta-grid-gap-sm);
    --discover-card-padding: var(--ifinsta-card-padding-sm);
    --discover-section-gap: var(--ifinsta-section-padding-sm);
}

/* ==========================================================================
   BASE STYLES - Compact Foundation
   ========================================================================== */
.discover-body {
    font-family: var(--discover-font);
    color: var(--discover-text);
    background: var(--ifinsta-bg);
    line-height: var(--ifinsta-leading-normal);
    word-wrap: break-word;
    overflow-wrap: break-word;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    min-height: 100%;
    padding-bottom: var(--ifinsta-space-12);
}

.discover-container {
    max-width: var(--ifinsta-content-max-width);
    margin: 0 auto;
    padding: 0 var(--ifinsta-content-padding);
}

@media (max-width: 640px) {
    .discover-container {
        padding: 0 var(--ifinsta-space-4);
    }
}

/* ==========================================================================
   GLASSMORPHISM - Subtle Elevation
   ========================================================================== */
.discover-glass {
    background: var(--discover-glass-bg);
    backdrop-filter: var(--ifinsta-blur-md);
    -webkit-backdrop-filter: var(--ifinsta-blur-md);
    border: 1px solid var(--discover-glass-border);
    box-shadow: var(--ifinsta-shadow-sm);
}

/* ==========================================================================
   ANIMATIONS - Windows 11 Style Micro-Animations
   ========================================================================== */
@keyframes discover-fade-in {
    from {
        opacity: 0;
        transform: translateY(var(--ifinsta-space-2));
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes discover-fade-in-up {
    from {
        opacity: 0;
        transform: translateY(var(--ifinsta-space-3));
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes discover-scale-in {
    from {
        opacity: 0;
        transform: scale(0.96);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

.discover-animate-fade {
    animation: discover-fade-in var(--ifinsta-duration-slow) var(--ifinsta-ease-smooth) forwards;
}

.discover-animate-fade-up {
    animation: discover-fade-in-up var(--ifinsta-duration-medium) var(--ifinsta-ease-smooth) forwards;
}

.discover-animate-scale {
    animation: discover-scale-in var(--ifinsta-duration-normal) var(--ifinsta-ease-smooth) forwards;
}

/* Staggered animation delays for lists */
.discover-animate-fade:nth-child(1) {
    animation-delay: 0ms;
}

.discover-animate-fade:nth-child(2) {
    animation-delay: 40ms;
}

.discover-animate-fade:nth-child(3) {
    animation-delay: 80ms;
}

.discover-animate-fade:nth-child(4) {
    animation-delay: 120ms;
}

.discover-animate-fade:nth-child(5) {
    animation-delay: 160ms;
}

.discover-animate-fade:nth-child(6) {
    animation-delay: 200ms;
}

/* ==========================================================================
   HERO SECTION - Compact Premium Header
   ========================================================================== */
.discover-hero {
    position: relative;
    padding: var(--ifinsta-space-8) 0 var(--ifinsta-space-7);
    background:
        var(--ifinsta-bg-aurora-1),
        var(--ifinsta-bg-aurora-2),
        var(--ifinsta-bg-main);
    overflow: hidden;
    border-bottom: 1px solid var(--ifinsta-border-light);
}

@media (max-width: 768px) {
    .discover-hero {
        padding: var(--ifinsta-section-padding-sm) 0;
    }
}

.discover-hero__content {
    text-align: center;
    max-width: 680px;
    margin: 0 auto;
}

.discover-hero__title {
    font-size: clamp(var(--ifinsta-text-2xl), 4vw, var(--ifinsta-text-4xl));
    font-weight: var(--ifinsta-font-bold);
    letter-spacing: -0.02em;
    margin-bottom: var(--ifinsta-space-3);
    color: var(--discover-text);
    line-height: var(--ifinsta-leading-tight);
}

.discover-hero__subtitle {
    font-size: var(--ifinsta-text-base);
    color: var(--discover-text-muted);
    margin-bottom: var(--ifinsta-space-5);
    line-height: var(--ifinsta-leading-normal);
}

/* ==========================================================================
   SEARCH BAR - Compact Material Design
   ========================================================================== */
.discover-search {
    max-width: 480px;
    margin: 0 auto;
    position: relative;
}

.discover-search__input {
    width: 100%;
    padding: var(--ifinsta-space-3) var(--ifinsta-space-4) var(--ifinsta-space-3) var(--ifinsta-space-10);
    border-radius: var(--ifinsta-radius-full);
    border: 1px solid var(--ifinsta-border);
    background: var(--ifinsta-surface);
    font-size: var(--ifinsta-text-sm);
    font-family: var(--discover-font);
    transition: var(--ifinsta-input-transition);
    height: var(--ifinsta-touch-target-md);
}

@media (max-width: 640px) {
    .discover-search__input {
        padding: var(--ifinsta-space-2-5) var(--ifinsta-space-3) var(--ifinsta-space-2-5) var(--ifinsta-space-9);
        font-size: var(--ifinsta-text-base);
    }
}

.discover-search__input:focus {
    outline: none;
    border-color: var(--ifinsta-primary-500);
    box-shadow: var(--ifinsta-input-focus-shadow);
}

.discover-search__input::placeholder {
    color: var(--ifinsta-text-muted);
}

.discover-search__icon {
    position: absolute;
    left: var(--ifinsta-space-4);
    top: 50%;
    transform: translateY(-50%);
    color: var(--discover-text-muted);
    width: var(--ifinsta-icon-sm);
    height: var(--ifinsta-icon-sm);
}

/* ==========================================================================
   GRID LAYOUTS - Compact Density-Optimized
   ========================================================================== */
.discover-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: var(--ifinsta-space-3);
    margin-top: 0;
}

@media (max-width: 1024px) {
    .discover-grid {
        gap: var(--ifinsta-space-2-5);
        grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    }
}

@media (max-width: 768px) {
    .discover-grid {
        grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
        gap: var(--ifinsta-space-2);
    }
}

@media (max-width: 480px) {
    .discover-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--ifinsta-space-2);
    }
}

/* Compact grid for denser information display */
.discover-grid--compact {
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: var(--ifinsta-space-2);
}

/* Two-column Layout with Sidebar */
.discover-layout-sidebar {
    display: grid;
    grid-template-columns: 1fr 240px;
    gap: var(--ifinsta-space-4);
}

@media (max-width: 1024px) {
    .discover-layout-sidebar {
        grid-template-columns: 1fr;
        gap: var(--ifinsta-space-3);
    }
}

/* Section spacing */
.discover-section {
    margin-top: var(--ifinsta-space-3);
    margin-bottom: 0;
    padding: var(--ifinsta-space-3);
    background: var(--ifinsta-surface);
    border: 1px solid #e8eaed;
    border-radius: 4px;
}

.discover-section--compact {
    padding: var(--ifinsta-space-2-5);
}

/* ==========================================================================
   CARD COMPONENTS - Compact E-commerce Style
   ========================================================================== */
.discover-card {
    background: var(--ifinsta-surface);
    border-radius: var(--discover-radius);
    overflow: visible;
    transition: var(--ifinsta-card-transition);
    border: none;
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

.discover-card:hover {
    z-index: 50;
}

/* Product card hover: border highlight, no lift */
.discover-card--product:hover {
    border-color: var(--ifinsta-primary-400);
}

.discover-card__image-wrap {
    aspect-ratio: 1;
    overflow: hidden;
    background: var(--discover-bg-alt);
    position: relative;
}

.discover-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--ifinsta-duration-slow) var(--ifinsta-ease-smooth);
}

.discover-card:hover .discover-card__image {
    transform: none;
}

.discover-card__content {
    padding: var(--ifinsta-space-2) var(--ifinsta-space-2) var(--ifinsta-space-2-5);
    flex: 1;
    display: flex;
    flex-direction: column;
}

@media (max-width: 640px) {
    .discover-card__content {
        padding: var(--ifinsta-space-1-5) var(--ifinsta-space-2);
    }
}

.discover-card__eyebrow-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--ifinsta-space-2);
    margin-bottom: var(--ifinsta-space-1);
}

.discover-card__category {
    font-size: var(--ifinsta-text-xs);
    text-transform: uppercase;
    font-weight: var(--ifinsta-font-semibold);
    color: var(--discover-primary);
    margin-bottom: 0;
    display: block;
    letter-spacing: var(--ifinsta-letter-spacing-wider);
}

.discover-card__meta-pill {
    display: inline-flex;
    align-items: center;
    min-height: 1.65rem;
    padding: 0 var(--ifinsta-space-2);
    border-radius: var(--ifinsta-radius-full);
    background: rgba(15, 23, 42, 0.05);
    color: var(--ifinsta-text-secondary);
    font-size: 0.7rem;
    font-weight: var(--ifinsta-font-semibold);
    letter-spacing: 0.01em;
}

.discover-card__meta-pill--success {
    background: rgba(22, 163, 74, 0.1);
    color: var(--ifinsta-success-700, #15803d);
}

.discover-card__title {
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    margin-bottom: var(--ifinsta-space-1);
    color: var(--discover-text);
    line-height: var(--ifinsta-leading-snug);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.discover-card__price {
    font-size: var(--ifinsta-text-base);
    font-weight: var(--ifinsta-font-bold);
    color: var(--discover-text);
    font-family: var(--ifinsta-font-mono);
    margin-top: auto;
    padding-top: var(--ifinsta-space-2);
}

.discover-card__meta {
    font-size: var(--ifinsta-text-xs);
    color: var(--discover-text-muted);
    margin-top: var(--ifinsta-space-1);
}

.discover-card__description {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.discover-card__meta-stack {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ifinsta-space-1-5);
    margin-top: var(--ifinsta-space-2);
}

.discover-card__metric {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    min-height: 1.6rem;
    padding: 0 var(--ifinsta-space-2);
    border-radius: var(--ifinsta-radius-full);
    background: rgba(148, 163, 184, 0.12);
    color: var(--ifinsta-text-secondary);
    font-size: 0.7rem;
    font-weight: var(--ifinsta-font-medium);
}

.discover-card__metric--accent {
    background: rgba(37, 99, 235, 0.1);
    color: var(--ifinsta-primary-700);
}

.discover-card__meta-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ifinsta-space-2);
    margin-top: auto;
    padding-top: var(--ifinsta-space-2);
}

.discover-card__link {
    color: var(--discover-primary);
    font-weight: 600;
}

.discover-card__rating {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--ifinsta-warning);
}

.discover-card__badge {
    position: absolute;
    top: var(--ifinsta-space-2);
    left: var(--ifinsta-space-2);
    padding: var(--ifinsta-space-0-5) var(--ifinsta-space-2);
    background: var(--ifinsta-primary);
    color: var(--ifinsta-white);
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    border-radius: var(--ifinsta-radius-sm);
    z-index: 10;
}

/* Store card */
.discover-card--store {
    border: 1px solid #e8eaed;
    border-radius: 4px;
    background: #fff;
    overflow: hidden;
    transition: border-color 0.15s ease;
}

.discover-card--store:hover {
    border-color: var(--ifinsta-primary-400);
}

.discover-card--store .discover-card__image-wrap {
    aspect-ratio: 3 / 2;
    border-radius: 0;
}

/* ==========================================================================
   STORIES RIBBON - Compact Horizontal Scroll
   ========================================================================== */
.discover-stories-ribbon {
    display: flex;
    overflow-x: auto;
    padding: var(--ifinsta-space-4) 0;
    gap: var(--ifinsta-space-4);
    scrollbar-width: none;
    -ms-overflow-style: none;
    margin: 0 calc(-1 * var(--ifinsta-content-padding));
    padding-left: var(--ifinsta-content-padding);
    padding-right: var(--ifinsta-content-padding);
}

.discover-stories-ribbon::-webkit-scrollbar {
    display: none;
}

@media (max-width: 640px) {
    .discover-stories-ribbon {
        margin: 0 calc(-1 * var(--ifinsta-space-4));
        padding-left: var(--ifinsta-space-4);
        padding-right: var(--ifinsta-space-4);
        gap: var(--ifinsta-space-3);
    }
}

.discover-story-item {
    flex: 0 0 auto;
    text-align: center;
    cursor: pointer;
    width: 64px;
    transition: var(--ifinsta-transition-hover);
}

.discover-story-item:hover {
    transform: var(--ifinsta-btn-hover-transform);
}

.discover-story-avatar {
    width: 64px;
    height: 64px;
    border-radius: var(--ifinsta-radius-full);
    padding: var(--ifinsta-space-0-5);
    border: 2px solid var(--discover-primary);
    transition: transform var(--ifinsta-duration-fast) var(--ifinsta-ease-fluent);
    object-fit: cover;
    background: var(--discover-bg);
}

@media (max-width: 640px) {

    .discover-story-avatar,
    .discover-story-item {
        width: 56px;
        height: 56px;
    }

    .discover-story-avatar {
        padding: 2px;
        border-width: 2px;
    }
}

.discover-story-item:hover .discover-story-avatar {
    transform: scale(1.05);
}

.discover-story-label {
    font-size: var(--ifinsta-text-xs);
    margin-top: var(--ifinsta-space-1);
    font-weight: var(--ifinsta-font-medium);
    color: var(--discover-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}

/* ==========================================================================
   CATEGORY CHIPS - Compact Filter Bar
   ========================================================================== */
.discover-category-bar {
    display: flex;
    gap: var(--ifinsta-space-2);
    overflow-x: auto;
    padding-bottom: var(--ifinsta-space-1);
    scrollbar-width: none;
    -ms-overflow-style: none;
    margin: 0;
    padding-left: 0;
    padding-right: 0;
}

.discover-category-bar::-webkit-scrollbar {
    display: none;
}

.discover-category-chip {
    padding: var(--ifinsta-space-2) var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-full);
    text-decoration: none;
    color: var(--discover-text);
    font-weight: var(--ifinsta-font-semibold);
    white-space: nowrap;
    transition: var(--ifinsta-transition-fast);
    font-size: var(--ifinsta-text-sm);
    background: var(--discover-bg-alt);
    border: 1px solid var(--discover-border);
    min-height: 2.5rem;
    display: inline-flex;
    align-items: center;
    gap: var(--ifinsta-space-1-5);
}

.discover-category-chip:hover {
    background: var(--ifinsta-primary-alpha-08);
    border-color: var(--discover-primary);
    color: var(--discover-primary);
}

.discover-category-chip__count {
    font-size: var(--ifinsta-text-xs);
    color: var(--discover-text-muted);
    margin-left: var(--ifinsta-space-1);
}

/* ==========================================================================
   SECTION HEADERS - Compact Layout
   ========================================================================== */
.discover-section-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: var(--ifinsta-space-3);
    gap: var(--ifinsta-space-3);
}

/* Categories header has no subtitle — tighten the bottom gap */
.discover-section-header--categories {
    margin-bottom: var(--ifinsta-space-3);
    align-items: center;
}

@media (max-width: 640px) {
    .discover-section-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--ifinsta-space-3);
        margin-bottom: var(--ifinsta-space-4);
    }
}

.discover-section-title {
    font-size: var(--ifinsta-text-lg);
    font-weight: var(--ifinsta-font-bold);
    letter-spacing: -0.01em;
    color: var(--discover-text);
}

.discover-section-subtitle {
    font-size: var(--ifinsta-text-sm);
    color: var(--discover-text-muted);
    margin-top: var(--ifinsta-space-1);
}

.discover-link-all {
    color: var(--discover-primary);
    font-weight: var(--ifinsta-font-semibold);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-1);
    font-size: var(--ifinsta-text-sm);
    transition: var(--ifinsta-transition-fast);
}

.discover-link-all:hover {
    color: var(--ifinsta-primary-700);
}

/* ==========================================================================
   STORE HEADER - Compact Profile
   ========================================================================== */
.discover-store-header {
    position: relative;
    margin-bottom: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-3);
    border: 1px solid #e8eaed;
    border-radius: 4px;
    background: var(--ifinsta-surface);
}

.discover-store-banner {
    height: clamp(100px, 18vh, 180px);
    width: 100%;
    position: relative;
    overflow: hidden;
    background: var(--discover-bg-alt);
    border-radius: 0;
}

.discover-store-banner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Banner overlay: Follow + Share buttons */
.discover-store-banner__overlay {
    position: absolute;
    top: var(--ifinsta-space-3);
    right: var(--ifinsta-space-3);
    display: flex;
    gap: var(--ifinsta-space-1-5);
    z-index: 1;
}

.discover-banner-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--ifinsta-space-1-5);
    height: 34px;
    padding: 0 var(--ifinsta-space-3);
    border-radius: var(--ifinsta-radius-md);
    background: rgba(255, 255, 255, 0.92);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.4);
    color: var(--ifinsta-text);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    font-family: var(--discover-font);
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    white-space: nowrap;
}

.discover-banner-btn:hover {
    background: rgba(255, 255, 255, 1);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    transform: translateY(-1px);
}

.discover-banner-btn--active {
    background: var(--ifinsta-primary-600);
    color: var(--ifinsta-white);
    border-color: var(--ifinsta-primary-600);
}

.discover-banner-btn--active:hover {
    background: var(--ifinsta-primary-700);
    border-color: var(--ifinsta-primary-700);
}

.discover-banner-btn--icon {
    width: 34px;
    padding: 0;
}

.discover-store-profile {
    position: relative;
    margin-top: calc(-1 * var(--ifinsta-space-6));
    padding: 0 var(--ifinsta-space-2) var(--ifinsta-space-1);
    display: flex;
    align-items: flex-end;
    gap: var(--ifinsta-space-3);
    flex-wrap: wrap;
}

.discover-store-logo {
    width: 68px;
    height: 68px;
    border-radius: 4px;
    border: 2px solid var(--ifinsta-surface);
    background: var(--ifinsta-bg-secondary);
    object-fit: cover;
    flex-shrink: 0;
}

@media (max-width: 640px) {
    .discover-store-logo {
        width: 52px;
        height: 52px;
        border-width: 2px;
    }
}

.discover-store-info {
    flex: 1;
    min-width: 200px;
    padding-bottom: var(--ifinsta-space-2);
}

.discover-store-name {
    font-size: clamp(var(--ifinsta-text-xl), 3vw, var(--ifinsta-text-2xl));
    font-weight: var(--ifinsta-font-bold);
    letter-spacing: -0.02em;
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
}

.discover-store-meta {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-4);
    margin-top: var(--ifinsta-space-2);
    flex-wrap: wrap;
    font-size: var(--ifinsta-text-sm);
    color: var(--discover-text-muted);
}

.discover-store-tagline {
    color: var(--discover-text-muted);
    font-size: var(--ifinsta-text-sm);
    margin-top: var(--ifinsta-space-1);
    max-width: 56ch;
}

.discover-store-actions {
    display: flex;
    gap: var(--ifinsta-space-1-5);
    align-items: center;
    padding-bottom: 0;
}

/* Icon-only compact action buttons in the profile row */
.discover-store-icon-btn {
    width: var(--discover-store-control-height, 2.5rem);
    height: var(--discover-store-control-height, 2.5rem);
    min-width: var(--discover-store-control-height, 2.5rem);
    padding: 0;
    border-radius: var(--discover-store-control-radius, 999px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.discover-store-icon-btn svg {
    width: var(--discover-store-icon-size, 1rem);
    height: var(--discover-store-icon-size, 1rem);
}

.discover-btn--cart {
    position: relative;
}

.discover-cart-pill {
    min-width: 1.4rem;
    height: 1.4rem;
    padding: 0 var(--ifinsta-space-1-5);
    border-radius: var(--ifinsta-radius-full);
    background: var(--ifinsta-primary-600);
    color: var(--ifinsta-white);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-bold);
}

/* ==========================================================================
   NAVIGATION TABS - Compact Horizontal
   ========================================================================== */
.discover-tabs {
    display: flex;
    gap: var(--ifinsta-space-6);
    border-bottom: 1px solid var(--discover-border);
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.discover-tabs::-webkit-scrollbar {
    display: none;
}

.discover-tab {
    padding: var(--ifinsta-space-2) var(--ifinsta-space-4);
    font-weight: var(--ifinsta-font-semibold);
    color: var(--discover-text-muted);
    text-decoration: none;
    border-bottom: 2px solid transparent;
    transition: all 0.2s ease;
    white-space: nowrap;
    font-size: var(--ifinsta-text-sm);
    background: none;
    border-top: none;
    border-left: none;
    border-right: none;
    cursor: pointer;
    border-radius: var(--ifinsta-radius-full);
}

.discover-tab:hover {
    color: var(--discover-text);
    background: var(--ifinsta-neutral-100);
}

.discover-tab--active {
    color: var(--discover-primary);
    border-bottom-color: var(--discover-primary);
    background: var(--ifinsta-primary-50) !important;
    border-bottom-width: 0;
    padding-bottom: var(--ifinsta-space-2);
}

.discover-tab--active:hover {
    background: var(--ifinsta-primary-100) !important;
}

/* ==========================================================================
   BUTTONS - Compact Actions
   ========================================================================== */
.discover-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--ifinsta-space-2);
    padding: var(--ifinsta-space-2) var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-md);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    text-decoration: none;
    cursor: pointer;
    transition: var(--ifinsta-btn-transition);
    border: 1px solid transparent;
    height: var(--ifinsta-touch-target-md);
}

.discover-btn--primary {
    background: var(--discover-primary);
    color: var(--ifinsta-white);
}

.discover-btn--primary:hover {
    background: var(--ifinsta-primary-700);
    transform: var(--ifinsta-btn-hover-transform);
}

.discover-btn--secondary {
    background: transparent;
    color: var(--discover-primary);
    border-color: var(--discover-primary);
}

.discover-btn--secondary:hover {
    background: var(--ifinsta-primary-alpha-08);
}

.discover-btn--ghost {
    background: transparent;
    color: var(--discover-text);
    border-color: var(--discover-border);
}

.discover-btn--ghost:hover {
    background: var(--ifinsta-neutral-100);
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.discover-store-icon-btn:hover {
    background: var(--ifinsta-primary-50) !important;
    color: var(--discover-primary) !important;
}

.discover-store-icon-btn:hover svg {
    transform: scale(1.1);
}

.discover-btn--icon {
    width: var(--ifinsta-touch-target-md);
    height: var(--ifinsta-touch-target-md);
    padding: 0;
    border-radius: var(--ifinsta-radius-full);
}

.discover-search-page-header {
    padding: var(--ifinsta-space-7) 0 var(--ifinsta-space-6);
    background: var(--ifinsta-surface);
    border-bottom: 1px solid var(--ifinsta-border-light);
}

.discover-search-page-title {
    font-size: clamp(var(--ifinsta-text-xl), 3vw, var(--ifinsta-text-3xl));
    font-weight: var(--ifinsta-font-bold);
    letter-spacing: -0.02em;
    margin-bottom: var(--ifinsta-space-2);
    line-height: var(--ifinsta-leading-tight);
}

.discover-search-page-summary {
    color: var(--discover-text-muted);
    font-size: var(--ifinsta-text-sm);
}

.discover-search-results {
    padding-top: var(--ifinsta-space-6);
    padding-bottom: var(--ifinsta-space-12);
}

/* ==========================================================================
   EMPTY STATE - Compact Centered
   ========================================================================== */
.discover-empty {
    text-align: center;
    padding: var(--ifinsta-space-8) var(--ifinsta-space-4);
}

.discover-empty__icon {
    width: 48px;
    height: 48px;
    background: var(--discover-bg-alt);
    border-radius: var(--ifinsta-radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--ifinsta-space-4);
    color: var(--discover-text-muted);
}

.discover-empty__title {
    font-size: var(--ifinsta-text-lg);
    font-weight: var(--ifinsta-font-semibold);
    margin-bottom: var(--ifinsta-space-2);
    color: var(--discover-text);
}

.discover-empty__text {
    color: var(--discover-text-muted);
    font-size: var(--ifinsta-text-sm);
    max-width: 400px;
    margin: 0 auto var(--ifinsta-space-6);
}

/* ==========================================================================
   SIDEBAR - Compact Info Panel
   ========================================================================== */
.discover-sidebar {
    padding: var(--ifinsta-space-3);
    background: var(--ifinsta-surface);
    border-radius: var(--ifinsta-radius-lg);
    border: 1px solid var(--ifinsta-border-light);
}

.discover-sidebar__title {
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-bold);
    margin-bottom: var(--ifinsta-space-3);
    text-transform: uppercase;
    color: var(--discover-text-muted);
    letter-spacing: var(--ifinsta-letter-spacing-wider);
}

.discover-sidebar__content {
    line-height: var(--ifinsta-leading-normal);
    color: var(--discover-text);
    font-size: var(--ifinsta-text-sm);
}

.discover-sidebar__footer {
    margin-top: var(--ifinsta-space-3);
    padding-top: var(--ifinsta-space-3);
    border-top: 1px solid var(--discover-border);
}

.discover-sidebar__meta-title {
    font-size: var(--ifinsta-text-xs);
    font-weight: 600;
    margin-bottom: var(--ifinsta-space-3);
    color: var(--discover-text-muted);
}

.discover-cart-feedback {
    position: fixed;
    right: var(--ifinsta-space-5);
    bottom: var(--ifinsta-space-5);
    z-index: 70;
    display: inline-flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    padding: var(--ifinsta-space-3) var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-lg);
    box-shadow: var(--ifinsta-shadow-lg);
    color: var(--ifinsta-white);
    font-size: var(--ifinsta-text-sm);
}

.discover-cart-feedback--success {
    background: #0f766e;
}

.discover-cart-feedback--error {
    background: #b91c1c;
}

.discover-cart-modal {
    position: fixed;
    inset: 0;
    z-index: 80;
    background: rgba(15, 23, 42, 0.58);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--ifinsta-space-4);
}

.discover-cart-modal__dialog {
    width: min(100%, 28rem);
    border-radius: var(--ifinsta-radius-xl);
    background: var(--ifinsta-surface);
    border: 1px solid var(--ifinsta-border-light);
    box-shadow: var(--ifinsta-shadow-lg);
    padding: var(--ifinsta-space-5);
    display: grid;
    gap: var(--ifinsta-space-4);
}

.discover-cart-modal__header {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: var(--ifinsta-space-3);
}

.discover-cart-modal__eyebrow {
    margin: 0 0 var(--ifinsta-space-1);
    color: var(--ifinsta-primary-700);
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    text-transform: uppercase;
    letter-spacing: var(--ifinsta-letter-spacing-wider);
}

.discover-cart-modal__title {
    margin: 0;
    font-size: var(--ifinsta-text-2xl);
    line-height: var(--ifinsta-leading-tight);
}

.discover-cart-modal__close {
    border: none;
    background: transparent;
    color: var(--ifinsta-text-muted);
    width: 2.25rem;
    height: 2.25rem;
    border-radius: var(--ifinsta-radius-full);
    cursor: pointer;
}

.discover-cart-modal__close:hover {
    background: rgba(148, 163, 184, 0.12);
}

.discover-cart-modal__form {
    display: grid;
    gap: var(--ifinsta-space-3);
}

.discover-cart-modal__copy {
    margin: 0;
    color: var(--ifinsta-text-secondary);
}

.discover-cart-modal__label,
.discover-checkout-field__label {
    display: block;
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    color: var(--discover-text);
}

.discover-cart-modal__actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--ifinsta-space-2);
    flex-wrap: wrap;
}

.discover-checkout-shell {
    gap: var(--ifinsta-space-6);
}

.discover-checkout-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(320px, 0.9fr);
    gap: var(--ifinsta-space-5);
    align-items: start;
}

.discover-checkout-panel {
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid var(--ifinsta-border-light);
    border-radius: var(--ifinsta-radius-xl);
    padding: var(--ifinsta-space-5);
    display: grid;
    gap: var(--ifinsta-space-4);
}

.discover-checkout-panel--summary {
    position: sticky;
    top: var(--ifinsta-space-5);
}

.discover-checkout-panel__header {
    display: grid;
    gap: var(--ifinsta-space-1);
}

.discover-checkout-panel__title {
    margin: 0;
    font-size: var(--ifinsta-text-lg);
    font-weight: var(--ifinsta-font-bold);
}

.discover-checkout-panel__copy,
.discover-checkout-panel__footnote {
    margin: 0;
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-text-sm);
}

.discover-checkout-field {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-checkout-items {
    display: grid;
    gap: var(--ifinsta-space-3);
}

.discover-checkout-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: var(--ifinsta-space-4);
    align-items: center;
    padding: var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-lg);
    border: 1px solid rgba(148, 163, 184, 0.18);
    background: rgba(248, 250, 252, 0.9);
}

.discover-checkout-item__copy {
    min-width: 0;
}

.discover-checkout-item__title {
    margin: 0 0 var(--ifinsta-space-1);
    font-size: var(--ifinsta-text-base);
}

.discover-checkout-item__meta {
    margin: 0;
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-sm);
}

.discover-checkout-item__controls {
    display: grid;
    justify-items: end;
    gap: var(--ifinsta-space-2);
}

.discover-checkout-stepper {
    display: inline-flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    padding: var(--ifinsta-space-1);
    border-radius: var(--ifinsta-radius-full);
    border: 1px solid rgba(148, 163, 184, 0.2);
    background: var(--ifinsta-white);
}

.discover-checkout-stepper__button {
    width: 2rem;
    height: 2rem;
    border: none;
    border-radius: var(--ifinsta-radius-full);
    background: rgba(37, 99, 235, 0.08);
    color: var(--ifinsta-primary-700);
    font-size: var(--ifinsta-text-base);
    cursor: pointer;
}

.discover-checkout-stepper__value {
    min-width: 2rem;
    text-align: center;
    font-weight: var(--ifinsta-font-semibold);
}

.discover-checkout-item__line-total {
    font-weight: var(--ifinsta-font-bold);
    color: var(--ifinsta-primary-700);
}

.discover-checkout-remove {
    border: none;
    background: transparent;
    color: #b91c1c;
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    cursor: pointer;
}

.discover-checkout-summary {
    display: grid;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-lg);
    background: rgba(15, 23, 42, 0.03);
    border: 1px solid rgba(148, 163, 184, 0.16);
}

.discover-checkout-summary__row {
    display: flex;
    justify-content: space-between;
    gap: var(--ifinsta-space-3);
    font-size: var(--ifinsta-text-sm);
    color: var(--ifinsta-text-secondary);
}

.discover-checkout-summary__row--total {
    font-size: var(--ifinsta-text-base);
    color: var(--discover-text);
}

.discover-checkout-state {
    display: grid;
    justify-items: center;
    text-align: center;
    gap: var(--ifinsta-space-3);
    padding: clamp(2rem, 4vw, 3rem);
    border-radius: var(--ifinsta-radius-xl);
    border: 1px dashed rgba(148, 163, 184, 0.3);
    background: rgba(255, 255, 255, 0.94);
}

.discover-checkout-state--success {
    border-style: solid;
    border-color: rgba(15, 118, 110, 0.18);
    background: linear-gradient(180deg, rgba(240, 253, 250, 0.98), rgba(255, 255, 255, 0.96));
}

.discover-checkout-state__icon {
    width: 4rem;
    height: 4rem;
    border-radius: var(--ifinsta-radius-full);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(37, 99, 235, 0.08);
    color: var(--ifinsta-primary-700);
}

.discover-checkout-state--success .discover-checkout-state__icon {
    background: rgba(15, 118, 110, 0.1);
    color: #0f766e;
}

.discover-checkout-state__title {
    margin: 0;
    font-size: clamp(var(--ifinsta-text-xl), 4vw, var(--ifinsta-text-3xl));
}

.discover-checkout-state__text {
    margin: 0;
    max-width: 42rem;
    color: var(--ifinsta-text-secondary);
}

/* ==========================================================================
   UTILITY CLASSES - Responsive Visibility
   ========================================================================== */
.hide-on-mobile {
    display: block;
}

@media (max-width: 640px) {
    .hide-on-mobile {
        display: none !important;
    }
}

.show-only-mobile {
    display: none;
}

@media (max-width: 640px) {
    .show-only-mobile {
        display: block !important;
    }
}

/* Focus states for accessibility */
.discover-focusable:focus-visible {
    outline: none;
    box-shadow: var(--ifinsta-shadow-focus);
    border-radius: var(--ifinsta-radius-sm);
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {

    .discover-card,
    .discover-story-item,
    .discover-category-chip,
    .discover-btn {
        transition: none;
    }

    .discover-animate-fade,
    .discover-animate-fade-up,
    .discover-animate-scale {
        animation: none;
        opacity: 1;
        transform: none;
    }
}

@media (max-width: 640px) {
    .discover-body {
        padding-bottom: var(--ifinsta-space-10);
    }

    .discover-hero {
        padding: var(--ifinsta-space-6) 0;
    }

    .discover-section {
        margin-top: var(--ifinsta-space-4);
        padding: var(--ifinsta-space-4);
        border-radius: var(--ifinsta-radius-lg);
    }

    .discover-store-header {
        padding: var(--ifinsta-space-3);
        margin-bottom: var(--ifinsta-space-5);
    }

    .discover-store-profile {
        margin-top: calc(-1 * var(--ifinsta-space-8));
        padding: 0 var(--ifinsta-space-1) var(--ifinsta-space-1);
    }

    .discover-store-info {
        min-width: 0;
        padding-bottom: 0;
    }

    .discover-store-name {
        font-size: var(--ifinsta-text-xl);
    }

    .discover-store-actions {
        justify-content: flex-end;
        padding-bottom: 0;
    }

    .discover-tabs--storefront {
        grid-column: 1 / -1;
        border-bottom: 1px solid var(--discover-border);
        padding: var(--ifinsta-space-1) 0 0;
        align-self: stretch;
        gap: var(--ifinsta-space-5);
    }

    .discover-grid--compact {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .discover-search-page-header {
        padding: var(--ifinsta-space-6) 0 var(--ifinsta-space-5);
    }

    .discover-search-results {
        padding-top: var(--ifinsta-space-5);
    }
}

/* ==========================================================================
   PUBLIC STOREFRONT SURFACES
   ========================================================================== */
.discover-body--public {
    min-height: calc(100vh - var(--ifinsta-guest-header-height));
    background: #f4f5f7;
}


.discover-container--public {
    max-width: 1180px;
}

.discover-page-stack {
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-3);
}

.discover-page-stack--compact {
    gap: var(--ifinsta-space-2);
}

.discover-section--page {
    margin-top: 0;
}

.discover-preview-banner {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 1rem;
    background: #fef9c3;
    border-bottom: 1px solid #fde047;
    font-size: 0.875rem;
    color: #713f12;
}

.discover-preview-banner svg {
    flex-shrink: 0;
    color: #ca8a04;
}

.discover-preview-banner__status {
    margin-left: auto;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.05em;
    color: #92400e;
}

.discover-empty--panel {
    background: var(--ifinsta-surface);
    border: 1px dashed var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-lg);
}

.discover-public-page .discover-grid--compact {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 140px), 1fr));
    justify-content: start;
}

.discover-grid--products {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 170px), 236px));
    gap: var(--ifinsta-space-2);
    justify-content: start;
}

.discover-card__anchor {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    color: inherit;
    text-decoration: none;
}

.discover-card__footer {
    padding: 0 var(--ifinsta-space-3) var(--ifinsta-space-3);
}

.discover-card__image-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(180deg, rgba(148, 163, 184, 0.12), rgba(148, 163, 184, 0.06));
    color: var(--ifinsta-text-muted);
}

.discover-store-header--public {
    overflow: hidden;
}

.discover-store-banner__fallback {
    width: 100%;
    height: 100%;
    background:
        linear-gradient(135deg, rgba(37, 99, 235, 0.18), rgba(14, 165, 233, 0.08)),
        linear-gradient(180deg, rgba(255, 255, 255, 0.6), rgba(226, 232, 240, 0.7));
}

.discover-store-logo--fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--ifinsta-primary-600), var(--ifinsta-primary-500));
    color: var(--ifinsta-white);
    font-size: clamp(var(--ifinsta-text-2xl), 4vw, var(--ifinsta-text-3xl));
    font-weight: var(--ifinsta-font-bold);
    text-transform: uppercase;
}

.discover-store-verified {
    color: var(--ifinsta-primary-600);
    flex-shrink: 0;
}

/* Location chip */
.discover-store-meta__chip {
    display: inline-flex;
    align-items: center;
    gap: var(--ifinsta-space-1);
    padding: 3px var(--ifinsta-space-2);
    border-radius: 3px;
    background: rgba(148, 163, 184, 0.10);
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-text-secondary);
    font-weight: var(--ifinsta-font-medium);
}

.discover-store-meta__item {
    display: inline-flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    padding: var(--ifinsta-space-1-5) var(--ifinsta-space-3);
    border-radius: 3px;
    background: rgba(148, 163, 184, 0.10);
}

.discover-store-meta__value {
    color: var(--discover-text);
    font-weight: var(--ifinsta-font-bold);
}

.discover-layout-sidebar--public {
    align-items: start;
}

.discover-sidebar__actions {
    display: grid;
    gap: var(--ifinsta-space-3);
    margin-top: var(--ifinsta-space-5);
}

.discover-share-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ifinsta-space-2);
}

.discover-btn--block {
    width: 100%;
}

.discover-btn--lg {
    min-height: 3.25rem;
    padding: var(--ifinsta-space-3) var(--ifinsta-space-5);
}

.discover-btn--whatsapp {
    background: #128c7e;
    border-color: #128c7e;
    color: var(--ifinsta-white);
}

.discover-btn--whatsapp:hover {
    background: #0f766e;
    border-color: #0f766e;
    color: var(--ifinsta-white);
}

.discover-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ifinsta-space-3);
    flex-wrap: wrap;
    margin-top: var(--ifinsta-space-6);
}

.discover-pagination__status {
    font-size: var(--ifinsta-text-sm);
    color: var(--ifinsta-text-muted);
}

.discover-products-panel {
    min-width: 0;
}

.discover-brand-context__back {
    display: inline-flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    color: var(--discover-primary);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    text-decoration: none;
}

.discover-brand-context {
    display: grid;
    gap: var(--ifinsta-space-3);
}

.discover-brand-context__surface {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: var(--ifinsta-space-5);
    align-items: center;
    padding: var(--ifinsta-space-5);
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid var(--ifinsta-border-light);
    border-radius: var(--ifinsta-radius-xl);
    box-shadow: var(--ifinsta-shadow-xs);
}

.discover-brand-context__identity {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-4);
}

.discover-brand-context__logo,
.discover-brand-context__logo--fallback {
    width: 72px;
    height: 72px;
    border-radius: var(--ifinsta-radius-lg);
    object-fit: cover;
    flex-shrink: 0;
}

.discover-brand-context__logo--fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.18), rgba(37, 99, 235, 0.06));
    color: var(--ifinsta-primary-700);
    font-size: var(--ifinsta-text-2xl);
    font-weight: var(--ifinsta-font-bold);
    text-transform: uppercase;
}

.discover-brand-context__copy {
    min-width: 0;
    display: grid;
    gap: var(--ifinsta-space-1);
}

.discover-brand-context__eyebrow {
    font-size: var(--ifinsta-text-xs);
    letter-spacing: var(--ifinsta-letter-spacing-wider);
    text-transform: uppercase;
    color: var(--ifinsta-text-muted);
    font-weight: var(--ifinsta-font-semibold);
}

.discover-brand-context__title {
    margin: 0;
    font-size: clamp(var(--ifinsta-text-xl), 3vw, var(--ifinsta-text-2xl));
    line-height: var(--ifinsta-leading-tight);
}

.discover-brand-context__subtitle {
    margin: 0;
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-sm);
}

.discover-brand-context__actions {
    display: inline-flex;
    flex-wrap: wrap;
    gap: var(--ifinsta-space-2);
}

.discover-product-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
    gap: var(--ifinsta-space-4);
    align-items: start;
}

.discover-product-gallery {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr);
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-3);
    background: var(--ifinsta-surface);
    border: 1px solid var(--ifinsta-border-light);
    border-radius: var(--ifinsta-radius-xl);
    box-shadow: var(--ifinsta-shadow-xs);
}

.discover-product-thumbnails {
    display: grid;
    gap: var(--ifinsta-space-3);
    align-content: start;
}

.discover-product-thumbnail {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    aspect-ratio: 1;
    padding: 0;
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-lg);
    background: rgba(255, 255, 255, 0.9);
    cursor: pointer;
    transition: var(--ifinsta-transition-fast);
    overflow: hidden;
}

.discover-product-thumbnail:hover {
    border-color: var(--ifinsta-primary-400);
}

.discover-product-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.discover-product-thumbnail--active {
    border-color: var(--ifinsta-primary-500);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}

.discover-product-thumbnail--placeholder {
    color: var(--ifinsta-text-muted);
    background: linear-gradient(180deg, rgba(148, 163, 184, 0.12), rgba(148, 163, 184, 0.06));
}

.discover-product-main-media {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
    overflow: hidden;
    border-radius: var(--ifinsta-radius-xl);
    background:
        radial-gradient(circle at top right, rgba(37, 99, 235, 0.1), transparent 38%),
        linear-gradient(180deg, rgba(248, 250, 252, 0.95), rgba(226, 232, 240, 0.72));
    aspect-ratio: 4 / 3;
}

.discover-product-main-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.discover-product-main-media__placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ifinsta-text-muted);
}

.discover-product-info {
    display: grid;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-4);
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid var(--ifinsta-border-light);
    border-radius: var(--ifinsta-radius-xl);
    box-shadow: var(--ifinsta-shadow-xs);
}

.discover-product-category {
    margin-bottom: 0;
}

.discover-product-name {
    margin: 0;
    font-size: clamp(var(--ifinsta-text-lg), 2.5vw, var(--ifinsta-text-2xl));
    line-height: var(--ifinsta-leading-tight);
    letter-spacing: -0.01em;
}

.discover-product-pricing {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: var(--ifinsta-space-3);
}

.discover-product-price {
    font-family: var(--ifinsta-font-mono);
    font-size: clamp(var(--ifinsta-text-base), 2vw, var(--ifinsta-text-xl));
    font-weight: var(--ifinsta-font-bold);
    color: var(--ifinsta-primary-700);
}

.discover-product-old-price {
    font-size: var(--ifinsta-text-base);
    color: var(--ifinsta-text-muted);
    text-decoration: line-through;
}

.discover-product-copy {
    display: grid;
    gap: var(--ifinsta-space-1-5);
    padding-top: var(--ifinsta-space-3);
    border-top: 1px solid var(--ifinsta-border-light);
}

.discover-product-copy__title {
    margin: 0;
    font-size: var(--ifinsta-text-xs);
    text-transform: uppercase;
    letter-spacing: var(--ifinsta-letter-spacing-wider);
    color: var(--ifinsta-text-muted);
}

.discover-product-copy__text {
    margin: 0;
    color: var(--ifinsta-text-secondary);
    line-height: 1.7;
}

.discover-product-ctas {
    display: grid;
    gap: var(--ifinsta-space-3);
}

.discover-product-trust {
    display: flex;
    align-items: flex-start;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-lg);
    border: 1px solid rgba(37, 99, 235, 0.14);
    background: rgba(37, 99, 235, 0.06);
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-text-sm);
}

.discover-product-trust__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    border-radius: var(--ifinsta-radius-full);
    background: rgba(37, 99, 235, 0.12);
    color: var(--ifinsta-primary-700);
    flex-shrink: 0;
}

.discover-contact-layout {
    display: grid;
    grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
    gap: var(--ifinsta-space-6);
    align-items: start;
}

.discover-contact-card {
    display: grid;
    gap: var(--ifinsta-space-5);
    padding: clamp(1.5rem, 2vw, 2rem);
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid var(--ifinsta-border-light);
    border-radius: var(--ifinsta-radius-xl);
    box-shadow: var(--ifinsta-shadow-xs);
}

.discover-contact-card--accent {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at top right, rgba(37, 99, 235, 0.14), transparent 38%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(239, 246, 255, 0.95));
}

.discover-contact-copy {
    display: grid;
    gap: var(--ifinsta-space-3);
}

.discover-contact-eyebrow {
    margin: 0;
    font-size: var(--ifinsta-text-xs);
    text-transform: uppercase;
    letter-spacing: var(--ifinsta-letter-spacing-wider);
    color: var(--ifinsta-primary-700);
    font-weight: var(--ifinsta-font-semibold);
}

.discover-contact-title,
.discover-contact-form__title {
    margin: 0;
    font-size: clamp(var(--ifinsta-text-2xl), 4vw, var(--ifinsta-text-3xl));
    line-height: var(--ifinsta-leading-tight);
}

.discover-contact-lead,
.discover-contact-form__lead {
    margin: 0;
    color: var(--ifinsta-text-secondary);
    line-height: 1.7;
}

.discover-contact-product-pill {
    display: inline-flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    padding: var(--ifinsta-space-2) var(--ifinsta-space-3);
    border-radius: var(--ifinsta-radius-full);
    background: rgba(37, 99, 235, 0.08);
    color: var(--ifinsta-primary-700);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-medium);
}

.discover-contact-methods {
    display: grid;
    gap: var(--ifinsta-space-3);
}

.discover-contact-method {
    display: flex;
    align-items: flex-start;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-lg);
    border: 1px solid rgba(148, 163, 184, 0.2);
    background: rgba(255, 255, 255, 0.8);
    color: inherit;
    text-decoration: none;
    transition: var(--ifinsta-transition-fast);
}

a.discover-contact-method:hover {
    border-color: rgba(37, 99, 235, 0.28);
    transform: translateY(-1px);
}

.discover-contact-method__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: var(--ifinsta-radius-lg);
    background: rgba(37, 99, 235, 0.08);
    color: var(--ifinsta-primary-700);
    flex-shrink: 0;
}

.discover-contact-method__content {
    min-width: 0;
    display: grid;
    gap: 2px;
}

.discover-contact-method__label {
    font-size: var(--ifinsta-text-xs);
    text-transform: uppercase;
    letter-spacing: var(--ifinsta-letter-spacing-wider);
    color: var(--ifinsta-text-muted);
}

.discover-contact-method__value {
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    color: var(--ifinsta-text);
    word-break: break-word;
}

.discover-contact-footer {
    margin-top: auto;
    padding-top: var(--ifinsta-space-3);
    border-top: 1px solid rgba(148, 163, 184, 0.2);
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-xs);
    letter-spacing: 0.02em;
}

.discover-contact-form {
    display: grid;
    gap: var(--ifinsta-space-4);
}

.discover-contact-form__header {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-form-grid {
    display: grid;
    gap: var(--ifinsta-space-4);
}

.discover-form-grid--two-up {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.discover-form-field {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-form-label {
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    color: var(--ifinsta-text);
}

.discover-form-control {
    width: 100%;
    min-height: 2.875rem;
    padding: 0.875rem 1rem;
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-lg);
    background: rgba(255, 255, 255, 0.95);
    color: var(--ifinsta-text);
    font: inherit;
    transition: var(--ifinsta-input-transition);
}

.discover-form-control:focus {
    outline: none;
    border-color: var(--ifinsta-primary-500);
    box-shadow: var(--ifinsta-input-focus-shadow);
}

.discover-form-control--textarea {
    min-height: 9rem;
    resize: vertical;
}

.discover-form-errors {
    margin: 0;
    color: var(--ifinsta-danger);
    font-size: var(--ifinsta-text-xs);
}

.discover-form-error-list {
    list-style: none;
    padding: 0;
}

/* ==========================================================================
   DISCOVER MARKETPLACE PUBLIC BROWSE
   ========================================================================== */
.discover-body--public {
    overflow-x: hidden;
}

.discover-market-page {
    padding: 0;
}

.discover-market-stack {
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-3);
}

.discover-market-stack--browse {
    gap: var(--ifinsta-space-5);
}

.discover-market-hero,
.discover-market-header {
    position: relative;
    overflow: hidden;
    padding: clamp(1.5rem, 2vw, 2.25rem);
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid var(--ifinsta-border-light);
    border-radius: var(--ifinsta-radius-2xl);
    box-shadow: var(--ifinsta-shadow-xs);
}

.discover-market-hero {
    display: grid;
    gap: var(--ifinsta-space-5);
    background:
        radial-gradient(ellipse 65% 55% at 85% 15%, rgba(37, 99, 235, 0.1), transparent),
        radial-gradient(ellipse 55% 45% at 8% 88%, rgba(14, 165, 233, 0.08), transparent),
        linear-gradient(175deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.96));
}

/* Single-column hero layout (right aside removed) */
.discover-market-hero__layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ifinsta-space-5);
}

.discover-market-hero__left {
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-4);
    min-width: 0;
}

.discover-market-hero__search-block {
    display: grid;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-xl);
    background: rgba(255, 255, 255, 0.75);
    border: 1px solid rgba(148, 163, 184, 0.2);
    max-width: 52rem;
    width: 100%;
}

.discover-market-hero__right {
    display: grid;
    gap: var(--ifinsta-space-3);
    align-content: start;
    min-width: 0;
}

.discover-market-hero__masthead {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(300px, 0.9fr);
    gap: var(--ifinsta-space-6);
    align-items: center;
}

.discover-market-hero__tools {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.8fr);
    gap: var(--ifinsta-space-5);
    align-items: start;
}

.discover-market-hero__tools-main {
    display: grid;
    gap: var(--ifinsta-space-3);
    align-content: start;
}

.discover-market-hero__copy,
.discover-market-hero__aside,
.discover-market-header__copy,
.discover-market-header__content {
    min-width: 0;
}

.discover-market-hero__copy {
    display: grid;
    gap: var(--ifinsta-space-3);
    align-content: start;
    max-width: 44rem;
}

.discover-market-hero__aside {
    align-self: start;
    justify-self: end;
}

.discover-market-header__copy {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-market-hero__eyebrow,
.discover-market-header__eyebrow,
.discover-market-spotlight__eyebrow,
.discover-browse-rail__label {
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    letter-spacing: var(--ifinsta-letter-spacing-wider);
    text-transform: uppercase;
}

.discover-market-hero__eyebrow,
.discover-market-header__eyebrow,
.discover-market-spotlight__eyebrow {
    color: var(--ifinsta-primary-700);
}

.discover-market-hero__title,
.discover-market-header__title,
.discover-market-spotlight__title {
    margin: 0;
    line-height: var(--ifinsta-leading-tight);
    letter-spacing: -0.03em;
}

.discover-market-hero__title {
    font-size: clamp(1.9rem, 4vw, 3.5rem);
    max-width: 22ch;
}

.discover-market-header__title {
    font-size: clamp(var(--ifinsta-text-2xl), 4vw, 3rem);
}

.discover-market-spotlight__title {
    font-size: clamp(var(--ifinsta-text-lg), 2vw, var(--ifinsta-text-2xl));
}

.discover-market-hero__subtitle,
.discover-market-header__summary,
.discover-market-spotlight__text {
    margin: 0;
    color: var(--ifinsta-text-secondary);
    line-height: 1.55;
}

.discover-market-hero__signals {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--ifinsta-space-3);
}

.discover-market-hero__signal {
    display: grid;
    gap: 0.25rem;
    padding: var(--ifinsta-space-3) var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-md);
    background: rgba(255, 255, 255, 0.65);
    border: 1px solid rgba(148, 163, 184, 0.14);
    box-shadow: inset 3px 0 0 var(--ifinsta-primary-500);
}

.discover-market-hero__signal strong {
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    line-height: 1.3;
    color: var(--ifinsta-text);
}

.discover-market-hero__signal span {
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-text-xs);
    line-height: 1.5;
}

.discover-search--market {
    max-width: none;
    margin: 0;
}

.discover-quick-links {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ifinsta-space-2);
}

.discover-quick-links--compact {
    gap: var(--ifinsta-space-1-5);
}

.discover-market-inline-group {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-market-inline-group__label {
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    letter-spacing: var(--ifinsta-letter-spacing-wider);
    text-transform: uppercase;
    color: var(--ifinsta-text-muted);
}

.discover-quick-link {
    display: inline-flex;
    align-items: center;
    min-height: 2.5rem;
    padding: 0 var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-full);
    border: 1px solid rgba(148, 163, 184, 0.24);
    background: rgba(255, 255, 255, 0.88);
    color: var(--ifinsta-text);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-medium);
    text-decoration: none;
    transition: var(--ifinsta-transition-fast);
}

.discover-quick-link:hover,
.discover-quick-link--active {
    border-color: rgba(37, 99, 235, 0.28);
    background: rgba(37, 99, 235, 0.08);
    color: var(--ifinsta-primary-700);
}

.discover-market-spotlight {
    display: grid;
    gap: var(--ifinsta-space-3);
    align-content: start;
    padding: var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-xl);
    border: 1px solid rgba(37, 99, 235, 0.12);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(239, 246, 255, 0.88)),
        radial-gradient(circle at top right, rgba(37, 99, 235, 0.12), transparent 32%);
}

.discover-market-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
    gap: var(--ifinsta-space-2);
    margin: 0;
}

.discover-market-stat {
    display: grid;
    gap: 0.2rem;
    padding: var(--ifinsta-space-2-5);
    border-radius: var(--ifinsta-radius-lg);
    background: rgba(255, 255, 255, 0.86);
    border: 1px solid rgba(148, 163, 184, 0.2);
}

.discover-market-stat dt {
    margin: 0;
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-xs);
    text-transform: uppercase;
    letter-spacing: var(--ifinsta-letter-spacing-wider);
}

.discover-market-stat dd {
    margin: 0;
    color: var(--ifinsta-primary-700);
    font-family: var(--ifinsta-font-mono);
    font-size: clamp(var(--ifinsta-text-xl), 2.4vw, 1.75rem);
    font-weight: var(--ifinsta-font-bold);
    line-height: 1.1;
}

.discover-market-header {
    display: grid;
    gap: var(--ifinsta-space-4);
}

.discover-market-header--search .discover-search--market {
    max-width: 100%;
}

.discover-market-header__back {
    display: inline-flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    color: var(--ifinsta-primary-700);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    text-decoration: none;
}

.discover-market-header__content {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: var(--ifinsta-space-4);
    align-items: center;
}

.discover-market-header__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 4.25rem;
    height: 4.25rem;
    border-radius: var(--ifinsta-radius-xl);
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.14), rgba(14, 165, 233, 0.08));
    color: var(--ifinsta-primary-700);
    flex-shrink: 0;
}

.discover-market-header__meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ifinsta-space-2);
}

.discover-market-meta-pill {
    display: inline-flex;
    align-items: center;
    min-height: 2.25rem;
    padding: 0 var(--ifinsta-space-3);
    border-radius: var(--ifinsta-radius-full);
    background: rgba(37, 99, 235, 0.08);
    color: var(--ifinsta-primary-700);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
}

.discover-market-spotlight__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ifinsta-space-2);
}

.discover-market-spotlight__featured {
    display: grid;
    gap: 0.2rem;
    padding: var(--ifinsta-space-3);
    border-radius: var(--ifinsta-radius-lg);
    border: 1px solid rgba(148, 163, 184, 0.18);
    background: rgba(255, 255, 255, 0.9);
    color: var(--ifinsta-text);
    text-decoration: none;
}

.discover-market-spotlight__featured strong {
    font-size: var(--ifinsta-text-sm);
}

.discover-market-spotlight__featured span {
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-text-xs);
    line-height: 1.45;
}

.discover-market-spotlight__featured-label {
    color: var(--ifinsta-primary-700);
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    letter-spacing: var(--ifinsta-letter-spacing-wider);
    text-transform: uppercase;
}

.discover-market-briefs {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--ifinsta-space-4);
}

.discover-market-brief {
    display: grid;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-xl);
    border: 1px solid rgba(148, 163, 184, 0.18);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 250, 252, 0.92));
}

.discover-market-brief__eyebrow {
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    letter-spacing: var(--ifinsta-letter-spacing-wider);
    text-transform: uppercase;
    color: var(--ifinsta-primary-700);
}

.discover-market-brief__title {
    margin: 0;
    font-size: var(--ifinsta-text-base);
    line-height: var(--ifinsta-leading-snug);
}

.discover-market-brief__chips,
.discover-market-brief__list {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-market-brief__chips {
    justify-content: start;
}

.discover-market-brief__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-2-5) var(--ifinsta-space-3);
    border-radius: var(--ifinsta-radius-lg);
    border: 1px solid rgba(148, 163, 184, 0.16);
    background: rgba(255, 255, 255, 0.88);
    color: var(--ifinsta-text);
    text-decoration: none;
    font-size: var(--ifinsta-text-sm);
}

.discover-market-brief__row strong,
.discover-market-brief__row span:last-child {
    color: var(--ifinsta-text);
    font-weight: var(--ifinsta-font-semibold);
}

.discover-market-brief__row small {
    display: block;
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-xs);
    margin-top: 0.15rem;
}

.discover-browse-rails {
    display: grid;
    gap: var(--ifinsta-space-4);
}

.discover-browse-rail {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-browse-rail__label {
    color: var(--ifinsta-text-muted);
}

.discover-category-chip--active {
    border-color: rgba(37, 99, 235, 0.28);
    background: rgba(37, 99, 235, 0.08);
    color: var(--ifinsta-primary-700);
}

.discover-section-header--rail {
    align-items: center;
}

.discover-lane-shell {
    display: grid;
    gap: var(--ifinsta-space-4);
}

.discover-lane {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(240px, 300px);
    gap: var(--ifinsta-space-4);
    min-width: 0;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scroll-snap-type: x proximity;
    padding-bottom: var(--ifinsta-space-1);
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.discover-lane::-webkit-scrollbar {
    display: none;
}

.discover-lane>* {
    min-width: 0;
    scroll-snap-align: start;
}

.discover-lane--stories {
    grid-auto-columns: minmax(72px, 88px);
}

.discover-lane--products {
    grid-auto-columns: minmax(220px, 250px);
}

.discover-lane--stores {
    grid-auto-columns: minmax(250px, 300px);
}

.discover-rail-controls {
    display: flex;
    justify-content: flex-end;
    gap: var(--ifinsta-space-2);
}

.discover-rail-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    padding: 0;
    border: 1px solid rgba(148, 163, 184, 0.24);
    border-radius: var(--ifinsta-radius-full);
    background: rgba(255, 255, 255, 0.92);
    color: var(--ifinsta-text);
    cursor: pointer;
    transition: var(--ifinsta-transition-fast);
}

.discover-rail-btn:hover:not(:disabled) {
    border-color: rgba(37, 99, 235, 0.28);
    color: var(--ifinsta-primary-700);
    transform: translateY(-1px);
}

.discover-rail-btn:disabled {
    opacity: 0.42;
    cursor: default;
}

.discover-band {
    display: grid;
    grid-template-columns: minmax(0, 1.16fr) minmax(320px, 0.84fr);
    gap: var(--ifinsta-space-4);
    align-items: stretch;
}

.discover-band__hero,
.discover-cluster {
    min-width: 0;
}

.discover-cluster {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--ifinsta-space-4);
    align-content: start;
}

.discover-grid--dense {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 280px));
    justify-content: start;
}

.discover-grid--products-dense {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 180px), 236px));
    justify-content: start;
}

.discover-card__image--contain {
    object-fit: contain;
    padding: var(--ifinsta-space-4);
    background: var(--ifinsta-bg-secondary);
}

.discover-card__image-placeholder--store {
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.16), rgba(14, 165, 233, 0.08));
    color: var(--ifinsta-primary-700);
    font-size: clamp(1.75rem, 3vw, 2.25rem);
    font-weight: var(--ifinsta-font-bold);
    text-transform: uppercase;
}

.discover-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.discover-card--hero {
    border-radius: var(--ifinsta-radius-xl);
    box-shadow: var(--ifinsta-shadow-sm);
}

.discover-card--hero .discover-card__image-wrap {
    aspect-ratio: 16 / 10;
}

.discover-card--hero .discover-card__content {
    padding: var(--ifinsta-space-5);
    gap: var(--ifinsta-space-1);
}

.discover-card--hero .discover-card__title {
    font-size: clamp(var(--ifinsta-text-lg), 2vw, var(--ifinsta-text-2xl));
}

.discover-card--compact .discover-card__image-wrap {
    aspect-ratio: 5 / 4;
}

.discover-card--compact .discover-card__content {
    padding: var(--ifinsta-space-3);
}

.discover-card--compact .discover-card__title,
.discover-card--lane .discover-card__title {
    font-size: var(--ifinsta-text-base);
}

.discover-card--lane {
    border: 1px solid #e8eaed;
    border-radius: 4px;
}

.discover-card--product.discover-card--lane .discover-card__image-wrap {
    aspect-ratio: 4 / 5;
}

.discover-card--product.discover-card--grid .discover-card__image-wrap {
    aspect-ratio: 4 / 5;
}

.discover-story-avatar--add {
    display: flex;
    align-items: center;
    justify-content: center;
    border-style: dashed;
    background: rgba(37, 99, 235, 0.08);
    color: var(--ifinsta-primary-700);
}

.discover-story-avatar--fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.14), rgba(14, 165, 233, 0.08));
    color: var(--ifinsta-primary-700);
    font-size: 1.125rem;
    font-weight: var(--ifinsta-font-bold);
    text-transform: uppercase;
}

.discover-tabs--market {
    margin: 0;
}

/* Storefront inline tabs — live inside profile row, right-aligned */
.discover-tabs--storefront {
    border-bottom: none;
    gap: var(--ifinsta-space-5);
    align-self: flex-end;
    padding-bottom: var(--ifinsta-space-2);
    flex-shrink: 0;
}

.discover-tabs--storefront .discover-tab {
    padding: var(--ifinsta-space-2) 0;
    font-size: var(--ifinsta-text-sm);
}

.discover-copilot {
    display: grid;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-3);
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: var(--ifinsta-radius-xl);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 250, 252, 0.94)),
        radial-gradient(circle at top right, rgba(37, 99, 235, 0.08), transparent 38%);
    box-shadow: var(--ifinsta-shadow-xs);
}

.discover-copilot__shell,
.discover-copilot__intro,
.discover-copilot__form,
.discover-copilot__canvas,
.discover-copilot__tray,
.discover-copilot-advisor {
    display: grid;
    gap: var(--ifinsta-space-2);
}

/* Prevent CSS display:grid from overriding the HTML hidden attribute */
.discover-copilot__canvas[hidden],
.discover-copilot__tray[hidden] {
    display: none;
}

.discover-copilot__eyebrow,
.discover-copilot-advisor__eyebrow,
.discover-copilot__entity-type,
.discover-copilot__tray-eyebrow {
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    letter-spacing: var(--ifinsta-letter-spacing-wider);
    text-transform: uppercase;
    color: var(--ifinsta-primary-700);
}

.discover-copilot__title,
.discover-copilot-advisor__title,
.discover-copilot__tray-title {
    margin: 0;
    line-height: var(--ifinsta-leading-tight);
}

.discover-copilot__title {
    font-size: clamp(var(--ifinsta-text-base), 1.5vw, var(--ifinsta-text-xl));
}

.discover-copilot__text,
.discover-copilot__status,
.discover-copilot__summary,
.discover-copilot-advisor__summary,
.discover-copilot-advisor__signal-detail,
.discover-copilot__entity-card span,
.discover-copilot__tray-row span {
    margin: 0;
    color: var(--ifinsta-text-secondary);
    line-height: 1.45;
    font-size: var(--ifinsta-text-sm);
}

.discover-copilot__input-wrap {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: var(--ifinsta-space-2);
    align-items: center;
}

.discover-copilot__input {
    width: 100%;
    min-height: 2.75rem;
    padding: 0 var(--ifinsta-space-3);
    border: 1px solid rgba(148, 163, 184, 0.28);
    border-radius: var(--ifinsta-radius-full);
    background: rgba(255, 255, 255, 0.98);
    font: inherit;
    color: var(--ifinsta-text);
}

.discover-copilot__input:focus {
    outline: none;
    border-color: rgba(37, 99, 235, 0.35);
    box-shadow: var(--ifinsta-input-focus-shadow);
}

.discover-copilot__submit {
    min-height: 2.75rem;
    white-space: nowrap;
}

.discover-copilot__chips,
.discover-copilot__suggestions,
.discover-copilot-advisor__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ifinsta-space-2);
}

.discover-copilot__chip,
.discover-copilot__suggestion {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0 var(--ifinsta-space-2-5);
    border: 1px solid rgba(148, 163, 184, 0.22);
    border-radius: var(--ifinsta-radius-full);
    background: rgba(255, 255, 255, 0.94);
    color: var(--ifinsta-text);
    font: inherit;
    font-size: var(--ifinsta-text-xs);
    cursor: pointer;
    transition: var(--ifinsta-transition-fast);
}

.discover-copilot__chip:hover,
.discover-copilot__suggestion:hover {
    border-color: rgba(37, 99, 235, 0.28);
    color: var(--ifinsta-primary-700);
    transform: translateY(-1px);
}

.discover-copilot__canvas {
    padding: var(--ifinsta-space-2-5);
    border-radius: var(--ifinsta-radius-lg);
    background: rgba(248, 250, 252, 0.8);
    border: 1px solid rgba(148, 163, 184, 0.16);
}

.discover-copilot__summary {
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-medium);
    color: var(--ifinsta-text);
}

.discover-copilot__entity-grid,
.discover-copilot__tray-list,
.discover-copilot-advisor__signals {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-copilot__entity-grid {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.discover-copilot__entity-card,
.discover-copilot__tray-row,
.discover-copilot-advisor__signal {
    display: grid;
    gap: 0.25rem;
    padding: var(--ifinsta-space-3);
    border-radius: var(--ifinsta-radius-lg);
    text-decoration: none;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(148, 163, 184, 0.18);
    color: var(--ifinsta-text);
}

.discover-copilot__entity-card strong,
.discover-copilot__tray-row strong {
    color: var(--ifinsta-text);
}

.discover-copilot__tray {
    padding: var(--ifinsta-space-3);
    border-radius: var(--ifinsta-radius-lg);
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(37, 99, 235, 0.14);
}

.discover-copilot-advisor {
    padding: var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-xl);
    border: 1px solid rgba(37, 99, 235, 0.14);
    background:
        linear-gradient(180deg, rgba(239, 246, 255, 0.88), rgba(255, 255, 255, 0.96));
}

.discover-copilot-advisor__signal--ready {
    border-color: rgba(22, 163, 74, 0.18);
}

.discover-copilot-advisor__signal--attention {
    border-color: rgba(245, 158, 11, 0.24);
}

.discover-copilot-advisor__signal--missing {
    border-color: rgba(239, 68, 68, 0.18);
}

.discover-card--highlighted,
.discover-category-chip--highlighted,
.discover-quick-link--highlighted,
.discover-section--highlighted {
    transition: var(--ifinsta-transition-fast);
}

.discover-card--highlighted {
    border-color: rgba(37, 99, 235, 0.34);
    box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.1), var(--ifinsta-shadow-sm);
}

.discover-category-chip--highlighted,
.discover-quick-link--highlighted {
    border-color: rgba(37, 99, 235, 0.34);
    background: rgba(37, 99, 235, 0.1);
    color: var(--ifinsta-primary-700);
}

.discover-section--highlighted {
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.08);
}

@media (max-width: 1024px) {

    .discover-contact-layout,
    .discover-product-detail-grid,
    .discover-layout-sidebar--public {
        grid-template-columns: 1fr;
    }

    .discover-market-hero__tools,
    .discover-market-hero__masthead,
    .discover-band,
    .discover-market-briefs {
        grid-template-columns: 1fr;
    }

    .discover-market-hero__signals {
        grid-template-columns: 1fr;
    }

    .discover-market-header__content {
        align-items: start;
    }

    .discover-copilot__entity-grid {
        grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    }
}

@media (max-width: 768px) {


    .discover-grid--products {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .discover-brand-context__surface,
    .discover-form-grid--two-up,
    .discover-product-gallery {
        grid-template-columns: 1fr;
    }

    .discover-market-stack {
        gap: var(--ifinsta-space-5);
    }

    .discover-market-hero,
    .discover-market-header {
        padding: var(--ifinsta-space-4);
        border-radius: var(--ifinsta-radius-xl);
    }

    .discover-market-stats,
    .discover-cluster {
        grid-template-columns: 1fr;
    }

    .discover-market-header__content {
        grid-template-columns: 1fr;
    }

    .discover-copilot__input-wrap {
        grid-template-columns: 1fr;
    }

    .discover-rail-controls {
        display: none;
    }

    .discover-lane {
        gap: var(--ifinsta-space-3);
    }

    .discover-lane--stores {
        grid-auto-columns: minmax(220px, 80vw);
    }

    .discover-lane--products {
        grid-auto-columns: minmax(200px, 72vw);
    }

    .discover-brand-context__actions {
        width: 100%;
    }

    .discover-product-thumbnails {
        grid-auto-flow: column;
        grid-auto-columns: minmax(4.5rem, 1fr);
        overflow-x: auto;
        padding-bottom: var(--ifinsta-space-1);
    }

    .discover-pagination {
        justify-content: center;
    }
}

@media (max-width: 640px) {
    .discover-container--public {
        padding: 0 var(--ifinsta-space-4);
    }

    .discover-market-hero,
    .discover-market-header {
        padding: var(--ifinsta-space-4);
    }

    .discover-market-hero__left {
        gap: var(--ifinsta-space-3);
    }

    .discover-market-hero__search-block {
        padding: var(--ifinsta-space-3);
    }

    .discover-market-hero__copy {
        max-width: none;
    }

    .discover-market-stat {
        padding: var(--ifinsta-space-2-5);
    }

    .discover-quick-link {
        min-height: 2.25rem;
        padding: 0 var(--ifinsta-space-3);
    }

    .discover-grid--dense,
    .discover-grid--products-dense {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .discover-store-meta__item {
        max-width: 100%;
    }

    .discover-contact-card,
    .discover-product-info,
    .discover-product-gallery,
    .discover-brand-context__surface {
        padding: var(--ifinsta-space-4);
    }

    .discover-contact-method {
        padding: var(--ifinsta-space-3);
    }

    .discover-copilot,
    .discover-copilot-advisor {
        padding: var(--ifinsta-space-3);
    }

    .discover-cart-feedback {
        left: var(--ifinsta-space-4);
        right: var(--ifinsta-space-4);
        bottom: var(--ifinsta-space-4);
    }

    .discover-checkout-layout,
    .discover-checkout-item {
        grid-template-columns: 1fr;
    }

    .discover-checkout-panel--summary {
        position: static;
    }

    .discover-checkout-item__controls {
        justify-items: start;
    }

    .discover-cart-modal__actions {
        justify-content: stretch;
    }

    .discover-cart-modal__actions .discover-btn {
        width: 100%;
    }
}

/* ==========================================================================
   DISCOVER MANAGEMENT SETTINGS
   Storefront settings experience inside the app shell.
   ========================================================================== */
.discover-manage {
    padding: var(--ifinsta-space-6) 0 var(--ifinsta-space-8);
}

.discover-manage__container {
    max-width: 1280px;
}

.discover-manage__header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--ifinsta-space-5);
    margin-bottom: var(--ifinsta-space-6);
}

.discover-manage__header-copy {
    display: grid;
    gap: var(--ifinsta-space-2);
    max-width: 50rem;
}

.discover-manage__eyebrow,
.discover-manage-card__eyebrow {
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    letter-spacing: var(--ifinsta-letter-spacing-wider);
    text-transform: uppercase;
    color: var(--ifinsta-primary-700);
}

.discover-manage__title {
    margin: 0;
    font-size: clamp(2rem, 3vw, 2.75rem);
    line-height: var(--ifinsta-leading-tight);
    letter-spacing: -0.03em;
}

.discover-manage__lead {
    margin: 0;
    color: var(--ifinsta-text-secondary);
    max-width: 42rem;
}

.discover-manage__header-meta {
    display: grid;
    justify-items: end;
    gap: var(--ifinsta-space-2);
}

.discover-manage__status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.25rem;
    padding: 0 var(--ifinsta-space-3);
    border-radius: var(--ifinsta-radius-full);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
}

.discover-manage__status--live {
    background: rgba(22, 163, 74, 0.12);
    color: #166534;
}

.discover-manage__status--draft {
    background: rgba(148, 163, 184, 0.16);
    color: #475569;
}

.discover-manage__status--tier {
    background: rgba(37, 99, 235, 0.08);
    color: var(--ifinsta-primary-700);
}

.discover-manage__header-path {
    display: grid;
    gap: 0.15rem;
    text-align: right;
}

.discover-manage__header-path span {
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-xs);
    text-transform: uppercase;
    letter-spacing: var(--ifinsta-letter-spacing-wider);
}

.discover-manage__header-path strong {
    font-size: var(--ifinsta-text-sm);
    word-break: break-all;
}

.discover-manage__shell {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(320px, 0.72fr);
    gap: var(--ifinsta-space-5);
    align-items: start;
}

.discover-manage__main,
.discover-manage__sidebar {
    display: grid;
    gap: var(--ifinsta-space-5);
}

.discover-manage-card {
    display: grid;
    gap: var(--ifinsta-space-4);
    padding: clamp(1.25rem, 1.8vw, 1.75rem);
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: var(--ifinsta-radius-2xl);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.96));
    box-shadow: var(--ifinsta-shadow-xs);
}

.discover-manage-card--sticky {
    position: sticky;
    top: calc(var(--ifinsta-space-5) + 4rem);
}

.discover-manage-card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--ifinsta-space-4);
}

.discover-manage-card__header--compact {
    gap: var(--ifinsta-space-3);
}

.discover-manage-card__title {
    margin: 0.2rem 0 0;
    font-size: clamp(var(--ifinsta-text-lg), 1.6vw, var(--ifinsta-text-xl));
    line-height: var(--ifinsta-leading-tight);
}

.discover-manage-card__text {
    margin: 0;
    max-width: 28rem;
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-text-sm);
    line-height: 1.55;
}

.discover-manage-grid {
    display: grid;
    gap: var(--ifinsta-space-4);
}

.discover-manage-grid--two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.discover-manage-field {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-manage-field__label {
    color: var(--ifinsta-text);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
}

.discover-manage-field__control {
    width: 100%;
    min-height: 2.875rem;
    padding: 0.875rem 1rem;
    border: 1px solid rgba(148, 163, 184, 0.24);
    border-radius: var(--ifinsta-radius-lg);
    background: rgba(255, 255, 255, 0.94);
    color: var(--ifinsta-text);
    font: inherit;
    transition: var(--ifinsta-input-transition);
}

.discover-manage-field__control:focus {
    outline: none;
    border-color: var(--ifinsta-primary-500);
    box-shadow: var(--ifinsta-input-focus-shadow);
}

.discover-manage-field__control--textarea {
    resize: vertical;
    min-height: 8rem;
}

.discover-manage-field__control--file {
    padding: 0.7rem 0.85rem;
}

.discover-manage-upload {
    display: grid;
    gap: var(--ifinsta-space-4);
    padding: var(--ifinsta-space-4);
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: var(--ifinsta-radius-xl);
    background: rgba(255, 255, 255, 0.78);
}

.discover-manage-upload__preview {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--ifinsta-radius-xl);
    background:
        linear-gradient(135deg, rgba(37, 99, 235, 0.08), rgba(14, 165, 233, 0.12));
    color: var(--ifinsta-primary-700);
    font-size: 1.6rem;
    font-weight: var(--ifinsta-font-bold);
}

.discover-manage-upload__preview--logo {
    width: 6rem;
    height: 6rem;
}

.discover-manage-upload__preview--cover {
    min-height: 10rem;
}

.discover-manage-upload__preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.discover-manage-upload__body {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-manage-upload__text {
    margin: 0;
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-text-sm);
    line-height: 1.5;
}

.discover-manage-choice-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--ifinsta-space-3);
}

.discover-manage-choice-grid--categories {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.discover-manage-choice {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-4);
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: var(--ifinsta-radius-xl);
    background: rgba(255, 255, 255, 0.88);
    cursor: pointer;
    transition: var(--ifinsta-transition-fast);
}

.discover-manage-choice:hover {
    border-color: rgba(37, 99, 235, 0.24);
    transform: translateY(-1px);
}

.discover-manage-choice input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.discover-manage-choice__indicator {
    width: 1.15rem;
    height: 1.15rem;
    flex-shrink: 0;
    margin-top: 0.15rem;
    border-radius: 0.35rem;
    border: 1.5px solid rgba(148, 163, 184, 0.42);
    background: rgba(255, 255, 255, 0.9);
    transition: var(--ifinsta-transition-fast);
}

.discover-manage-choice input:checked+.discover-manage-choice__indicator {
    border-color: var(--ifinsta-primary-600);
    background: var(--ifinsta-primary-600);
    box-shadow: inset 0 0 0 3px rgba(255, 255, 255, 0.92);
}

.discover-manage-choice__content {
    display: grid;
    gap: 0.25rem;
    min-width: 0;
}

.discover-manage-choice__content strong {
    color: var(--ifinsta-text);
    font-size: var(--ifinsta-text-sm);
    line-height: 1.4;
}

.discover-manage-choice__content small {
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-text-xs);
    line-height: 1.45;
}

.discover-manage-empty {
    margin: 0;
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-text-sm);
}

.discover-manage-theme-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--ifinsta-space-3);
}

.discover-manage-theme {
    position: relative;
    display: grid;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-3);
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: var(--ifinsta-radius-xl);
    background: rgba(255, 255, 255, 0.9);
    cursor: pointer;
    transition: var(--ifinsta-transition-fast);
}

.discover-manage-theme:hover {
    border-color: rgba(37, 99, 235, 0.24);
    transform: translateY(-1px);
}

.discover-manage-theme--active {
    border-color: rgba(37, 99, 235, 0.34);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.08);
}

.discover-manage-theme input {
    position: absolute;
    opacity: 0;
    inset: 0;
    cursor: pointer;
}

.discover-manage-theme__canvas {
    position: relative;
    min-height: 5rem;
    border-radius: var(--ifinsta-radius-lg);
    background:
        radial-gradient(circle at top right, rgba(255, 255, 255, 0.52), transparent 35%),
        linear-gradient(135deg,
            var(--theme-preview-surface),
            color-mix(in srgb, var(--theme-preview-primary) 35%, var(--theme-preview-surface)),
            color-mix(in srgb, var(--theme-preview-secondary) 64%, white));
    overflow: hidden;
}

.discover-manage-theme__canvas::before,
.discover-manage-theme__canvas::after {
    content: "";
    position: absolute;
    left: 0.9rem;
    right: 0.9rem;
    border-radius: var(--ifinsta-radius-md);
    background: rgba(255, 255, 255, 0.9);
}

.discover-manage-theme__canvas::before {
    top: 0.95rem;
    height: 0.65rem;
}

.discover-manage-theme__canvas::after {
    top: 2rem;
    height: 1.35rem;
}

.discover-manage-theme__mark {
    position: absolute;
    top: 0.8rem;
    right: 0.8rem;
    width: 1.1rem;
    height: 1.1rem;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.88);
}

.discover-manage-theme__swatches {
    display: flex;
    gap: var(--ifinsta-space-2);
}

.discover-manage-theme__swatch {
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
    border: 1px solid rgba(15, 23, 42, 0.08);
}

.discover-manage-theme__info {
    display: grid;
    gap: 0.2rem;
}

.discover-manage-theme__name {
    color: var(--ifinsta-text);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
}

.discover-manage-theme__hint {
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-text-xs);
    line-height: 1.45;
}

.discover-manage-color-control {
    display: inline-flex;
    align-items: center;
    gap: var(--ifinsta-space-3);
    padding: 0.6rem 0.75rem;
    border: 1px solid rgba(148, 163, 184, 0.24);
    border-radius: var(--ifinsta-radius-lg);
    background: rgba(255, 255, 255, 0.92);
}

.discover-manage-color-control__input {
    width: 3rem;
    height: 2.5rem;
    border: none;
    background: transparent;
    padding: 0;
    cursor: pointer;
}

.discover-manage-color-control__value {
    font-family: var(--ifinsta-font-mono);
    font-size: var(--ifinsta-text-sm);
    color: var(--ifinsta-text);
}

.discover-manage-preview {
    --discover-manage-accent: #6366f1;
    --discover-manage-secondary: #818cf8;
    --discover-manage-surface: #eef2ff;
    display: grid;
    gap: var(--ifinsta-space-4);
    padding: var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-xl);
    border: 1px solid rgba(148, 163, 184, 0.16);
    background:
        radial-gradient(circle at top right, rgba(255, 255, 255, 0.52), transparent 30%),
        linear-gradient(160deg,
            var(--discover-manage-surface) 0%,
            color-mix(in srgb, var(--discover-manage-accent) 20%, white) 52%,
            color-mix(in srgb, var(--discover-manage-secondary) 18%, white) 100%);
}

.discover-manage-preview__hero {
    display: grid;
    gap: var(--ifinsta-space-3);
}

.discover-manage-preview__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 2rem;
    padding: 0 var(--ifinsta-space-3);
    border-radius: var(--ifinsta-radius-full);
    background: rgba(255, 255, 255, 0.82);
    color: var(--ifinsta-text);
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    letter-spacing: var(--ifinsta-letter-spacing-wider);
    text-transform: uppercase;
}

.discover-manage-preview__brand {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-3);
}

.discover-manage-preview__logo {
    width: 3.75rem;
    height: 3.75rem;
    border-radius: 1rem;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--discover-manage-accent), var(--discover-manage-secondary));
    color: #fff;
    font-size: 1.35rem;
    font-weight: var(--ifinsta-font-bold);
    flex-shrink: 0;
}

.discover-manage-preview__logo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.discover-manage-preview__title {
    margin: 0;
    font-size: var(--ifinsta-text-lg);
    line-height: var(--ifinsta-leading-tight);
}

.discover-manage-preview__subtitle {
    margin: 0.3rem 0 0;
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-text-sm);
    line-height: 1.45;
}

.discover-manage-preview__meta,
.discover-manage-summary {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-manage-preview__meta-row,
.discover-manage-summary__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ifinsta-space-3);
    padding: 0.8rem 0.95rem;
    border-radius: var(--ifinsta-radius-lg);
    background: rgba(255, 255, 255, 0.84);
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-text-sm);
}

.discover-manage-preview__meta-row strong,
.discover-manage-summary__row strong {
    color: var(--ifinsta-text);
}

.discover-manage-preview__chips {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ifinsta-space-2);
}

.discover-manage-preview__chips span {
    display: inline-flex;
    align-items: center;
    min-height: 1.9rem;
    padding: 0 var(--ifinsta-space-2-5);
    border-radius: var(--ifinsta-radius-full);
    background: rgba(255, 255, 255, 0.82);
    color: var(--ifinsta-text);
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-medium);
}

.discover-manage-actions {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-manage-publish {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-3);
    flex-wrap: wrap;
}

@media (max-width: 1180px) {
    .discover-manage__shell {
        grid-template-columns: 1fr;
    }

    .discover-manage-card--sticky {
        position: static;
    }
}

@media (max-width: 1024px) {
    .discover-manage-theme-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .discover-manage-choice-grid--categories {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    .discover-manage {
        padding: var(--ifinsta-space-5) 0 var(--ifinsta-space-7);
    }

    .discover-manage__header,
    .discover-manage-card__header {
        flex-direction: column;
        align-items: flex-start;
    }

    .discover-manage__header-meta {
        justify-items: start;
    }

    .discover-manage__header-path {
        text-align: left;
    }

    .discover-manage-grid--two,
    .discover-manage-choice-grid,
    .discover-manage-choice-grid--categories {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .discover-manage__container {
        padding: 0 var(--ifinsta-space-4);
    }

    .discover-manage-theme-grid {
        grid-template-columns: 1fr;
    }

    .discover-manage-publish .discover-btn,
    .discover-manage-actions .discover-btn {
        width: 100%;
    }
}

/* ==========================================================================
   DISCOVER MANAGEMENT — CATALOG, ANALYTICS, STORIES, REVIEW QUEUE
   Phase 1-4 design system components.
   ========================================================================== */

/* ── Page header ──────────────────────────────────────────────────── */
.dc-mgmt-page-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: var(--ifinsta-space-5);
    margin-bottom: var(--ifinsta-space-6);
    flex-wrap: wrap;
}

.dc-mgmt-page-header__copy {
    min-width: 0;
}

.dc-mgmt-page-header__actions {
    display: flex;
    gap: var(--ifinsta-space-2);
    align-items: center;
    flex-shrink: 0;
}

.dc-mgmt-h1 {
    margin: 0 0 var(--ifinsta-space-2);
    font-size: clamp(1.75rem, 3vw, 2.25rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.15;
    color: var(--ifinsta-text);
}

.dc-mgmt-lead {
    margin: 0;
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-sm);
    max-width: 56ch;
}

/* ── 4-stat row ──────────────────────────────────────────────────── */
.dc-stat-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--ifinsta-space-4);
    margin-bottom: var(--ifinsta-space-6);
}

@media (max-width: 1024px) {
    .dc-stat-row {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .dc-stat-row {
        grid-template-columns: 1fr;
    }
}

.dc-stat-card {
    background: var(--ifinsta-surface);
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-lg);
    padding: 20px 24px;
    box-shadow: var(--ifinsta-shadow-xs);
}

.dc-stat-card__label {
    font-size: 0.69rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--ifinsta-text-muted);
    margin-bottom: var(--ifinsta-space-2);
}

.dc-stat-card__value {
    font-family: var(--ifinsta-font-mono);
    font-size: 2rem;
    font-weight: 800;
    line-height: 1;
    color: var(--ifinsta-text);
}

.dc-stat-card__value--green {
    color: #047857;
}

.dc-stat-card__value--blue {
    color: #1D4ED8;
}

.dc-stat-card__value--orange {
    color: #C2410C;
}

.dc-stat-card__sub {
    font-size: 0.75rem;
    color: var(--ifinsta-text-muted);
    margin-top: var(--ifinsta-space-1);
}

/* ── Mgmt shell: 2-column ─────────────────────────────────────────── */
.dc-mgmt-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(260px, 0.6fr);
    gap: var(--ifinsta-space-5);
    align-items: start;
}

@media (max-width: 1100px) {
    .dc-mgmt-shell {
        grid-template-columns: 1fr;
    }
}

.dc-mgmt-main {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-3);
}

.dc-mgmt-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-3);
}

/* ── URL-addressable Tab bar ──────────────────────────────────────── */
.dc-tab-bar {
    display: flex;
    gap: 4px;
    border-bottom: 2px solid var(--ifinsta-border);
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    flex-shrink: 0;
}

.dc-tab-bar::-webkit-scrollbar {
    display: none;
}

.dc-tab {
    display: inline-flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    padding: var(--ifinsta-space-2-5) var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-full) var(--ifinsta-radius-full) 0 0;
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    color: var(--ifinsta-text-muted);
    text-decoration: none;
    white-space: nowrap;
    border: 1px solid transparent;
    border-bottom: none;
    transition: var(--ifinsta-transition-fast);
    position: relative;
    bottom: -2px;
}

.dc-tab:hover {
    color: var(--ifinsta-text);
    background: var(--ifinsta-bg-secondary);
}

.dc-tab--active {
    background: var(--ifinsta-surface);
    color: var(--ifinsta-primary-600);
    border-color: var(--ifinsta-border);
    border-bottom-color: var(--ifinsta-surface);
}

.dc-tab__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.4rem;
    height: 1.4rem;
    padding: 0 var(--ifinsta-space-1-5);
    border-radius: var(--ifinsta-radius-full);
    background: rgba(15, 23, 42, 0.07);
    color: var(--ifinsta-text-muted);
    font-size: 0.68rem;
    font-weight: 700;
    font-family: var(--ifinsta-font-mono);
}

.dc-tab__count--blue {
    background: #EFF6FF;
    color: #1D4ED8;
}

.dc-tab__count--orange {
    background: #FFF7ED;
    color: #C2410C;
}

/* ── Tab panel ───────────────────────────────────────────────────── */
.dc-panel {
    background: var(--ifinsta-surface);
    border: 1px solid var(--ifinsta-border);
    border-top: none;
    border-radius: 0 0 var(--ifinsta-radius-lg) var(--ifinsta-radius-lg);
    overflow: hidden;
}

/* ── Dense table ─────────────────────────────────────────────────── */
.dc-table-wrap {
    overflow-x: auto;
}

.dc-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.85rem;
}

.dc-table thead tr {
    background: var(--ifinsta-bg-secondary);
}

.dc-table th {
    padding: 10px 14px;
    text-align: left;
    font-size: 0.69rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--ifinsta-text-muted);
    border-bottom: 1px solid var(--ifinsta-border);
    white-space: nowrap;
}

.dc-table td {
    padding: 0 14px;
    height: 48px;
    vertical-align: middle;
    border-bottom: 1px solid var(--ifinsta-border-light);
}

.dc-table tbody tr:last-child td {
    border-bottom: none;
}

.dc-row {
    transition: background var(--ifinsta-duration-fast);
}

.dc-row--selectable:hover {
    background: var(--ifinsta-primary-alpha-04, rgba(79, 70, 229, 0.03));
}

.dc-row--selectable:has(.dc-row-check:checked) {
    background: rgba(79, 70, 229, 0.06);
}

/* ── Thumbnail + preview ─────────────────────────────────────────── */
.dc-thumb-cell {
    width: 48px;
    padding: 0 8px 0 14px;
}

.dc-thumb-wrap {
    position: relative;
    width: 36px;
    height: 36px;
    border-radius: var(--ifinsta-radius-md);
    overflow: visible;
    cursor: default;
    outline: none;
    display: inline-block;
}

.dc-thumb-wrap:focus-visible {
    box-shadow: var(--ifinsta-shadow-focus);
    border-radius: var(--ifinsta-radius-md);
}

.dc-thumb {
    width: 36px;
    height: 36px;
    border-radius: var(--ifinsta-radius-md);
    object-fit: cover;
    border: 1px solid var(--ifinsta-border-light);
    display: block;
}

.dc-thumb--empty {
    width: 36px;
    height: 36px;
    border-radius: var(--ifinsta-radius-md);
    background: var(--ifinsta-bg-secondary);
    border: 1px solid var(--ifinsta-border-light);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ifinsta-text-muted);
}

/* ── Singleton hover preview panel ──────────────────────────────── */
.dc-hover-preview-singleton {
    position: absolute;
    z-index: 120;
    width: 260px;
    background: var(--ifinsta-surface);
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-lg);
    box-shadow: var(--ifinsta-shadow-md);
    overflow: hidden;
    pointer-events: auto;
}

.dc-hover-preview__img-wrap {
    width: 100%;
    height: 200px;
    background: var(--ifinsta-bg-secondary);
    overflow: hidden;
}

.dc-hover-preview__img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.dc-hover-preview__img-empty {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ifinsta-text-muted);
}

.dc-hover-preview__body {
    padding: 12px 14px;
    display: grid;
    gap: 4px;
}

.dc-hover-preview__name {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--ifinsta-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dc-hover-preview__sku {
    font-family: var(--ifinsta-font-mono);
    font-size: 0.72rem;
    color: var(--ifinsta-text-muted);
}

.dc-hover-preview__desc {
    font-size: 0.78rem;
    color: var(--ifinsta-text-muted);
    margin: 4px 0 6px;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.dc-hover-preview__moderation-note {
    font-size: 0.75rem;
    color: #C2410C;
    background: #FFF7ED;
    border-left: 3px solid #C2410C;
    padding: 6px 8px;
    border-radius: 0 4px 4px 0;
    margin: 4px 0;
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
    .dc-hover-preview-singleton {
        transition: none;
    }
}

/* ── Inline moderation note row ──────────────────────────────────── */
.dc-moderation-note-row td {
    padding: 0;
}

.dc-moderation-note {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 10px 14px;
    background: #FFF7ED;
    border-left: 3px solid #C2410C;
    font-size: 0.8rem;
    color: #7C2D12;
}

.dc-moderation-note svg {
    flex-shrink: 0;
    margin-top: 1px;
}

/* ── Bulk action bar ─────────────────────────────────────────────── */
.dc-bulk-bar {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-3);
    padding: 10px 14px;
    background: var(--ifinsta-surface);
    border-bottom: 1px solid var(--ifinsta-border);
    flex-wrap: wrap;
    position: sticky;
    top: 0;
    z-index: 10;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.06);
}

.dc-bulk-bar__count {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--ifinsta-text);
    white-space: nowrap;
}

.dc-bulk-bar__actions {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    flex: 1;
    flex-wrap: wrap;
}

.dc-bulk-bar__dismiss {
    margin-left: auto;
    background: none;
    border: none;
    color: var(--ifinsta-text-muted);
    cursor: pointer;
    font-size: 1rem;
    line-height: 1;
    padding: 4px;
    border-radius: var(--ifinsta-radius-full);
    transition: var(--ifinsta-transition-fast);
}

.dc-bulk-bar__dismiss:hover {
    background: var(--ifinsta-bg-secondary);
    color: var(--ifinsta-text);
}

.dc-bulk-select {
    min-height: 2.1rem;
    padding: 0 var(--ifinsta-space-3);
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-full);
    background: var(--ifinsta-surface);
    font-size: var(--ifinsta-text-sm);
    color: var(--ifinsta-text);
    font-family: var(--ifinsta-font-family);
    cursor: pointer;
}

/* ── Filter bar ──────────────────────────────────────────────────── */
.dc-filter-bar {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-3);
    padding: 12px 14px;
    border-bottom: 1px solid var(--ifinsta-border-light);
    flex-wrap: wrap;
}

.dc-filter-chips {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ifinsta-space-1-5);
    flex: 1;
}

.dc-filter-chip {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0 var(--ifinsta-space-3);
    border-radius: var(--ifinsta-radius-full);
    border: 1px solid var(--ifinsta-border);
    background: var(--ifinsta-surface);
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    text-decoration: none;
    transition: var(--ifinsta-transition-fast);
    white-space: nowrap;
}

.dc-filter-chip:hover {
    border-color: var(--ifinsta-primary-400);
    color: var(--ifinsta-primary-700);
    background: rgba(79, 70, 229, 0.05);
}

.dc-filter-chip--active {
    background: var(--ifinsta-primary-600);
    border-color: var(--ifinsta-primary-600);
    color: #fff;
}

.dc-filter-chip--active:hover {
    background: var(--ifinsta-primary-700);
    border-color: var(--ifinsta-primary-700);
    color: #fff;
}

.dc-filter-search-form {
    display: flex;
}

.dc-filter-search {
    min-height: 2rem;
    padding: 0 var(--ifinsta-space-3);
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-full);
    background: var(--ifinsta-surface);
    font-size: var(--ifinsta-text-xs);
    font-family: var(--ifinsta-font-family);
    color: var(--ifinsta-text);
    width: 180px;
    transition: var(--ifinsta-input-transition);
}

.dc-filter-search:focus {
    outline: none;
    border-color: var(--ifinsta-primary-500);
    box-shadow: var(--ifinsta-input-focus-shadow);
}

/* ── Row actions (hidden until hover) ───────────────────────────── */
.dc-row-actions {
    text-align: right;
    white-space: nowrap;
}

.dc-row-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: var(--ifinsta-radius-full);
    border: 1px solid transparent;
    background: transparent;
    color: var(--ifinsta-text-muted);
    cursor: pointer;
    transition: var(--ifinsta-transition-fast);
    opacity: 0;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0;
    font-family: var(--ifinsta-font-family);
}

.dc-row:hover .dc-row-btn,
.dc-row:focus-within .dc-row-btn {
    opacity: 1;
}

.dc-row-remove-btn:hover {
    background: #FFF1F2;
    color: #BE123C;
    border-color: #FECDD3;
}

.dc-row-withdraw-btn {
    width: auto;
    padding: 0 var(--ifinsta-space-2);
    font-size: var(--ifinsta-text-xs);
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-full);
}

.dc-row-withdraw-btn:hover {
    border-color: #C2410C;
    color: #C2410C;
    background: #FFF7ED;
}

/* ── Status pills ────────────────────────────────────────────────── */
.dc-status-pill {
    display: inline-flex;
    align-items: center;
    padding: 2px 10px;
    border-radius: var(--ifinsta-radius-full);
    font-size: 0.72rem;
    font-weight: 700;
    white-space: nowrap;
}

.dc-status-pill--green {
    background: #ECFDF5;
    color: #047857;
}

.dc-status-pill--blue {
    background: #EFF6FF;
    color: #1D4ED8;
}

.dc-status-pill--orange {
    background: #FFF7ED;
    color: #C2410C;
}

.dc-status-pill--red {
    background: #FFF1F2;
    color: #BE123C;
}

.dc-status-pill--gray {
    background: #F3F4F6;
    color: #6B7280;
}

/* ── AI signal chips ─────────────────────────────────────────────── */
.dc-ai-chip {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: var(--ifinsta-radius-full);
    font-size: 0.7rem;
    font-weight: 700;
    white-space: nowrap;
}

.dc-ai-chip--approve {
    background: #ECFDF5;
    color: #047857;
}

.dc-ai-chip--flag {
    background: #FFF7ED;
    color: #C2410C;
}

.dc-ai-chip--reject {
    background: #FFF1F2;
    color: #BE123C;
}

/* ── Department chip ─────────────────────────────────────────────── */
.dc-dept-chip {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: var(--ifinsta-radius-full);
    font-size: 0.72rem;
    font-weight: 600;
    background: #EEF2FF;
    color: #4F46E5;
    white-space: nowrap;
}

.dc-dept-chip--empty {
    background: transparent;
    color: var(--ifinsta-text-muted);
    font-weight: 400;
}

/* ── Stock badges ────────────────────────────────────────────────── */
.dc-stock-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: var(--ifinsta-radius-full);
    font-size: 0.72rem;
    font-weight: 700;
    white-space: nowrap;
}

.dc-stock-badge--in {
    background: #DCFCE7;
    color: #166534;
}

.dc-stock-badge--low {
    background: #F3F4F6;
    color: #4B5563;
}

.dc-stock-badge--out {
    background: #FFF1F2;
    color: #BE123C;
}

/* ── Eligibility chips ───────────────────────────────────────────── */
.dc-eligibility-chip {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: var(--ifinsta-radius-full);
    font-size: 0.7rem;
    font-weight: 700;
    white-space: nowrap;
}

.dc-eligibility-chip--ok {
    background: #ECFDF5;
    color: #047857;
}

.dc-eligibility-chip--warn {
    background: #FFFBEB;
    color: #D97706;
}

.dc-eligibility-chip--fail {
    background: #FFF1F2;
    color: #BE123C;
}

/* ── Monospace inline ────────────────────────────────────────────── */
.dc-product-name {
    font-weight: 700;
    font-size: 0.85rem;
    color: var(--ifinsta-text);
}

.dc-mono,
.dc-mono-inline {
    font-family: var(--ifinsta-font-mono);
    font-size: 0.78rem;
    color: var(--ifinsta-text-muted);
}

.dc-price {
    font-family: var(--ifinsta-font-mono);
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--ifinsta-primary-600);
    white-space: nowrap;
}

.dc-price--bargain {
    color: #047857;
}

/* ── Empty state ─────────────────────────────────────────────────── */
.dc-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--ifinsta-space-8) var(--ifinsta-space-4);
    gap: var(--ifinsta-space-3);
}

.dc-empty__icon {
    width: 48px;
    height: 48px;
    border-radius: var(--ifinsta-radius-full);
    background: var(--ifinsta-bg-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ifinsta-text-muted);
}

.dc-empty__title {
    margin: 0;
    font-size: var(--ifinsta-text-base);
    font-weight: 700;
    color: var(--ifinsta-text);
}

.dc-empty__text {
    margin: 0;
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-sm);
    max-width: 36ch;
}

/* ── Sidebar cards ───────────────────────────────────────────────── */
.dc-sidebar-card {
    background: var(--ifinsta-surface);
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-lg);
    padding: 18px 20px;
    box-shadow: var(--ifinsta-shadow-xs);
}

.dc-sidebar-card__title {
    margin: 0 0 6px;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--ifinsta-text-muted);
}

.dc-sidebar-card__sub {
    font-size: 0.72rem;
    color: var(--ifinsta-text-muted);
    margin-bottom: 10px;
}

.dc-sidebar-card__text {
    font-size: 0.8rem;
    color: var(--ifinsta-text-muted);
    line-height: 1.55;
    margin: 0;
}

/* ── Policy checklist ────────────────────────────────────────────── */
.dc-policy-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 6px;
}

.dc-policy-list__item {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    font-size: 0.78rem;
    color: var(--ifinsta-text);
    line-height: 1.45;
}

.dc-policy-list__item svg {
    flex-shrink: 0;
    margin-top: 1px;
}

/* ── Capacity bar ────────────────────────────────────────────────── */
.dc-capacity-bar {
    height: 6px;
    background: var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-full);
    overflow: hidden;
    margin: 8px 0;
}

.dc-capacity-bar__fill {
    height: 100%;
    background: var(--ifinsta-primary-600);
    border-radius: var(--ifinsta-radius-full);
    transition: width var(--ifinsta-duration-slow);
    max-width: 100%;
}

.dc-capacity-warning {
    font-size: 0.75rem;
    font-weight: 600;
    color: #C2410C;
    background: #FFF7ED;
    border-radius: var(--ifinsta-radius-md);
    padding: 6px 10px;
    margin-top: 8px;
}

/* ── Batch rows (sidebar) ────────────────────────────────────────── */
.dc-batch-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--ifinsta-space-2);
    padding: 8px 0;
    border-bottom: 1px solid var(--ifinsta-border-light);
}

.dc-batch-row:last-child {
    border-bottom: none;
}

.dc-batch-row__label {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--ifinsta-text);
}

.dc-batch-row__meta {
    font-size: 0.7rem;
    color: var(--ifinsta-text-muted);
    margin-top: 2px;
}

.dc-batch-status {
    font-size: 0.7rem;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: var(--ifinsta-radius-full);
    background: var(--ifinsta-bg-secondary);
    color: var(--ifinsta-text-muted);
    white-space: nowrap;
    flex-shrink: 0;
}

/* ── Small button variant ────────────────────────────────────────── */
.discover-btn--sm {
    min-height: 2.1rem;
    padding: 0 var(--ifinsta-space-3);
    font-size: var(--ifinsta-text-xs);
}

/* ── Checkbox styling ────────────────────────────────────────────── */
.dc-check {
    width: 15px;
    height: 15px;
    border-radius: 3px;
    accent-color: var(--ifinsta-primary-600);
    cursor: pointer;
}

/* ── Analytics page stats ────────────────────────────────────────── */
.dc-analytics-stat-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--ifinsta-space-4);
    margin-bottom: var(--ifinsta-space-5);
}

@media (max-width: 1024px) {
    .dc-analytics-stat-row {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .dc-analytics-stat-row {
        grid-template-columns: 1fr;
    }
}

.dc-analytics-card {
    background: var(--ifinsta-surface);
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-lg);
    padding: 24px;
    box-shadow: var(--ifinsta-shadow-xs);
    position: relative;
    overflow: hidden;
}

.dc-analytics-card__glow {
    position: absolute;
    top: -20px;
    right: -20px;
    width: 80px;
    height: 80px;
    border-radius: 50%;
    filter: blur(30px);
    opacity: 0.8;
}

.dc-analytics-card__label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--ifinsta-text-muted);
    margin-bottom: 10px;
}

.dc-analytics-card__value {
    font-family: var(--ifinsta-font-mono);
    font-size: 2.25rem;
    font-weight: 800;
    line-height: 1;
    color: var(--ifinsta-text);
}

.dc-analytics-trend {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-top: 10px;
    font-size: 0.75rem;
    font-weight: 700;
}

.dc-analytics-trend--up {
    color: #059669;
}

.dc-analytics-trend--down {
    color: #DC2626;
}

.dc-analytics-secondary-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--ifinsta-space-3);
    margin-bottom: var(--ifinsta-space-5);
}

@media (max-width: 1024px) {
    .dc-analytics-secondary-row {
        grid-template-columns: repeat(2, 1fr);
    }
}

.dc-analytics-secondary-card {
    background: var(--ifinsta-surface);
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-md);
    padding: 14px 18px;
    box-shadow: var(--ifinsta-shadow-xs);
}

.dc-analytics-secondary-card__label {
    font-size: 0.72rem;
    color: var(--ifinsta-text-muted);
    font-weight: 600;
    margin-bottom: 6px;
}

.dc-analytics-secondary-card__value {
    font-family: var(--ifinsta-font-mono);
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--ifinsta-text);
}

/* ── Analytics chart layout ──────────────────────────────────────── */
.dc-analytics-charts {
    display: grid;
    grid-template-columns: 3fr 2fr;
    gap: var(--ifinsta-space-4);
    margin-bottom: var(--ifinsta-space-5);
}

@media (max-width: 1024px) {
    .dc-analytics-charts {
        grid-template-columns: 1fr;
    }
}

.dc-analytics-chart-panel {
    background: var(--ifinsta-surface);
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-lg);
    padding: 24px;
    box-shadow: var(--ifinsta-shadow-xs);
}

.dc-analytics-chart-panel__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    gap: var(--ifinsta-space-3);
}

.dc-analytics-chart-panel__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 800;
}

.dc-analytics-chart-canvas {
    position: relative;
    height: 280px;
}

/* ── Analytics: most wanted product rows ─────────────────────────── */
.dc-top-product-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ifinsta-space-3);
    padding: 12px 0;
    border-bottom: 1px solid var(--ifinsta-border-light);
}

.dc-top-product-row:last-child {
    border-bottom: none;
}

/* ── Analytics: bottom row ───────────────────────────────────────── */
.dc-analytics-bottom {
    display: grid;
    grid-template-columns: 11fr 9fr;
    gap: var(--ifinsta-space-4);
}

@media (max-width: 1024px) {
    .dc-analytics-bottom {
        grid-template-columns: 1fr;
    }
}

/* ── Funnel bars ─────────────────────────────────────────────────── */
.dc-funnel {
    display: grid;
    gap: var(--ifinsta-space-3);
}

.dc-funnel-step {
    display: grid;
    gap: 4px;
}

.dc-funnel-step__label-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.78rem;
}

.dc-funnel-step__label {
    color: var(--ifinsta-text);
    font-weight: 600;
}

.dc-funnel-step__pct {
    font-family: var(--ifinsta-font-mono);
    font-size: 0.75rem;
    color: var(--ifinsta-text-muted);
}

.dc-funnel-step__bar {
    height: 8px;
    background: var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-full);
    overflow: hidden;
}

.dc-funnel-step__fill {
    height: 100%;
    background: var(--ifinsta-primary-600);
    border-radius: var(--ifinsta-radius-full);
}

.dc-funnel-step__dropoff {
    font-size: 0.7rem;
    font-weight: 700;
    color: #D97706;
    margin-top: 2px;
}

/* ── Department performance mini-table ──────────────────────────── */
.dc-dept-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.82rem;
}

.dc-dept-table th {
    padding: 8px 10px;
    text-align: left;
    font-size: 0.69rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--ifinsta-text-muted);
    border-bottom: 1px solid var(--ifinsta-border);
    font-weight: 700;
}

.dc-dept-table td {
    padding: 10px 10px;
    vertical-align: middle;
    border-bottom: 1px solid var(--ifinsta-border-light);
}

.dc-dept-table tbody tr:nth-child(even) td {
    background: var(--ifinsta-bg-secondary);
}

.dc-dept-table tbody tr:last-child td {
    border-bottom: none;
}

/* ── Stories management ──────────────────────────────────────────── */
.dc-stories-table {
    width: 100%;
    border-collapse: collapse;
}

.dc-stories-table th {
    padding: 10px 14px;
    font-size: 0.69rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--ifinsta-text-muted);
    border-bottom: 1px solid var(--ifinsta-border);
    background: var(--ifinsta-bg-secondary);
    font-weight: 700;
    text-align: left;
}

.dc-stories-table td {
    padding: 0 14px;
    height: 52px;
    vertical-align: middle;
    border-bottom: 1px solid var(--ifinsta-border-light);
}

.dc-stories-table tbody tr:last-child td {
    border-bottom: none;
}

.dc-stories-table tbody tr:hover {
    background: rgba(79, 70, 229, 0.02);
}

.dc-stories-table tbody tr:hover .dc-row-btn {
    opacity: 1;
}

.dc-story-type-chip {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: var(--ifinsta-radius-full);
    font-size: 0.7rem;
    font-weight: 700;
    white-space: nowrap;
}

.dc-story-type-chip--general {
    background: #EEF2FF;
    color: #4F46E5;
}

.dc-story-type-chip--product {
    background: #EEF2FF;
    color: #4F46E5;
}

.dc-story-type-chip--promo {
    background: #ECFDF5;
    color: #047857;
}

.dc-story-type-chip--restock {
    background: #FFFBEB;
    color: #D97706;
}

.dc-story-type-chip--event {
    background: #F5F3FF;
    color: #7C3AED;
}

/* ── Review queue cards ──────────────────────────────────────────── */
.dc-review-card {
    background: var(--ifinsta-surface);
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-lg);
    padding: 20px;
    box-shadow: var(--ifinsta-shadow-xs);
    transition: var(--ifinsta-transition-fast);
}

.dc-review-card--approved {
    background: #ECFDF5;
    border-color: #A7F3D0;
}

.dc-review-card__grid {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) minmax(0, 2fr) minmax(140px, 1fr);
    gap: var(--ifinsta-space-5);
    align-items: start;
}

@media (max-width: 1024px) {
    .dc-review-card__grid {
        grid-template-columns: 1fr;
    }
}

.dc-review-card__product-name {
    font-size: 0.9rem;
    font-weight: 700;
    margin-bottom: 4px;
    color: var(--ifinsta-text);
}

.dc-review-card__footer {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid var(--ifinsta-border-light);
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-3);
    font-size: 0.72rem;
    color: var(--ifinsta-text-muted);
    flex-wrap: wrap;
}

.dc-review-source-badge {
    display: inline-flex;
    align-items: center;
    padding: 1px 6px;
    border-radius: var(--ifinsta-radius-full);
    background: var(--ifinsta-bg-secondary);
    color: var(--ifinsta-text-muted);
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.dc-review-ai-notes {
    font-size: 0.8rem;
    color: var(--ifinsta-text-muted);
    margin: 6px 0 0;
    line-height: 1.5;
}

.dc-review-notes-field {
    width: 100%;
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-md);
    padding: 8px 12px;
    font-size: 0.82rem;
    font-family: var(--ifinsta-font-family);
    color: var(--ifinsta-text);
    resize: vertical;
    min-height: 64px;
    transition: var(--ifinsta-input-transition);
}

.dc-review-notes-field:focus {
    outline: none;
    border-color: var(--ifinsta-primary-500);
    box-shadow: var(--ifinsta-input-focus-shadow);
}

.dc-review-actions {
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-2);
}

/* ── Stories: feed grid ──────────────────────────────────────────── */
.dc-stories-feed-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--ifinsta-space-4);
}

@media (max-width: 1024px) {
    .dc-stories-feed-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .dc-stories-feed-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

.dc-story-feed-card {
    border-radius: 24px;
    overflow: hidden;
    position: relative;
    aspect-ratio: 4/5;
    cursor: pointer;
    box-shadow: var(--ifinsta-shadow-xs);
    transition: transform var(--ifinsta-duration-fast) var(--ifinsta-ease-smooth), box-shadow var(--ifinsta-duration-fast);
    text-decoration: none;
    display: block;
    background: #1e293b;
}

.dc-story-feed-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--ifinsta-shadow-md);
}

.dc-story-feed-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.dc-story-feed-card__img-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #1e293b, #334155);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #64748b;
}

.dc-story-feed-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.80) 0%, transparent 60%);
}

.dc-story-feed-card__bottom {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 12px 14px 14px;
}

.dc-story-feed-card__store-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
}

.dc-story-feed-card__store-logo {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 2px solid white;
    object-fit: cover;
    flex-shrink: 0;
}

.dc-story-feed-card__store-logo-fallback {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 2px solid white;
    background: var(--ifinsta-primary-600);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    font-weight: 700;
    flex-shrink: 0;
    text-transform: uppercase;
}

.dc-story-feed-card__store-name {
    color: white;
    font-size: 0.78rem;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dc-story-feed-card__time {
    color: rgba(255, 255, 255, 0.65);
    font-size: 0.68rem;
    margin-left: auto;
    flex-shrink: 0;
}

.dc-story-feed-card__caption {
    color: white;
    font-size: 0.8rem;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom: 6px;
}

.dc-story-feed-card__type-chip {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: var(--ifinsta-radius-full);
    font-size: 0.68rem;
    font-weight: 700;
    color: white;
    background: rgba(79, 70, 229, 0.85);
}

.dc-story-feed-card__play-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity var(--ifinsta-duration-fast);
}

.dc-story-feed-card:hover .dc-story-feed-card__play-overlay {
    opacity: 1;
}

.dc-story-feed-card__play-btn {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.22);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
}

/* Unseen ring */
.dc-story-feed-card--unseen::before {
    content: '';
    position: absolute;
    inset: -3px;
    border-radius: 27px;
    border: 2.5px solid var(--ifinsta-primary-500);
    pointer-events: none;
    z-index: 1;
}

/* Seen ring */
.dc-story-feed-card--seen::before {
    content: '';
    position: absolute;
    inset: -3px;
    border-radius: 27px;
    border: 2px solid #E5E7EB;
    pointer-events: none;
    z-index: 1;
}

/* ── Story viewer ────────────────────────────────────────────────── */
.dc-story-viewer-backdrop {
    min-height: calc(100vh - var(--ifinsta-guest-header-height, 56px));
    background: #0F172A;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: var(--ifinsta-space-5);
    padding: var(--ifinsta-space-6) var(--ifinsta-space-4);
}

.dc-story-viewer-frame {
    position: relative;
    width: min(100%, 380px);
    aspect-ratio: 9/16;
    border-radius: 16px;
    overflow: hidden;
    background: #1e293b;
    flex-shrink: 0;
}

.dc-story-viewer-sidebar {
    width: 280px;
    flex-shrink: 0;
    padding-top: var(--ifinsta-space-2);
}

@media (max-width: 768px) {
    .dc-story-viewer-sidebar {
        display: none;
    }
}

.dc-story-progress-bar {
    position: absolute;
    top: 10px;
    left: 10px;
    right: 10px;
    height: 3px;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 2px;
    overflow: hidden;
    z-index: 2;
}

.dc-story-progress-fill {
    height: 100%;
    background: white;
    border-radius: 2px;
    animation: dc-story-progress 5s linear forwards;
}

@keyframes dc-story-progress {
    from {
        width: 0%;
    }

    to {
        width: 100%;
    }
}

.dc-story-viewer-top {
    position: absolute;
    top: 20px;
    left: 12px;
    right: 12px;
    display: flex;
    align-items: center;
    gap: 8px;
    z-index: 2;
}

.dc-story-viewer-close {
    margin-left: auto;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.15);
    border-radius: 50%;
    color: white;
    text-decoration: none;
    border: none;
    cursor: pointer;
}

.dc-story-viewer-bottom {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 16px;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.7) 0%, transparent 100%);
    z-index: 2;
}

.dc-story-reaction-bar {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--ifinsta-space-5);
    padding: var(--ifinsta-space-4);
    background: rgba(15, 23, 42, 0.6);
}

.dc-story-reaction-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    color: #6B7280;
    font-size: 0.72rem;
    background: none;
    border: none;
    cursor: pointer;
    transition: var(--ifinsta-transition-fast);
    text-decoration: none;
    padding: 0;
}

.dc-story-reaction-btn:hover {
    color: var(--ifinsta-primary-400);
}

/* ── Story create ────────────────────────────────────────────────── */
.dc-story-create-grid {
    display: grid;
    grid-template-columns: 2fr 3fr;
    gap: var(--ifinsta-space-6);
    align-items: start;
}

@media (max-width: 768px) {
    .dc-story-create-grid {
        grid-template-columns: 1fr;
    }
}

.dc-upload-dropzone {
    border: 2px dashed var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-lg);
    padding: var(--ifinsta-space-8) var(--ifinsta-space-4);
    text-align: center;
    cursor: pointer;
    transition: var(--ifinsta-transition-fast);
    background: var(--ifinsta-surface);
}

.dc-upload-dropzone:hover {
    border-color: var(--ifinsta-primary-400);
    background: rgba(79, 70, 229, 0.03);
}

.dc-story-type-chips {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ifinsta-space-2);
}

.dc-story-type-radio {
    position: relative;
}

.dc-story-type-radio input[type="radio"] {
    position: absolute;
    opacity: 0;
}

.dc-story-type-radio label {
    display: inline-flex;
    align-items: center;
    padding: var(--ifinsta-space-1-5) var(--ifinsta-space-3);
    border-radius: var(--ifinsta-radius-full);
    border: 1px solid var(--ifinsta-border);
    background: var(--ifinsta-surface);
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    cursor: pointer;
    transition: var(--ifinsta-transition-fast);
}

.dc-story-type-radio input[type="radio"]:checked+label {
    background: var(--ifinsta-primary-600);
    border-color: var(--ifinsta-primary-600);
    color: white;
}

/* ── Public product detail — bargain price states ────────────────── */
.dc-price-range {
    font-family: var(--ifinsta-font-mono);
    font-size: clamp(1.25rem, 3vw, 1.75rem);
    font-weight: 800;
    color: var(--ifinsta-primary-600);
}

.dc-price-bargain-block {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: var(--ifinsta-space-2);
}

.dc-price-bargain-active {
    font-family: var(--ifinsta-font-mono);
    font-size: clamp(1.25rem, 3vw, 1.75rem);
    font-weight: 800;
    color: var(--ifinsta-primary-600);
}

.dc-price-bargain-old {
    font-family: var(--ifinsta-font-mono);
    font-size: 1rem;
    color: var(--ifinsta-text-muted);
    text-decoration: line-through;
}

.dc-price-bargain-chip {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: var(--ifinsta-radius-full);
    background: #ECFDF5;
    color: #047857;
    font-size: 0.72rem;
    font-weight: 700;
}

/* ── Department tabs on storefront products ──────────────────────── */
.dc-dept-tab-bar {
    display: flex;
    gap: var(--ifinsta-space-2);
    flex-wrap: wrap;
    margin-bottom: var(--ifinsta-space-4);
    /* mobile: horizontal scroll overrides flex-wrap */
}

@media (max-width: 640px) {
    .dc-dept-tab-bar {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        -ms-overflow-style: none;
        padding-bottom: 4px;
        /* bleed to container edges for full-width feel */
        margin-left: -14px;
        margin-right: -14px;
        padding-left: 14px;
        padding-right: 14px;
    }

    .dc-dept-tab-bar::-webkit-scrollbar {
        display: none;
    }

    .dc-dept-tab {
        flex-shrink: 0;
        font-size: var(--ifinsta-text-xs);
        padding: 8px 14px;
        min-height: 36px;
    }
}

.dc-dept-tab {
    display: inline-flex;
    align-items: center;
    padding: var(--ifinsta-space-2) var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-full);
    border: 1px solid var(--ifinsta-border);
    background: var(--ifinsta-surface);
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    text-decoration: none;
    transition: var(--ifinsta-transition-fast);
    white-space: nowrap;
}

.dc-dept-tab:hover {
    border-color: var(--ifinsta-primary-400);
    color: var(--ifinsta-primary-700);
    background: rgba(79, 70, 229, 0.05);
}

.dc-dept-tab--active {
    background: var(--ifinsta-primary-600);
    border-color: var(--ifinsta-primary-600);
    color: white;
}

.dc-dept-tab--active:hover {
    background: var(--ifinsta-primary-700);
    border-color: var(--ifinsta-primary-700);
}

/* ========================================================================== */
/* STORE CANVAS THEMES
   Scoped to [data-store-theme] on the public storefront shell.
   Each theme overrides --discover-primary and sets banner/logo variables.
   ========================================================================== */

/* --- Minimal (default, no overrides needed) --- */
[data-store-theme="minimal"] {
    --store-banner-gradient: linear-gradient(135deg, #eef2ff 0%, #e0e7ff 60%, #c7d2fe 100%);
    --store-logo-bg: linear-gradient(135deg, #6366f1, #818cf8);
    --store-logo-color: #ffffff;
}

/* --- Beauty & Wellness --- */
[data-store-theme="beauty"] {
    --discover-primary: #e11d48;
    --discover-primary-soft: rgba(225, 29, 72, 0.10);
    --store-banner-gradient: linear-gradient(135deg, #fdf2f8 0%, #fce7f3 45%, #fbcfe8 100%);
    --store-logo-bg: linear-gradient(135deg, #e11d48, #f43f5e);
    --store-logo-color: #ffffff;
}

/* --- Fashion & Clothing --- */
[data-store-theme="fashion"] {
    --discover-primary: #18181b;
    --discover-primary-soft: rgba(24, 24, 27, 0.10);
    --store-banner-gradient: linear-gradient(135deg, #27272a 0%, #3f3f46 50%, #52525b 100%);
    --store-logo-bg: linear-gradient(135deg, #18181b, #3f3f46);
    --store-logo-color: #d4af37;
}

[data-store-theme="fashion"] .discover-btn--primary {
    background: #18181b;
    border-color: #18181b;
    color: #d4af37;
}

[data-store-theme="fashion"] .discover-btn--primary:hover {
    background: #27272a;
    border-color: #27272a;
}

[data-store-theme="fashion"] .discover-tab--active {
    border-bottom-color: #d4af37;
    color: #18181b;
}

/* --- Kitchen & Home --- */
[data-store-theme="kitchen"] {
    --discover-primary: #c2410c;
    --discover-primary-soft: rgba(194, 65, 12, 0.10);
    --store-banner-gradient: linear-gradient(135deg, #fff7ed 0%, #fed7aa 50%, #fdba74 100%);
    --store-logo-bg: linear-gradient(135deg, #c2410c, #ea580c);
    --store-logo-color: #ffffff;
}

/* --- Bags & Accessories --- */
[data-store-theme="bags"] {
    --discover-primary: #78350f;
    --discover-primary-soft: rgba(120, 53, 15, 0.10);
    --store-banner-gradient: linear-gradient(135deg, #fef3c7 0%, #d4a96a 50%, #92400e 100%);
    --store-logo-bg: linear-gradient(135deg, #78350f, #b45309);
    --store-logo-color: #fef3c7;
}

/* --- Electronics & Tech --- */
[data-store-theme="electronics"] {
    --discover-primary: #0ea5e9;
    --discover-primary-soft: rgba(14, 165, 233, 0.10);
    --store-banner-gradient: linear-gradient(135deg, #0f172a 0%, #1e3a5f 50%, #0369a1 100%);
    --store-logo-bg: linear-gradient(135deg, #0369a1, #0ea5e9);
    --store-logo-color: #ffffff;
}

/* --- Food & Beverages --- */
[data-store-theme="food"] {
    --discover-primary: #16a34a;
    --discover-primary-soft: rgba(22, 163, 74, 0.10);
    --store-banner-gradient: linear-gradient(135deg, #f0fdf4 0%, #bbf7d0 50%, #4ade80 100%);
    --store-logo-bg: linear-gradient(135deg, #16a34a, #22c55e);
    --store-logo-color: #ffffff;
}

/* --- Jewelry & Luxury --- */
[data-store-theme="jewelry"] {
    --discover-primary: #7c3aed;
    --discover-primary-soft: rgba(124, 58, 237, 0.10);
    --store-banner-gradient: linear-gradient(135deg, #1e1b4b 0%, #4c1d95 50%, #7c3aed 100%);
    --store-logo-bg: linear-gradient(135deg, #4c1d95, #7c3aed);
    --store-logo-color: #ffd700;
}

/* Theme-aware banner fallback and logo */
[data-store-theme] .discover-store-banner__fallback {
    background: var(--store-banner-gradient);
}

[data-store-theme] .discover-store-logo--fallback {
    background: var(--store-logo-bg);
    color: var(--store-logo-color);
}

/* ==========================================================================
   MARKETPLACE BROWSE — Product-first homepage layout
   ========================================================================== */

/* Top bar: search + tabs */
.discover-browse-topbar {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-2) var(--ifinsta-space-3);
    background: #fff;
    border: 1px solid #e8eaed;
    border-radius: 4px;
}

.discover-search--browse {
    flex: 1;
    min-width: 0;
    max-width: none;
    margin: 0;
}

/* Segmented pill control */
.discover-tabs--browse {
    display: flex;
    align-items: center;
    gap: 2px;
    padding: 3px;
    background: var(--ifinsta-bg-secondary);
    border-radius: var(--ifinsta-radius-full);
    border-bottom: none;
    flex-shrink: 0;
}

.discover-tabs--browse .discover-tab {
    padding: var(--ifinsta-space-1) var(--ifinsta-space-3);
    border-radius: var(--ifinsta-radius-full);
    border-bottom: none;
    font-size: var(--ifinsta-text-xs);
    display: inline-flex;
    align-items: center;
}

.discover-tabs--browse .discover-tab--active {
    background: var(--ifinsta-surface);
    color: var(--ifinsta-text);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);
    border-bottom: none;
}

.discover-tabs--browse .discover-tab:hover:not(.discover-tab--active) {
    background: rgba(0, 0, 0, 0.04);
    color: var(--ifinsta-text);
}

.discover-tab__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.3rem;
    height: 1.3rem;
    padding: 0 0.3rem;
    border-radius: var(--ifinsta-radius-full);
    background: rgba(148, 163, 184, 0.15);
    color: var(--ifinsta-text-secondary);
    font-size: 0.6rem;
    font-weight: var(--ifinsta-font-semibold);
    margin-left: 0.25rem;
}

.discover-tab--active .discover-tab__count {
    background: rgba(79, 70, 229, 0.12);
    color: var(--ifinsta-primary-600);
}

/* Two-column browse layout: sidebar left + main right */
.discover-browse-layout {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: var(--ifinsta-space-4);
    align-items: start;
}

@media (max-width: 1024px) {
    .discover-browse-layout {
        grid-template-columns: 200px minmax(0, 1fr);
        gap: var(--ifinsta-space-3);
    }
}

@media (max-width: 768px) {
    .discover-browse-layout {
        grid-template-columns: 1fr;
    }
}

/* Sidebar panel */
.discover-sidebar-panel {
    display: flex;
    flex-direction: column;
    gap: 0;
    position: sticky;
    top: var(--ifinsta-space-4);
    background: #fff;
    border: 1px solid #e8eaed;
    border-radius: 4px;
    padding: 0 var(--ifinsta-space-3);
    overflow: hidden;
}

.discover-sidebar-section {
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--ifinsta-border-light);
    border-radius: 0;
    padding: var(--ifinsta-space-3) 0;
}

.discover-sidebar-title {
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    text-transform: uppercase;
    letter-spacing: var(--ifinsta-letter-spacing-wider);
    color: var(--ifinsta-text-muted);
    margin: 0 0 var(--ifinsta-space-2) 0;
}

.discover-sidebar-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.discover-sidebar-item {
    border-radius: var(--ifinsta-radius-sm);
}

.discover-sidebar-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--ifinsta-space-1-5) var(--ifinsta-space-2);
    border-radius: var(--ifinsta-radius-sm);
    font-size: var(--ifinsta-text-sm);
    color: var(--ifinsta-text-secondary);
    text-decoration: none;
    transition: var(--ifinsta-transition-fast);
    gap: var(--ifinsta-space-2);
}

.discover-sidebar-link:hover {
    background: var(--ifinsta-primary-alpha-08);
    color: var(--ifinsta-primary-700);
}

.discover-sidebar-item--active .discover-sidebar-link {
    background: var(--ifinsta-primary-alpha-08);
    color: var(--ifinsta-primary-700);
    font-weight: var(--ifinsta-font-semibold);
}

.discover-sidebar-count {
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-text-muted);
    margin-left: auto;
    flex-shrink: 0;
}

/* Price filter */
.discover-price-filter {
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-2);
}

.discover-price-filter__row {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: var(--ifinsta-space-1-5);
}

.discover-price-filter__input {
    width: 100%;
    padding: var(--ifinsta-space-1-5) var(--ifinsta-space-2);
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-sm);
    font-size: var(--ifinsta-text-xs);
    font-family: var(--discover-font);
    background: var(--ifinsta-bg);
    color: var(--ifinsta-text);
    min-width: 0;
}

.discover-price-filter__input:focus {
    outline: none;
    border-color: var(--ifinsta-primary-500);
    box-shadow: var(--ifinsta-input-focus-shadow);
}

.discover-price-filter__sep {
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-text-muted);
    text-align: center;
}

.discover-price-filter__submit {
    margin-top: var(--ifinsta-space-2);
    font-size: var(--ifinsta-text-xs);
}

.discover-price-filter__clear {
    display: block;
    text-align: center;
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-text-muted);
    text-decoration: none;
    margin-top: var(--ifinsta-space-1);
}

.discover-price-filter__clear:hover {
    color: var(--ifinsta-primary-600);
}

/* Main panel — overflow visible so popups aren't clipped */
.discover-main-panel {
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-3);
    min-width: 0;
    overflow: visible;
}

/* Browse grid — overflow visible for popup */
.discover-browse-section {
    overflow: visible;
}

.discover-grid--browse {
    overflow: visible;
}

/* Actions bar */
.discover-actions-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ifinsta-space-3);
    flex-wrap: wrap;
    padding: var(--ifinsta-space-1-5) 0;
    background: transparent;
    border: none;
    border-bottom: 1px solid #e8eaed;
    border-radius: 0;
    min-height: 2.5rem;
}

/* Active filter chips */
.discover-active-filters {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    flex-wrap: wrap;
    flex: 1;
    min-width: 0;
}

.discover-active-chip {
    display: inline-flex;
    align-items: center;
    gap: var(--ifinsta-space-1-5);
    padding: var(--ifinsta-space-1) var(--ifinsta-space-2);
    border-radius: var(--ifinsta-radius-full);
    border: 1px solid var(--ifinsta-border);
    background: var(--ifinsta-bg);
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-text);
    white-space: nowrap;
    max-width: 260px;
}

.discover-active-chip__label {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.discover-active-chip__remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--ifinsta-text-muted);
    text-decoration: none;
    border-radius: var(--ifinsta-radius-full);
    padding: 1px;
    transition: var(--ifinsta-transition-fast);
}

.discover-active-chip__remove:hover {
    color: var(--ifinsta-text);
    background: rgba(0, 0, 0, 0.06);
}

.discover-clear-all {
    display: inline-flex;
    align-items: center;
    gap: var(--ifinsta-space-1-5);
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-medium);
    color: var(--ifinsta-text-secondary);
    text-decoration: none;
    padding: var(--ifinsta-space-1) var(--ifinsta-space-2);
    border-radius: var(--ifinsta-radius-sm);
    white-space: nowrap;
    transition: var(--ifinsta-transition-fast);
}

.discover-clear-all:hover {
    color: #dc2626;
    background: rgba(220, 38, 38, 0.06);
}

/* Right side: count + sort select + grid toggle */
.discover-actions-right {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-3);
    flex-shrink: 0;
}

/* Sort select */
.discover-sort-select-wrap {
    display: inline-flex;
    align-items: center;
    gap: var(--ifinsta-space-1-5);
    position: relative;
}

.discover-sort-select-wrap__label {
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-text-secondary);
    white-space: nowrap;
}

.discover-sort-select {
    -webkit-appearance: none;
    appearance: none;
    border: none;
    background: transparent;
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    color: var(--ifinsta-text);
    font-family: var(--discover-font);
    cursor: pointer;
    padding-right: 1.2rem;
    outline: none;
}

.discover-sort-select-wrap__caret {
    position: absolute;
    right: 0;
    pointer-events: none;
    color: var(--ifinsta-text-muted);
}

/* Grid density toggle */
.discover-grid-toggle {
    display: flex;
    align-items: center;
    gap: 2px;
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-sm);
    padding: 2px;
    background: var(--ifinsta-bg);
}

.discover-grid-toggle__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.8rem;
    height: 1.8rem;
    border: none;
    background: transparent;
    border-radius: calc(var(--ifinsta-radius-sm) - 2px);
    cursor: pointer;
    color: var(--ifinsta-text-muted);
    transition: var(--ifinsta-transition-fast);
}

.discover-grid-toggle__btn:hover {
    color: var(--ifinsta-text);
    background: rgba(0, 0, 0, 0.05);
}

.discover-grid-toggle__btn--active {
    background: var(--ifinsta-primary-600);
    color: var(--ifinsta-white);
}

.discover-grid-toggle__btn--active:hover {
    background: var(--ifinsta-primary-700);
    color: var(--ifinsta-white);
}

/* Grid density: compact mode */
.discover-grid--browse[data-grid-density="compact"] {
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: var(--ifinsta-space-2);
}

/* Sort bar (legacy, kept for search.html) */
.discover-sort-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ifinsta-space-3);
    flex-wrap: wrap;
    padding: var(--ifinsta-space-2-5) var(--ifinsta-space-3);
    background: var(--ifinsta-surface);
    border: 1px solid var(--ifinsta-border-light);
    border-radius: var(--ifinsta-radius-md);
}

.discover-results-count {
    font-size: var(--ifinsta-text-sm);
    color: var(--ifinsta-text-secondary);
    font-weight: var(--ifinsta-font-medium);
}

.discover-sort-chips {
    display: flex;
    gap: var(--ifinsta-space-1-5);
    flex-wrap: wrap;
}

.discover-sort-chip {
    padding: var(--ifinsta-space-1) var(--ifinsta-space-3);
    border-radius: var(--ifinsta-radius-full);
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-medium);
    color: var(--ifinsta-text-secondary);
    text-decoration: none;
    border: 1px solid var(--ifinsta-border);
    background: var(--ifinsta-bg);
    transition: var(--ifinsta-transition-fast);
    white-space: nowrap;
}

.discover-sort-chip:hover {
    border-color: var(--ifinsta-primary-400);
    color: var(--ifinsta-primary-600);
}

.discover-sort-chip--active {
    background: var(--ifinsta-primary-600);
    border-color: var(--ifinsta-primary-600);
    color: var(--ifinsta-white);
}

.discover-sort-chip--active:hover {
    background: var(--ifinsta-primary-700);
    border-color: var(--ifinsta-primary-700);
    color: var(--ifinsta-white);
}

/* Browse section (products / stores sub-section) */
.discover-browse-section {
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-2);
}

.discover-browse-section-header {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    padding-bottom: var(--ifinsta-space-1-5);
    border-bottom: 1px solid var(--ifinsta-border-light);
}

.discover-browse-section-label {
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    text-transform: uppercase;
    letter-spacing: var(--ifinsta-letter-spacing-wider);
    color: var(--ifinsta-text-muted);
}

/* Browse grid — Alibaba-style 4-column density */
.discover-grid--browse {
    grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
    gap: var(--ifinsta-space-2);
}

@media (max-width: 640px) {
    .discover-grid--browse {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--ifinsta-space-1-5);
    }
}

/* Pagination */
.discover-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-4) 0;
}

.discover-pagination__page {
    font-size: var(--ifinsta-text-sm);
    color: var(--ifinsta-text-secondary);
}

/* ==========================================================================
   IMAGE CAROUSEL — multi-image product cards
   ========================================================================== */

.discover-card__carousel-wrap {
    position: relative;
    line-height: 0;
}

/* Slides container */
.discover-card__slides {
    position: relative;
    aspect-ratio: 1;
    overflow: hidden;
    border-radius: 0;
    background: var(--ifinsta-bg-secondary);
}

.discover-card__slide {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0;
    transition: opacity 0.22s ease;
}

.discover-card__slide--active {
    opacity: 1;
}

/* Prev / next arrow buttons — hidden until hover */
.discover-card__carousel-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: none;
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.18);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.15s ease, background 0.15s ease;
    color: var(--ifinsta-text);
}

.discover-card__carousel-btn--prev {
    left: 6px;
}

.discover-card__carousel-btn--next {
    right: 6px;
}

.discover-card__carousel-wrap:hover .discover-card__carousel-btn {
    opacity: 1;
}

.discover-card__carousel-btn:hover {
    background: #fff;
}

/* Dot indicators */
.discover-card__carousel-dots {
    position: absolute;
    bottom: 7px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 4px;
    z-index: 10;
}

.discover-card__carousel-dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.55);
    cursor: pointer;
    transition: background 0.15s ease, transform 0.15s ease;
}

.discover-card__carousel-dot--active {
    background: #fff;
    transform: scale(1.25);
}

/* ==========================================================================
   HOVER QUICK-VIEW POPUP
   ========================================================================== */

.discover-card__popup {
    position: absolute;
    top: 0;
    left: calc(100% + 10px);
    width: 400px;
    background: var(--ifinsta-surface);
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-lg);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.10);
    z-index: 9999;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
    transform: translateX(-6px);
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.discover-card__popup--visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(0);
}

/* Transparent bridge that fills the gap between card and popup so the
   mouse can glide across without triggering the hide timer */
.discover-card__popup::before {
    content: '';
    position: absolute;
    top: 0;
    right: 100%;
    width: 18px;
    height: 100%;
}

/* Flip popup to the left when it would overflow the viewport right edge */
.discover-card__popup--left {
    left: auto;
    right: calc(100% + 10px);
}

.discover-card__popup--left::before {
    right: auto;
    left: 100%;
}

.discover-card__popup-image-wrap {
    position: relative;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: var(--ifinsta-bg-secondary);
}

/* ── Popup image carousel ── */
.discover-popup__slides {
    position: relative;
    width: 100%;
    height: 100%;
}

.discover-popup__slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 0.22s ease;
}

.discover-popup__slide--active {
    opacity: 1;
}

.discover-popup__slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.discover-popup__carousel-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 4;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: none;
    background: rgba(255, 255, 255, 0.9);
    color: var(--ifinsta-text);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.18);
    opacity: 0;
    transition: opacity 0.15s ease, background 0.15s ease;
}

.discover-card__popup-image-wrap:hover .discover-popup__carousel-btn {
    opacity: 1;
}

.discover-popup__carousel-btn:hover {
    background: #fff;
}

.discover-popup__carousel-btn--prev {
    left: 8px;
}

.discover-popup__carousel-btn--next {
    right: 8px;
}

.discover-popup__carousel-dots {
    position: absolute;
    bottom: 8px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 5px;
    z-index: 4;
}

.discover-popup__dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.55);
    transition: background 0.15s ease, transform 0.15s ease;
    cursor: pointer;
}

.discover-popup__dot--active {
    background: #fff;
    transform: scale(1.3);
}

.discover-card__popup-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.discover-card__popup-body {
    padding: var(--ifinsta-space-3);
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-1-5);
}

.discover-card__popup-title {
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    color: var(--ifinsta-text);
    margin: 0;
    line-height: var(--ifinsta-leading-snug);
}

.discover-card__popup-price {
    font-size: 1.05rem;
    font-weight: var(--ifinsta-font-bold);
    color: var(--ifinsta-text);
    font-family: var(--ifinsta-font-mono);
    margin: 0;
}

.discover-card__popup-supplier {
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-text-muted);
    margin: 0;
}

.discover-card__popup-actions {
    display: flex;
    gap: var(--ifinsta-space-2);
    margin-top: var(--ifinsta-space-1);
}

.discover-card__popup-btn {
    flex: 1;
    padding: var(--ifinsta-space-2) var(--ifinsta-space-2);
    border-radius: var(--ifinsta-radius-full);
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    font-family: var(--discover-font);
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    border: 1px solid var(--ifinsta-border);
    transition: var(--ifinsta-transition-fast);
    white-space: nowrap;
}

.discover-card__popup-btn--primary {
    background: var(--ifinsta-primary-600);
    border-color: var(--ifinsta-primary-600);
    color: #fff;
}

.discover-card__popup-btn--primary:hover {
    background: var(--ifinsta-primary-700);
    border-color: var(--ifinsta-primary-700);
    color: #fff;
}

.discover-card__popup-btn--secondary {
    background: var(--ifinsta-bg);
    color: var(--ifinsta-text);
}

.discover-card__popup-btn--secondary:hover {
    background: var(--ifinsta-primary-alpha-08);
    border-color: var(--ifinsta-primary-400);
    color: var(--ifinsta-primary-700);
}

/* On narrow viewports, popup appears below instead of to the right */
@media (max-width: 900px) {
    .discover-card__popup {
        left: 0;
        top: calc(100% + 6px);
        width: min(360px, calc(100vw - 16px));
    }
}

/* ── Infinite scroll sentinel ── */
.discover-infinite-sentinel {
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: var(--ifinsta-space-4);
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-sm);
}

.discover-infinite-sentinel--loading::after {
    content: '';
    width: 24px;
    height: 24px;
    border: 2px solid var(--ifinsta-border);
    border-top-color: var(--ifinsta-primary-600);
    border-radius: 50%;
    animation: discover-spin 0.65s linear infinite;
}

@keyframes discover-spin {
    to {
        rotate: 1turn;
    }
}

/* ==========================================================================
   PRODUCT CARD v2 — Alibaba-style: image → title → price → supplier → CTA
   ========================================================================== */

/* Card body (below image) */
.discover-card__body {
    display: flex;
    flex-direction: column;
    padding: var(--ifinsta-space-2) var(--ifinsta-space-2) var(--ifinsta-space-2-5);
    flex: 1;
    gap: var(--ifinsta-space-1);
}

/* Image anchor — wraps the image only, never the body */
.discover-card__anchor--image {
    display: block;
    text-decoration: none;
    overflow: hidden;
    line-height: 0;
    border-radius: 0;
}

.discover-card__anchor--image:hover .discover-card__image {
    transform: scale(1.03);
}

/* Image wrap: no radius — card overflow:hidden handles clipping */
.discover-card__anchor--image .discover-card__image-wrap {
    border-radius: 0;
    overflow: hidden;
}

/* Title link — unstyled */
.discover-card__title-link {
    text-decoration: none;
    color: inherit;
    display: block;
}

.discover-card__title-link:hover .discover-card__title {
    color: var(--ifinsta-primary-600);
}

/* Price block — dominant visual element */
.discover-card__price-block {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: var(--ifinsta-space-1-5);
    margin-top: var(--ifinsta-space-0-5);
}

.discover-card__price-main {
    font-size: 1.05rem;
    font-weight: var(--ifinsta-font-bold);
    color: var(--ifinsta-primary-700);
    font-family: var(--ifinsta-font-mono);
    line-height: 1.2;
}

@media (max-width: 480px) {
    .discover-card__price-main {
        font-size: 1rem;
    }
}

.discover-card__price-old {
    font-size: 0.75rem;
    text-decoration: line-through;
    color: var(--ifinsta-text-muted);
}

/* Verified badge — overlaid on image (top-right) */
.discover-card__badge--verified {
    top: auto;
    bottom: var(--ifinsta-space-2);
    left: var(--ifinsta-space-2);
    background: rgba(22, 163, 74, 0.92);
    color: #fff;
}

/* Supplier section */
.discover-card__supplier {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin-top: auto;
    padding-top: var(--ifinsta-space-1);
}

.discover-card__supplier-name {
    font-size: 0.72rem;
    color: var(--ifinsta-text-muted);
    font-weight: var(--ifinsta-font-medium);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-decoration: none;
}

.discover-card__supplier-meta {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-1);
    flex-wrap: wrap;
}

.discover-card__rating-inline {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 0.7rem;
    color: var(--ifinsta-text-secondary);
    font-weight: var(--ifinsta-font-medium);
}

.discover-card__supplier-sep {
    font-size: 0.65rem;
    color: var(--ifinsta-text-muted);
}

.discover-card__supplier-city {
    font-size: 0.7rem;
    color: var(--ifinsta-text-muted);
    white-space: nowrap;
}

/* CTA button — full-width pill */
.discover-card__cta {
    margin-top: var(--ifinsta-space-2);
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    transition: max-height 0.18s ease, opacity 0.18s ease;
}

.discover-card--product:hover .discover-card__cta {
    max-height: 3rem;
    opacity: 1;
}

.discover-card__cta-btn {
    width: 100%;
    padding: var(--ifinsta-space-1-5) var(--ifinsta-space-3);
    border-radius: 2px;
    border: 1px solid var(--ifinsta-primary-500);
    background: transparent;
    color: var(--ifinsta-primary-600);
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    font-family: var(--discover-font);
    cursor: pointer;
    transition: var(--ifinsta-transition-fast);
    text-align: center;
    white-space: nowrap;
}

.discover-card__cta-btn:hover {
    background: var(--ifinsta-primary-600);
    border-color: var(--ifinsta-primary-600);
    color: var(--ifinsta-white);
}

/* Verified badge (standalone, not on image) */
.discover-verified-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    padding: 0.1rem 0.4rem;
    border-radius: var(--ifinsta-radius-full);
    background: rgba(22, 163, 74, 0.1);
    color: var(--ifinsta-success-700, #15803d);
    font-size: 0.65rem;
    font-weight: var(--ifinsta-font-semibold);
    white-space: nowrap;
    flex-shrink: 0;
}

/* Bargain chip */
.dc-price-bargain-chip {
    font-size: 0.65rem;
    padding: 0.1rem 0.4rem;
    border-radius: var(--ifinsta-radius-full);
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
    font-weight: var(--ifinsta-font-semibold);
}

/* ==========================================================================
   PRODUCT DETAIL PAGE (PDP) — Alibaba-inspired dense marketplace layout
   ========================================================================== */

.discover-pdp-page {
    padding: var(--ifinsta-space-4) 0 var(--ifinsta-space-10);
}

@media (max-width: 900px) {
    .discover-pdp-page {
        padding-top: 0;
    }
}

.discover-pdp-breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-1-5);
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-text-muted);
    margin-bottom: var(--ifinsta-space-4);
    flex-wrap: wrap;
}

.discover-pdp-breadcrumb__link {
    color: var(--ifinsta-text-muted);
    text-decoration: none;
}

.discover-pdp-breadcrumb__link:hover {
    color: var(--ifinsta-primary-600);
    text-decoration: underline;
}

.discover-pdp-breadcrumb__current {
    color: var(--ifinsta-text);
    font-weight: var(--ifinsta-font-medium);
}

.discover-pdp-layout {
    display: grid;
    grid-template-columns: 1.6fr 1fr;
    grid-template-areas:
        "gallery info"
        "details info";
    gap: var(--ifinsta-space-8);
    align-items: start;
    max-width: 1280px;
    margin: 0 auto;
}

.discover-pdp-gallery {
    grid-area: gallery;
    display: grid;
    grid-template-columns: 76px 1fr;
    gap: var(--ifinsta-space-2-5);
    position: sticky;
    top: var(--ifinsta-space-4);
}

/* Main media container with tabs */
.discover-pdp-media-container {
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-3);
}

/* Tab navigation for Photos/Video/Attributes */
.discover-pdp-media-tabs {
    display: flex;
    gap: var(--ifinsta-space-1);
    padding: 4px;
    background: transparent;
    border-radius: 0;
    width: fit-content;
    margin: 0 auto;
}

.discover-pdp-media-tab {
    padding: 8px 16px;
    border-radius: var(--ifinsta-radius-full);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-medium);
    color: var(--ifinsta-neutral-600);
    background: transparent;
    border: none;
    cursor: pointer;
    transition: var(--ifinsta-transition-fast);
}

.discover-pdp-media-tab:hover {
    color: var(--ifinsta-neutral-900);
}

.discover-pdp-media-tab--active {
    background: transparent;
    color: var(--ifinsta-primary-600);
    box-shadow: none;
    border-bottom: 2px solid var(--ifinsta-primary-600);
    border-radius: 0;
}

/* Main media wrapper with actions */
.discover-pdp-main-wrap {
    position: relative;
    aspect-ratio: 1;
    max-height: 520px;
    border-radius: var(--ifinsta-radius-xl);
    overflow: hidden;
    background: var(--ifinsta-bg-secondary);
}

/* Media actions (favorite, zoom) */
.discover-pdp-media-actions {
    position: absolute;
    top: var(--ifinsta-space-3);
    right: var(--ifinsta-space-3);
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-2);
    z-index: 10;
}

.discover-pdp-media-action {
    width: 40px;
    height: 40px;
    border-radius: var(--ifinsta-radius-full);
    background: #fff;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    transition: var(--ifinsta-transition-fast);
    color: var(--ifinsta-neutral-700);
}

.discover-pdp-media-action:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.discover-pdp-media-action--active {
    color: #ef4444;
}

/* Navigation arrows */
.discover-pdp-nav-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    border-radius: var(--ifinsta-radius-full);
    background: #fff;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    transition: var(--ifinsta-transition-fast);
    z-index: 10;
    color: var(--ifinsta-neutral-700);
}

.discover-pdp-nav-btn:hover {
    background: var(--ifinsta-neutral-50);
}

.discover-pdp-nav-btn--prev {
    left: var(--ifinsta-space-3);
}

.discover-pdp-nav-btn--next {
    right: var(--ifinsta-space-3);
}

.discover-pdp-nav-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

/* Thumbnail scroll indicator */
.discover-pdp-thumb-scroll {
    position: absolute;
    bottom: var(--ifinsta-space-2);
    left: 50%;
    transform: translateX(-50%);
    width: 32px;
    height: 32px;
    border-radius: var(--ifinsta-radius-full);
    background: #fff;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    z-index: 10;
    color: var(--ifinsta-neutral-700);
}

/* Video container */
.discover-pdp-video {
    width: 100%;
    height: 100%;
    object-fit: contain;
    background: #000;
}

/* Attributes panel */
.discover-pdp-attributes {
    padding: var(--ifinsta-space-4);
    overflow-y: auto;
    max-height: 100%;
}

/* Lazy loading placeholder */
.discover-pdp-img--loading {
    background: linear-gradient(90deg, var(--ifinsta-neutral-100) 25%, var(--ifinsta-neutral-200) 50%, var(--ifinsta-neutral-100) 75%);
    background-size: 200% 100%;
    animation: discover-pdp-shimmer 1.5s infinite;
}

@keyframes discover-pdp-shimmer {
    0% {
        background-position: 200% 0;
    }

    100% {
        background-position: -200% 0;
    }
}

.discover-pdp-thumbstrip {
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-2);
    max-height: 520px;
    overflow-y: auto;
    scrollbar-width: thin;
    /* Firefox */
}

.discover-pdp-thumbstrip::-webkit-scrollbar {
    width: 4px;
}

.discover-pdp-thumbstrip::-webkit-scrollbar-track {
    background: transparent;
}

.discover-pdp-thumbstrip::-webkit-scrollbar-thumb {
    background: var(--ifinsta-border);
    border-radius: 2px;
}

.discover-pdp-thumb {
    width: 76px;
    height: 76px;
    flex-shrink: 0;
    border-radius: var(--ifinsta-radius-md);
    overflow: hidden;
    border: 2px solid var(--ifinsta-border-light);
    cursor: pointer;
    background: var(--ifinsta-bg-secondary);
    padding: 0;
    transition: border-color 0.15s ease;
}

.discover-pdp-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.discover-pdp-thumb--active,
.discover-pdp-thumb:hover {
    border-color: var(--ifinsta-primary-600);
}

.discover-pdp-main-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.discover-pdp-main-img--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ifinsta-text-muted);
}

.discover-pdp-main-col {
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-4);
    min-width: 0;
}

.discover-pdp-info {
    grid-area: info;
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-3-5);
    background: transparent;
    border: none;
    border-radius: 0;
    padding: 0;
    position: sticky;
    top: var(--ifinsta-space-4);
    max-height: calc(100vh - var(--ifinsta-space-8));
    overflow-y: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.discover-pdp-info::-webkit-scrollbar {
    display: none;
}


.discover-pdp-category-tag {
    display: inline-block;
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    color: var(--ifinsta-primary-700);
    background: var(--ifinsta-primary-alpha-08);
    padding: 2px 10px;
    border-radius: var(--ifinsta-radius-full);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.discover-pdp-name {
    font-size: var(--ifinsta-text-base);
    font-weight: var(--ifinsta-font-semibold);
    color: var(--ifinsta-text);
    line-height: 1.4;
    margin: 0;
}

.discover-pdp-meta-row {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-1-5);
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-text-muted);
    flex-wrap: wrap;
}

.discover-pdp-rating {
    display: flex;
    align-items: center;
    gap: 3px;
    color: var(--ifinsta-text);
    font-weight: var(--ifinsta-font-semibold);
}

.discover-pdp-location {
    display: flex;
    align-items: center;
    gap: 3px;
}

.discover-pdp-meta-sep {
    opacity: 0.4;
}

.discover-pdp-price-band {
    display: flex;
    align-items: baseline;
    gap: var(--ifinsta-space-3);
    flex-wrap: wrap;
    padding: 0;
    background: transparent;
    border-radius: 0;
    border-left: none;
}

.discover-pdp-price {
    font-size: var(--ifinsta-text-lg);
    font-weight: var(--ifinsta-font-semibold);
    font-family: var(--ifinsta-font-mono);
    color: var(--ifinsta-text);
    line-height: 1.2;
}

.discover-pdp-price-old {
    font-size: 1rem;
    color: var(--ifinsta-text-muted);
    text-decoration: line-through;
    font-family: var(--ifinsta-font-mono);
}

.discover-pdp-discount-badge {
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-bold);
    color: #fff;
    background: #ef4444;
    padding: 2px 8px;
    border-radius: var(--ifinsta-radius-full);
    text-transform: uppercase;
}

.discover-pdp-ctas {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 12px;
    padding: 16px 0 0;
    margin-top: 16px;
    border-top: 1px solid var(--ifinsta-neutral-200);
    position: sticky;
    bottom: 0;
    background: #fff;
    z-index: 10;
}

.discover-pdp-ctas-row {
    display: flex;
    flex: 1;
    gap: 12px;
}

.discover-pdp-cta-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--ifinsta-space-2);
    padding: 14px 24px;
    border-radius: var(--ifinsta-radius-full);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    font-family: var(--discover-font);
    text-decoration: none;
    cursor: pointer;
    border: none;
    transition: var(--ifinsta-transition-fast);
    flex: 1;
    min-width: 0;
    white-space: nowrap;
}

.discover-pdp-cta-btn--primary {
    background: var(--discover-primary);
    color: #fff;
}

.discover-pdp-cta-btn--primary:hover {
    background: var(--ifinsta-primary-700);
}

.discover-pdp-cta-btn--whatsapp {
    background: #25D366;
    color: #fff;
}

.discover-pdp-cta-btn--whatsapp:hover {
    background: #1ebe5d;
}

.discover-pdp-cta-btn--secondary {
    background: #fff;
    color: var(--ifinsta-text);
    border: 1.5px solid var(--ifinsta-neutral-300);
}

.discover-pdp-cta-btn--secondary:hover {
    border-color: var(--ifinsta-neutral-400);
    background: var(--ifinsta-neutral-50);
}

.discover-pdp-supplier-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-3) 0;
    border: none;
    border-top: 1px solid var(--ifinsta-border-light);
    border-bottom: 1px solid var(--ifinsta-border-light);
    border-radius: 0;
    background: transparent;
}

.discover-pdp-supplier-identity {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-2-5);
    min-width: 0;
}

.discover-pdp-supplier-logo {
    width: 42px;
    height: 42px;
    border-radius: var(--ifinsta-radius-md);
    object-fit: cover;
    flex-shrink: 0;
    border: 1px solid var(--ifinsta-border-light);
}

.discover-pdp-supplier-logo--fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    font-weight: var(--ifinsta-font-bold);
    color: var(--ifinsta-primary-700);
    background: var(--ifinsta-primary-alpha-08);
    border: 1px solid var(--ifinsta-primary-200);
}

.discover-pdp-supplier-copy {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.discover-pdp-supplier-name {
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    color: var(--ifinsta-text);
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.discover-pdp-supplier-name:hover {
    color: var(--ifinsta-primary-600);
}

.discover-pdp-supplier-badges {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-1-5);
    flex-wrap: wrap;
}

.discover-pdp-verified-badge {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 0.7rem;
    font-weight: var(--ifinsta-font-semibold);
    color: #059669;
    background: rgba(5, 150, 105, 0.1);
    padding: 1px 7px;
    border-radius: var(--ifinsta-radius-full);
}

.discover-pdp-supplier-city {
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-text-muted);
}

.discover-pdp-supplier-browse {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
    color: var(--ifinsta-primary-600);
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 0;
}

.discover-pdp-supplier-browse:hover {
    text-decoration: underline;
}

.discover-pdp-trust-row {
    display: flex;
    gap: var(--ifinsta-space-4);
    padding: var(--ifinsta-space-2-5) 0;
    border-top: 1px solid var(--ifinsta-border-light);
    flex-wrap: wrap;
}

.discover-pdp-trust-item {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-1-5);
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-text-muted);
}

.discover-pdp-details-section {
    grid-area: details;
    border: none;
    border-top: 1px solid var(--ifinsta-border-light);
    border-radius: 0;
    overflow: hidden;
}

.discover-pdp-details-heading {
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    color: var(--ifinsta-text);
    margin: 0;
    padding: var(--ifinsta-space-3) 0;
    border-bottom: 1px solid var(--ifinsta-border-light);
    background: transparent;
}

.discover-pdp-details-body {
    padding: var(--ifinsta-space-5);
    font-size: var(--ifinsta-text-sm);
    color: var(--ifinsta-text-secondary);
    line-height: var(--ifinsta-leading-relaxed);
}

.discover-pdp-related {
    margin-top: var(--ifinsta-space-8);
}

.discover-pdp-related-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--ifinsta-space-4);
}

.discover-pdp-related-title {
    font-size: var(--ifinsta-text-lg);
    font-weight: var(--ifinsta-font-bold);
    color: var(--ifinsta-text);
    margin: 0;
}

.discover-pdp-related-all {
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    color: var(--ifinsta-primary-600);
    text-decoration: none;
}

.discover-pdp-related-all:hover {
    text-decoration: underline;
}

.discover-pdp-related-grid {
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
}

/* ── Wholesale badge & MOQ note ─────────────────────────────────────────── */
.discover-pdp-wholesale-row {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    flex-wrap: wrap;
    margin-top: var(--ifinsta-space-3);
}

.discover-pdp-wholesale-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    background: #fff3e0;
    color: #b45309;
    border: 1px solid #f59e0b;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .02em;
}

.discover-pdp-moq-note {
    font-size: 12px;
    color: var(--ifinsta-neutral-500);
}

/* ── ctas-row: legacy — no longer used (buttons are direct flex children of ctas) ── */

/* ── Quantity-tiered pricing ─────────────────────────────────────────────── */
.discover-pdp-price-tiers {
    display: flex;
    gap: 0;
    border: none;
    background: var(--ifinsta-neutral-50);
    border-radius: var(--ifinsta-radius-md);
    overflow: hidden;
    margin-top: var(--ifinsta-space-3);
    margin-bottom: var(--ifinsta-space-2);
}

.discover-pdp-price-tier {
    flex: 1;
    padding: var(--ifinsta-space-3) var(--ifinsta-space-3);
    border-right: 1px solid var(--ifinsta-neutral-200);
    min-width: 0;
}

.discover-pdp-price-tier:last-child {
    border-right: none;
}

.discover-pdp-price-tier__label {
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-neutral-500);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 4px;
}

.discover-pdp-price-tier__price {
    font-size: 15px;
    font-weight: 700;
    color: var(--ifinsta-neutral-900);
}

/* ── Shared panel (Variations / Shipping / any bordered section) ─────────── */
.discover-pdp-panel {
    border: none;
    border-top: 1px solid var(--ifinsta-border-light);
    border-radius: 0;
    background: transparent;
    padding: 14px 0;
    margin-top: 12px;
}

.discover-pdp-panel__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.discover-pdp-panel__title {
    font-size: 14px;
    font-weight: 700;
    color: var(--ifinsta-neutral-900);
}

.discover-pdp-panel__action {
    font-size: 13px;
    font-weight: 500;
    color: var(--ifinsta-primary, #2563eb);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.discover-pdp-panel__hint {
    font-size: 13px;
    color: var(--ifinsta-neutral-500);
    margin: 0;
    line-height: 1.5;
}

/* ── Variations swatches ─────────────────────────────────────────────────── */
.discover-pdp-variation {
    margin-bottom: 10px;
}

.discover-pdp-variation__label {
    font-size: 13px;
    font-weight: 600;
    color: var(--ifinsta-neutral-700);
    margin-bottom: 6px;
}

.discover-pdp-variation__swatches {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.discover-pdp-variant-swatch {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 48px;
    padding: 4px 10px;
    border: 1.5px solid var(--ifinsta-neutral-300);
    border-radius: 4px;
    font-size: 12px;
    color: var(--ifinsta-neutral-800);
    background: #fff;
    cursor: default;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100px;
}

/* ── Ship-to row ─────────────────────────────────────────────────────────── */
.discover-pdp-ship-to {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
}

.discover-pdp-ship-to__label {
    font-size: 13px;
    font-weight: 500;
    color: var(--ifinsta-neutral-600);
    white-space: nowrap;
}

.discover-pdp-ship-to__input {
    flex: 1;
    min-width: 0;
    height: 32px;
    padding: 0 10px;
    font-size: 13px;
    color: var(--ifinsta-neutral-900);
    background: #fff;
    border: 1px solid var(--ifinsta-neutral-300);
    border-radius: 4px;
    outline: none;
    transition: border-color .15s;
}

.discover-pdp-ship-to__input:focus {
    border-color: var(--ifinsta-primary, #2563eb);
}

/* ── Shipping box ────────────────────────────────────────────────────────── */
.discover-pdp-shipping__box {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    background: transparent;
    border: none;
    border-radius: 0;
    padding: 10px 0;
    color: var(--ifinsta-neutral-700);
}

.discover-pdp-shipping__box svg {
    flex-shrink: 0;
    margin-top: 2px;
    color: var(--ifinsta-neutral-500);
}

.discover-pdp-shipping__box-copy {
    flex: 1;
    min-width: 0;
}

.discover-pdp-shipping__box-title {
    font-size: 13px;
    font-weight: 600;
    margin: 0 0 2px;
}

.discover-pdp-shipping__box-note {
    font-size: 12px;
    color: var(--ifinsta-neutral-500);
    margin: 0;
}

.discover-pdp-shipping__change {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    flex-shrink: 0;
    font-size: 12px;
    font-weight: 500;
    color: var(--ifinsta-primary, #2563eb);
    white-space: nowrap;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.discover-pdp-shipping__disclaimer {
    font-size: 11px;
    color: var(--ifinsta-neutral-400);
    margin: 8px 0 0;
    line-height: 1.4;
}

/* ── Tabbed details section ──────────────────────────────────────────────── */
.discover-pdp-tabs {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--ifinsta-neutral-200);
    margin-bottom: 0;
}

.discover-pdp-tab {
    padding: var(--ifinsta-space-3) var(--ifinsta-space-5);
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    font-size: var(--ifinsta-text-sm);
    font-weight: 500;
    color: var(--ifinsta-neutral-500);
    cursor: pointer;
    transition: color .15s, border-color .15s;
    white-space: nowrap;
}

.discover-pdp-tab:hover {
    color: var(--ifinsta-neutral-900);
}

.discover-pdp-tab--active {
    color: var(--ifinsta-primary, #2563eb);
    border-bottom-color: var(--ifinsta-primary, #2563eb);
    font-weight: 600;
}

.discover-pdp-tab-panel {
    padding: var(--ifinsta-space-5);
}

.discover-pdp-tab-panel--hidden {
    display: none;
}

/* ── Key attributes 4-column grid (2 label/value pairs per row) ─────────── */
.discover-pdp-attr-grid {
    display: grid;
    grid-template-columns: max-content 1fr max-content 1fr;
    gap: 0;
    border-top: 1px solid var(--ifinsta-neutral-200);
    border-left: 1px solid var(--ifinsta-neutral-200);
    font-size: var(--ifinsta-text-sm);
}

.discover-pdp-attr-label,
.discover-pdp-attr-value {
    padding: var(--ifinsta-space-2) var(--ifinsta-space-4);
    border-right: 1px solid var(--ifinsta-neutral-200);
    border-bottom: 1px solid var(--ifinsta-neutral-200);
}

.discover-pdp-attr-label {
    background: var(--ifinsta-neutral-50, #f9fafb);
    color: var(--ifinsta-neutral-600);
    font-weight: 500;
    white-space: nowrap;
}

.discover-pdp-attr-value {
    color: var(--ifinsta-neutral-900);
    word-break: break-word;
}

/* Odd number of attributes: last label spans 1, last value spans 3 */
.discover-pdp-attr-label:last-of-type:nth-child(4n-1) {
    grid-column: span 1;
}

.discover-pdp-attr-value:last-child:nth-child(4n) {
    grid-column: span 3;
}

@media (max-width: 900px) {
    .discover-pdp-layout {
        grid-template-columns: 1fr;
        grid-template-areas:
            "gallery"
            "info"
            "details";
        gap: var(--ifinsta-space-5);
    }

    .discover-pdp-gallery {
        position: static;
        grid-template-columns: 60px 1fr;
    }

    .discover-pdp-thumbstrip {
        max-height: 360px;
    }

    .discover-pdp-thumb {
        width: 60px;
        height: 60px;
    }

    .discover-pdp-attr-grid {
        grid-template-columns: max-content 1fr;
    }

    .discover-pdp-ctas {
        padding: 10px 0;
        gap: 6px;
    }
}

@media (max-width: 480px) {
    .discover-pdp-gallery {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto;
    }

    .discover-pdp-thumbstrip {
        flex-direction: row;
        max-height: none;
        overflow-x: auto;
        overflow-y: hidden;
        order: 2;
    }

    .discover-pdp-media-container {
        order: 1;
    }

    .discover-pdp-thumb {
        width: 64px;
        height: 64px;
    }

    .discover-pdp-price-tiers {
        flex-wrap: wrap;
    }

    .discover-pdp-price-tier {
        flex: 0 0 calc(50% - 1px);
    }
}

/* ==========================================================================
   DISCOVER HOME PAGE ADDITIONAL FILTER STYLES
   ========================================================================== */

.discover-rating-stars {
    color: #f59e0b;
    font-size: 0.85rem;
    letter-spacing: -1px;
}

.discover-sidebar-link svg {
    flex-shrink: 0;
}

/* Active filter chips for new filters */
.discover-active-chip--verified {
    background: rgba(22, 163, 74, 0.1);
    border-color: rgba(22, 163, 74, 0.3);
    color: #166534;
}

.discover-active-chip--discount {
    background: rgba(239, 68, 68, 0.1);
    border-color: rgba(239, 68, 68, 0.3);
    color: #dc2626;
}

.discover-active-chip--rating {
    background: rgba(245, 158, 11, 0.1);
    border-color: rgba(245, 158, 11, 0.3);
    color: #d97706;
}

.discover-active-chip--stock {
    background: rgba(37, 99, 235, 0.1);
    border-color: rgba(37, 99, 235, 0.3);
    color: #2563eb;
}

/* (sidebar inline-grid removed — drawer handled in ≤900px block below) */

@media (max-width: 640px) {
    .discover-browse-topbar {
        flex-direction: column;
        align-items: stretch;
        gap: var(--ifinsta-space-2);
        padding: var(--ifinsta-space-3);
    }

    .discover-tabs--browse {
        justify-content: center;
    }

    .discover-actions-bar {
        flex-direction: column;
        align-items: stretch;
        gap: var(--ifinsta-space-3);
    }

    .discover-active-filters {
        order: 2;
    }

    .discover-actions-right {
        order: 1;
        justify-content: space-between;
        width: 100%;
    }

    .discover-grid-toggle {
        display: none;
    }
}

/* ==========================================================================
   STOREFRONT SIDEBAR — EcoPack Kenya Design
   ========================================================================== */

.storefront-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-3);
}

.storefront-sidebar__card {
    background: var(--ifinsta-surface);
    border: 1px solid var(--ifinsta-border-light);
    border-radius: var(--ifinsta-radius-xl);
    padding: var(--ifinsta-space-4);
    box-shadow: var(--ifinsta-shadow-xs);
}

.storefront-sidebar__card--highlight {
    background: linear-gradient(135deg, rgba(79, 70, 229, 0.04), rgba(255, 255, 255, 0.98));
    border-color: rgba(79, 70, 229, 0.15);
}

.storefront-sidebar__title {
    font-size: var(--ifinsta-text-lg);
    font-weight: var(--ifinsta-font-bold);
    color: var(--ifinsta-text);
    margin: 0 0 var(--ifinsta-space-3) 0;
}

.storefront-sidebar__text {
    font-size: var(--ifinsta-text-sm);
    color: var(--ifinsta-text-secondary);
    line-height: 1.6;
    margin: 0 0 var(--ifinsta-space-4) 0;
}

.storefront-sidebar__actions {
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-2);
}

.storefront-sidebar__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--ifinsta-space-2);
    padding: var(--ifinsta-space-3) var(--ifinsta-space-4);
    border-radius: var(--ifinsta-radius-full);
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    text-decoration: none;
    cursor: pointer;
    transition: var(--ifinsta-transition-fast);
    border: none;
}

.storefront-sidebar__btn--secondary {
    background: var(--ifinsta-bg-secondary);
    color: var(--ifinsta-primary-600);
}

.storefront-sidebar__btn--secondary:hover {
    background: var(--ifinsta-primary-alpha-08);
}

.storefront-sidebar__btn--whatsapp {
    background: #25D366;
    color: white;
}

.storefront-sidebar__btn--whatsapp:hover {
    background: #1ebe5d;
}

.storefront-sidebar__share {
    margin-top: var(--ifinsta-space-4);
    padding-top: var(--ifinsta-space-4);
    border-top: 1px solid var(--ifinsta-border-light);
}

.storefront-sidebar__share-title {
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-bold);
    color: var(--ifinsta-text-muted);
    letter-spacing: 0.1em;
    margin: 0 0 var(--ifinsta-space-3) 0;
}

.storefront-sidebar__share-actions {
    display: flex;
    gap: var(--ifinsta-space-2);
}

.storefront-sidebar__share-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: var(--ifinsta-radius-full);
    border: 1px solid var(--ifinsta-border);
    background: var(--ifinsta-surface);
    color: var(--ifinsta-text-muted);
    cursor: pointer;
    transition: var(--ifinsta-transition-fast);
    text-decoration: none;
}

.storefront-sidebar__share-btn:hover {
    background: var(--ifinsta-primary-alpha-08);
    color: var(--ifinsta-primary-600);
    border-color: var(--ifinsta-primary-400);
}

.storefront-sidebar__delivery-header {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    margin-bottom: var(--ifinsta-space-3);
}

.storefront-sidebar__delivery-header svg {
    color: var(--ifinsta-primary-600);
}

.storefront-sidebar__delivery-title {
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-bold);
    color: var(--ifinsta-text);
    margin: 0;
}

.storefront-sidebar__delivery-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--ifinsta-space-2);
}

.storefront-sidebar__delivery-item {
    display: flex;
    align-items: flex-start;
    gap: var(--ifinsta-space-2);
    font-size: var(--ifinsta-text-sm);
    color: var(--ifinsta-text-secondary);
}

.storefront-sidebar__delivery-item svg {
    flex-shrink: 0;
    margin-top: 3px;
}

/* ==========================================================================
   PRODUCT CARD RESPONSIVE IMPROVEMENTS
   ========================================================================== */

@media (max-width: 640px) {
    .discover-grid--compact {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--ifinsta-space-2);
    }

    .discover-card__body {
        padding: var(--ifinsta-space-1-5) var(--ifinsta-space-2);
    }

    .discover-card__title {
        font-size: 0.75rem;
        line-height: 1.3;
        -webkit-line-clamp: 2;
    }

    .discover-card__price-main {
        font-size: 0.85rem;
    }

    .discover-card__price-old {
        font-size: 0.65rem;
    }

    .discover-card__supplier {
        margin-top: var(--ifinsta-space-1);
        padding-top: var(--ifinsta-space-1);
    }

    .discover-card__supplier-name {
        font-size: 0.65rem;
    }

    .discover-card__supplier-meta {
        font-size: 0.6rem;
        gap: 2px;
    }

    .discover-card__rating-inline {
        font-size: 0.6rem;
        gap: 2px;
    }

    .discover-card__rating-inline svg {
        width: 9px;
        height: 9px;
    }

    .discover-card__supplier-city {
        font-size: 0.6rem;
    }

    .discover-card__cta {
        margin-top: var(--ifinsta-space-1-5);
    }

    .discover-card__cta-btn {
        padding: var(--ifinsta-space-1-5) var(--ifinsta-space-2);
        font-size: 0.65rem;
        min-height: 28px;
    }

    .discover-card__badge {
        top: var(--ifinsta-space-1);
        left: var(--ifinsta-space-1);
        padding: 2px 6px;
        font-size: 0.6rem;
    }

    .discover-card__carousel-btn {
        width: 22px;
        height: 22px;
    }

    .discover-card__carousel-btn svg {
        width: 10px;
        height: 10px;
    }

    .storefront-sidebar {
        order: 2;
        margin-top: var(--ifinsta-space-4);
        margin-bottom: 0;
    }

    .discover-layout-sidebar--public {
        display: flex;
        flex-direction: column;
    }

    /* Products stack always renders first on mobile */
    .discover-layout-sidebar--public>.discover-page-stack {
        order: 1;
    }

    .storefront-sidebar__card {
        padding: var(--ifinsta-space-3);
    }

    .storefront-sidebar__title {
        font-size: var(--ifinsta-text-base);
    }
}

/* ==========================================================================
   PDP GALLERY IMPROVEMENTS
   ========================================================================== */

.discover-pdp-media-display {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--ifinsta-bg-secondary) 0%, #ffffff 100%);
    overflow: hidden;
}

.discover-pdp-main-img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    transition: transform 0.3s ease;
}

.discover-pdp-main-img--placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--ifinsta-text-muted);
    gap: var(--ifinsta-space-3);
}

.discover-pdp-main-img--placeholder svg {
    opacity: 0.5;
}

.discover-pdp-main-img--placeholder span {
    font-size: var(--ifinsta-text-sm);
    color: var(--ifinsta-text-muted);
}

.discover-pdp-thumb__video {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
}

.discover-pdp-thumb--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--ifinsta-bg-secondary);
    color: var(--ifinsta-text-muted);
    cursor: default;
}

/* Gallery responsive improvements */
@media (max-width: 900px) {
    .discover-pdp-gallery {
        grid-template-columns: 60px 1fr;
        gap: var(--ifinsta-space-2);
    }

    .discover-pdp-thumb {
        width: 56px;
        height: 56px;
    }

    .discover-pdp-main-wrap {
        max-height: 400px;
    }

    .discover-pdp-media-actions {
        top: var(--ifinsta-space-2);
        right: var(--ifinsta-space-2);
        gap: var(--ifinsta-space-1);
    }

    .discover-pdp-media-action {
        width: 36px;
        height: 36px;
    }

    .discover-pdp-nav-btn {
        width: 36px;
        height: 36px;
    }

    .discover-pdp-nav-btn--prev {
        left: var(--ifinsta-space-2);
    }

    .discover-pdp-nav-btn--next {
        right: var(--ifinsta-space-2);
    }
}

@media (max-width: 640px) {
    .discover-pdp-gallery {
        grid-template-columns: 1fr;
        position: relative;
    }

    .discover-pdp-thumbstrip {
        flex-direction: row;
        order: 2;
        max-height: none;
        overflow-x: auto;
        overflow-y: hidden;
        gap: var(--ifinsta-space-1);
        padding: var(--ifinsta-space-2) 0;
        scrollbar-width: none;
        -ms-overflow-style: none;
    }

    .discover-pdp-thumbstrip::-webkit-scrollbar {
        display: none;
    }

    .discover-pdp-thumb {
        width: 64px;
        height: 64px;
        flex-shrink: 0;
    }

    .discover-pdp-main-wrap {
        aspect-ratio: 1;
        max-height: 350px;
        order: 1;
    }

    .discover-pdp-media-tabs {
        order: 3;
        margin-top: var(--ifinsta-space-2);
    }

    .discover-pdp-media-container {
        order: 1;
    }
}

/* ==========================================================================
   HERO SECTION — Modern two-column hero layout
   ========================================================================== */

.discover-hero {
    background: linear-gradient(135deg, #fafbfc 0%, #f0f4f8 100%);
    padding: 64px 0 48px;
    margin-bottom: 32px;
    position: relative;
    overflow: hidden;
}

.discover-hero__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: center;
}

.discover-hero__content {
    max-width: 600px;
}

.discover-hero__title {
    font-size: clamp(2.25rem, 5vw, 3.5rem);
    font-weight: 800;
    line-height: 1.15;
    color: #1a1a2e;
    margin: 0 0 20px;
    letter-spacing: -0.02em;
}

.discover-hero__title-accent {
    display: block;
    color: var(--ifinsta-primary, #4f46e5);
}

.discover-hero__subtitle {
    font-size: 1.0625rem;
    line-height: 1.7;
    color: #4a5568;
    margin: 0 0 32px;
    max-width: 520px;
}

/* Hero Search Bar */
.discover-hero-search {
    margin-bottom: 20px;
}

.discover-hero-search__wrapper {
    display: flex;
    align-items: stretch;
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #e2e8f0;
    transition: border-color 0.2s ease;
}

.discover-hero-search__wrapper:focus-within {
    border-color: var(--ifinsta-primary, #4f46e5);
}

.discover-hero-search__category {
    position: relative;
    border-right: 1px solid #e2e8f0;
    display: flex;
    align-items: center;
    padding: 0 16px;
    background: #f8fafc;
    min-width: 140px;
}

.discover-hero-search__select {
    appearance: none;
    background: transparent;
    border: none;
    font-size: 0.9375rem;
    font-weight: 500;
    color: #1a1a2e;
    cursor: pointer;
    padding: 16px 24px 16px 8px;
    width: 100%;
    outline: none;
}

.discover-hero-search__select-icon {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: #64748b;
    pointer-events: none;
}

.discover-hero-search__input-wrap {
    flex: 1;
    display: flex;
    align-items: center;
    position: relative;
}

.discover-hero-search__input-icon {
    position: absolute;
    left: 16px;
    width: 20px;
    height: 20px;
    color: #94a3b8;
    pointer-events: none;
}

.discover-hero-search__input {
    flex: 1;
    border: none;
    background: transparent;
    padding: 16px 16px 16px 48px;
    font-size: 1rem;
    color: #1a1a2e;
    outline: none;
    min-width: 0;
}

.discover-hero-search__input::placeholder {
    color: #94a3b8;
}

.discover-hero-search__btn {
    background: var(--ifinsta-primary, #4f46e5);
    color: #fff;
    border: none;
    padding: 16px 28px;
    font-size: 0.9375rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    cursor: pointer;
    transition: background 0.2s ease, transform 0.1s ease;
    white-space: nowrap;
}

.discover-hero-search__btn:hover {
    background: var(--ifinsta-primary-hover, #4338ca);
}

.discover-hero-search__btn:active {
    transform: translateY(1px);
}

/* Category Quick Links */
.discover-hero__categories {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.discover-hero__category-chip {
    display: inline-flex;
    align-items: center;
    padding: 8px 16px;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    font-size: 0.875rem;
    font-weight: 500;
    color: #475569;
    text-decoration: none;
    transition: all 0.2s ease;
}

.discover-hero__category-chip:hover {
    background: var(--ifinsta-primary-light, #eef2ff);
    border-color: var(--ifinsta-primary, #4f46e5);
    color: var(--ifinsta-primary, #4f46e5);
    transform: translateY(-1px);
}

/* Hero Visual (Right Column) */
.discover-hero__visual {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}

.discover-hero__image-wrap {
    position: relative;
    width: 100%;
    max-width: 520px;
}

.discover-hero__image {
    width: 100%;
    height: auto;
    border-radius: 16px;
    object-fit: cover;
    aspect-ratio: 4/3;
}

/* Stats Card Overlay */
.discover-hero__stats-card {
    position: absolute;
    bottom: -20px;
    left: -20px;
    background: #fff;
    padding: 20px 24px;
    border-radius: 12px;
    border: 1px solid rgba(0, 0, 0, 0.07);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.07);
    min-width: 200px;
    animation: discover-float 3s ease-in-out infinite;
}

@keyframes discover-float {

    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-6px);
    }
}

.discover-hero__stats-stars {
    display: flex;
    gap: 2px;
    margin-bottom: 8px;
}

.discover-hero__stats-star {
    color: #fbbf24;
    font-size: 1rem;
    line-height: 1;
}

.discover-hero__stats-value {
    font-size: 1.125rem;
    font-weight: 700;
    color: #1a1a2e;
    margin-bottom: 6px;
}

.discover-hero__stats-quote {
    font-size: 0.8125rem;
    color: #64748b;
    font-style: italic;
    line-height: 1.5;
}

/* Hero Responsive */
@media (max-width: 1024px) {
    .discover-hero__inner {
        grid-template-columns: 1fr;
        gap: 40px;
        text-align: center;
    }

    .discover-hero__content {
        max-width: 100%;
    }

    .discover-hero__subtitle {
        margin-left: auto;
        margin-right: auto;
    }

    .discover-hero__visual {
        order: -1;
    }

    .discover-hero__image-wrap {
        max-width: 480px;
    }

    .discover-hero__stats-card {
        left: auto;
        right: -10px;
        bottom: -10px;
    }
}

@media (max-width: 640px) {
    .discover-hero {
        padding: 40px 0 32px;
    }

    .discover-hero__title {
        font-size: 2rem;
    }

    .discover-hero-search__wrapper {
        flex-direction: column;
        border-radius: 12px;
    }

    .discover-hero-search__category {
        border-right: none;
        border-bottom: 1px solid #e2e8f0;
        padding: 0 12px;
    }

    .discover-hero-search__select {
        padding: 14px 24px 14px 8px;
    }

    .discover-hero-search__input {
        padding: 14px 14px 14px 44px;
    }

    .discover-hero-search__btn {
        padding: 14px 24px;
        width: 100%;
    }

    .discover-hero__stats-card {
        position: relative;
        bottom: auto;
        left: auto;
        right: auto;
        margin-top: 16px;
        animation: none;
        text-align: center;
    }

    .discover-hero__stats-stars {
        justify-content: center;
    }
}

/* ══════════════════════════════════════════════════════════════════
   MOBILE RESPONSIVENESS — ruthless small-screen optimisations
   Breakpoints:
     ≤ 900px  fix PDP two-column → single column stack
     ≤ 768px  filter sidebar → bottom-sheet drawer
     ≤ 640px  borderless / edge-to-edge surfaces
   ══════════════════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────────────────
   Desktop-only defaults for elements that flip on mobile
   ───────────────────────────────────────────────────────────────── */
.discover-mobile-filter-btn {
    display: none;
}

.discover-pdp-mobile-cta-bar {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 200;
    padding: 10px 16px calc(env(safe-area-inset-bottom, 0px) + 10px);
    background: var(--ifinsta-bg);
    border-top: 1px solid var(--ifinsta-border-light);
    gap: 10px;
    align-items: center;
}

.discover-pdp-mobile-cta-bar .discover-pdp-cta-btn {
    flex: 1;
}

.discover-drawer-handle {
    display: none;
}

.discover-drawer-header {
    display: none;
}

.discover-sidebar-panel__inner {
    display: contents;
}

.discover-sidebar-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 399;
    background: rgba(0, 0, 0, 0.4);
}

/* ─────────────────────────────────────────────────────────────────
   ≤ 900px: PDP — single-column stack (critical layout bug fix)
   ───────────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
    .discover-pdp-layout {
        grid-template-columns: 1fr;
        grid-template-areas:
            "gallery"
            "info"
            "details";
        gap: 0;
    }
}

/* ─────────────────────────────────────────────────────────────────
   ≤ 900px: filter sidebar becomes a bottom-sheet drawer
   ───────────────────────────────────────────────────────────────── */
@media (max-width: 900px) {

    /* Make the browse layout a single column — sidebar is now fixed */
    .discover-browse-layout {
        display: block;
    }

    /* Filter button: show on mobile */
    .discover-mobile-filter-btn {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        padding: 6px 13px;
        font-size: 0.8125rem;
        font-weight: 500;
        border: 1px solid var(--ifinsta-border);
        border-radius: 6px;
        background: var(--ifinsta-bg);
        color: var(--ifinsta-text);
        cursor: pointer;
        white-space: nowrap;
        flex-shrink: 0;
    }

    /* Sidebar transforms into a bottom-sheet drawer */
    .discover-sidebar-panel {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        z-index: 400;
        background: var(--ifinsta-bg);
        border-top: 1px solid var(--ifinsta-border);
        border-radius: 16px 16px 0 0;
        max-height: 85dvh;
        overflow-y: auto;
        overscroll-behavior: contain;
        transform: translateY(calc(100% + env(safe-area-inset-bottom, 0px) + 24px));
        transition: transform 0.32s cubic-bezier(0.32, 0.72, 0, 1);
        padding: 0 0 calc(env(safe-area-inset-bottom, 0px) + 20px);
        -webkit-overflow-scrolling: touch;
        visibility: hidden;
        pointer-events: none;
        /* reset tablet grid — drawer must stack vertically */
        display: flex;
        flex-direction: column;
        width: auto;
        min-width: 0;
    }

    .discover-sidebar-panel--open {
        transform: translateY(0);
        visibility: visible;
        pointer-events: auto;
    }

    /* Drawer handle pill */
    .discover-drawer-handle {
        display: flex;
        justify-content: center;
        padding: 12px 0 6px;
        flex-shrink: 0;
        cursor: grab;
    }

    .discover-drawer-handle::after {
        content: "";
        display: block;
        width: 36px;
        height: 4px;
        border-radius: 2px;
        background: var(--ifinsta-border);
    }

    /* Drawer header: title + close button */
    .discover-drawer-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 4px 20px 12px;
        border-bottom: 1px solid var(--ifinsta-border-light);
        flex-shrink: 0;
    }

    .discover-drawer-header__title {
        font-size: 0.9375rem;
        font-weight: 600;
        color: var(--ifinsta-text);
        margin: 0;
    }

    .discover-drawer-close {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 30px;
        height: 30px;
        border-radius: 50%;
        background: var(--ifinsta-border-light);
        border: none;
        cursor: pointer;
        color: var(--ifinsta-text-muted);
        padding: 0;
    }

    /* Inner wrapper so the content scrolls inside the drawer */
    .discover-sidebar-panel__inner {
        display: block;
    }

    /* Backdrop */
    .discover-sidebar-backdrop--visible {
        display: block;
    }

    /* Actions bar tweaks */
    .discover-actions-bar {
        flex-wrap: nowrap;
        gap: 6px;
    }

    .discover-results-count {
        display: none;
    }

    .discover-actions-right {
        gap: 6px;
        flex-shrink: 0;
    }
}

/* ─────────────────────────────────────────────────────────────────
   ≤ 640px: borderless / edge-to-edge surfaces
   ───────────────────────────────────────────────────────────────── */
@media (max-width: 640px) {

    /* Container flushes to screen edges */
    .discover-container--public {
        padding-left: 0;
        padding-right: 0;
    }

    /* ── Browse topbar: sticky borderless strip ── */
    .discover-browse-topbar {
        position: sticky;
        top: 0;
        z-index: 100;
        border: none;
        border-bottom: 1px solid var(--ifinsta-border-light);
        border-radius: 0;
        box-shadow: none;
        background: var(--ifinsta-bg);
        padding: 10px 14px;
        gap: 8px;
        margin: 0;
    }

    /* ── Actions bar: borderless divider ── */
    .discover-actions-bar {
        border: none;
        border-bottom: 1px solid var(--ifinsta-border-light);
        border-radius: 0;
        box-shadow: none;
        padding: 8px 14px;
        margin-bottom: 0;
    }

    /* Active filters: horizontal scroll so they never wrap */
    .discover-active-filters {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 2px;
        scrollbar-width: none;
        min-width: 0;
    }

    .discover-active-filters::-webkit-scrollbar {
        display: none;
    }

    /* ── Discover market sections: hairline separators only ── */
    .discover-section {
        border: none;
        border-radius: 0;
        box-shadow: none;
        border-bottom: 1px solid var(--ifinsta-border-light);
        margin-bottom: 0;
    }

    /* ── Market hero / header ── */
    .discover-market-header,
    .discover-market-hero {
        border: none;
        border-radius: 0;
        box-shadow: none;
        border-bottom: 1px solid var(--ifinsta-border-light);
        margin-bottom: 0;
    }

    /* ── Store header: full-bleed, borderless ── */
    .discover-store-header--public {
        border: none;
        border-radius: 0;
        box-shadow: none;
        margin: 0;
        border-bottom: 1px solid var(--ifinsta-border-light);
    }

    .discover-store-banner {
        border-radius: 0;
    }

    /* ── Store profile row: tighten ── */
    .discover-store-profile {
        padding: 12px 14px 0;
    }

    /* ── Storefront sidebar/about cards: transparent/minimal ── */
    .storefront-sidebar__card,
    .storefront-sidebar__section {
        border: none;
        border-radius: 0;
        box-shadow: none;
        background: transparent;
        border-bottom: 1px solid var(--ifinsta-border-light);
    }

    /* ── Browse sidebar sections inside drawer ── */
    .discover-sidebar-section {
        border-bottom: 1px solid var(--ifinsta-border-light);
        border-radius: 0;
        box-shadow: none;
    }

    /* ── PDP: edge-to-edge, borderless panels ── */
    .discover-pdp-main-wrap {
        border: none;
        border-radius: 0;
        box-shadow: none;
    }

    .discover-pdp-gallery {
        border: none;
        border-radius: 0;
        box-shadow: none;
        margin: 0;
    }

    .discover-pdp-info {
        border: none;
        border-radius: 0;
        box-shadow: none;
        padding: 16px 14px;
        border-top: 1px solid var(--ifinsta-border-light);
        border-bottom: 1px solid var(--ifinsta-border-light);
    }

    .discover-pdp-details-section {
        border: none;
        border-radius: 0;
        box-shadow: none;
        margin: 0;
    }

    .discover-pdp-supplier-card {
        border-radius: 0;
        box-shadow: none;
    }

    /* ── PDP: hide in-flow CTAs, show sticky bar instead ── */
    .discover-pdp-ctas {
        display: none;
    }

    .discover-pdp-mobile-cta-bar {
        display: flex;
    }

    /* Spacer so sticky bar doesn't overlap content */
    .discover-pdp-info {
        padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 80px);
    }

    /* ── Browse grid: proper edge padding ── */
    .discover-browse-section {
        padding: 0;
    }

    .discover-grid--browse {
        padding: 10px 10px 0;
        gap: 8px;
    }

    /* ── Store nav tabs: horizontal scroll ── */
    .discover-tabs--storefront {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        flex-wrap: nowrap;
    }

    .discover-tabs--storefront::-webkit-scrollbar {
        display: none;
    }

    /* ── Market browse tabs: horizontal scroll ── */
    .discover-tabs--browse {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        flex-wrap: nowrap;
    }

    .discover-tabs--browse::-webkit-scrollbar {
        display: none;
    }
}

/* ==========================================================================
   CATALOG EDIT MODAL
   ========================================================================== */

/* ── Edit row button (pencil) ──────────────────────────────────────── */
.dc-row-edit-btn:hover {
    background: #EEF2FF;
    color: #4338CA;
    border-color: #C7D2FE;
}

/* ── Backdrop ──────────────────────────────────────────────────────── */
.dc-edit-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    z-index: 1040;
}

/* ── Modal container ───────────────────────────────────────────────── */
.dc-edit-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1050;
    width: min(560px, calc(100vw - 32px));
    max-height: calc(100vh - 48px);
    background: var(--ifinsta-bg);
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-lg);
    box-shadow: var(--ifinsta-shadow-lg);
    display: flex;
    flex-direction: column;
}

/* ── Header ────────────────────────────────────────────────────────── */
.dc-edit-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--ifinsta-border-light);
    flex-shrink: 0;
}

.dc-edit-modal__title {
    font-size: var(--ifinsta-text-base);
    font-weight: 600;
    color: var(--ifinsta-text);
    margin: 0;
}

.dc-edit-modal__close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: var(--ifinsta-radius-full);
    border: 1px solid transparent;
    background: transparent;
    color: var(--ifinsta-text-muted);
    cursor: pointer;
    font-size: 1rem;
    line-height: 1;
    transition: var(--ifinsta-transition-fast);
}

.dc-edit-modal__close:hover {
    background: var(--ifinsta-bg-secondary);
    color: var(--ifinsta-text);
}

/* ── Body ──────────────────────────────────────────────────────────── */
.dc-edit-modal__body {
    padding: 20px;
    overflow-y: auto;
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.dc-edit-form {
    overflow-y: auto;
}

/* ── Footer ────────────────────────────────────────────────────────── */
.dc-edit-modal__footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    padding: 14px 20px;
    border-top: 1px solid var(--ifinsta-border-light);
    flex-shrink: 0;
}

/* ── Form fields ───────────────────────────────────────────────────── */
.dc-edit-field {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.dc-edit-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.dc-edit-label {
    font-size: var(--ifinsta-text-sm);
    font-weight: 500;
    color: var(--ifinsta-text);
    display: flex;
    align-items: center;
    gap: 6px;
}

.dc-edit-label input[type="checkbox"] {
    accent-color: var(--ifinsta-primary-600);
    width: 15px;
    height: 15px;
    cursor: pointer;
}

.dc-edit-hint {
    font-weight: 400;
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-xs);
}

.dc-edit-input,
.dc-edit-select,
.dc-edit-textarea {
    width: 100%;
    padding: 7px 10px;
    font-size: var(--ifinsta-text-sm);
    font-family: var(--ifinsta-font-family);
    color: var(--ifinsta-text);
    background: var(--ifinsta-bg);
    border: 1px solid var(--ifinsta-border);
    border-radius: var(--ifinsta-radius-md);
    transition: border-color var(--ifinsta-transition-fast);
    box-sizing: border-box;
}

.dc-edit-input:focus,
.dc-edit-select:focus,
.dc-edit-textarea:focus {
    outline: none;
    border-color: var(--ifinsta-primary-600);
    box-shadow: 0 0 0 3px var(--ifinsta-primary-alpha-08);
}

.dc-edit-textarea {
    resize: vertical;
    min-height: 72px;
}

.dc-edit-product-name {
    font-size: var(--ifinsta-text-sm);
    font-weight: 600;
    color: var(--ifinsta-text);
    padding: 6px 10px;
    background: var(--ifinsta-bg-secondary);
    border-radius: var(--ifinsta-radius-md);
    border: 1px solid var(--ifinsta-border-light);
}

.dc-edit-divider {
    border: none;
    border-top: 1px solid var(--ifinsta-border-light);
    margin: 2px 0;
}

.dc-edit-section-label {
    font-size: var(--ifinsta-text-xs);
    font-weight: 600;
    color: var(--ifinsta-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.dc-edit-error {
    font-size: var(--ifinsta-text-xs);
    color: #BE123C;
    padding: 6px 10px;
    background: #FFF1F2;
    border-radius: var(--ifinsta-radius-md);
    border: 1px solid #FECDD3;
    display: none;
}

.dc-edit-error--visible {
    display: block;
}

/* ==========================================================================
   MOBILE-FIRST OPTIMIZATIONS — v2.2
   Covers: PDP header · touch cards · gallery · store profile · browse page
   ========================================================================== */

/* ── PDP Header Block ──────────────────────────────────────────────────────
   The title / meta / supplier chip block above the gallery had no CSS.
   ─────────────────────────────────────────────────────────────────────── */
.discover-pdp-header {
    margin-bottom: var(--ifinsta-space-4);
}

.discover-pdp-name--header {
    font-size: clamp(var(--ifinsta-text-xl), 2.5vw, 2rem);
    font-weight: var(--ifinsta-font-bold);
    line-height: 1.25;
    letter-spacing: -0.01em;
    margin: 0 0 var(--ifinsta-space-2) 0;
    color: var(--ifinsta-text);
}

.discover-pdp-meta-header {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    font-size: var(--ifinsta-text-sm);
    color: var(--ifinsta-text-muted);
    flex-wrap: wrap;
    margin-bottom: var(--ifinsta-space-2);
}

.discover-pdp-reviews-link {
    color: var(--ifinsta-primary-600);
    text-decoration: underline;
    text-underline-offset: 2px;
    font-size: var(--ifinsta-text-sm);
}

.discover-pdp-reviews-link:hover {
    color: var(--ifinsta-primary-700);
}

.discover-pdp-sold {
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-sm);
}

.discover-pdp-supplier-header {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    font-size: var(--ifinsta-text-sm);
    flex-wrap: wrap;
    padding: var(--ifinsta-space-2) 0;
    border-top: 1px solid var(--ifinsta-border-light);
    margin-top: var(--ifinsta-space-1);
}

.discover-pdp-supplier-header__logo {
    width: 22px;
    height: 22px;
    border-radius: var(--ifinsta-radius-sm);
    object-fit: cover;
    flex-shrink: 0;
}

.discover-pdp-supplier-header__name {
    font-weight: var(--ifinsta-font-semibold);
    color: var(--ifinsta-primary-600);
    text-decoration: none;
}

.discover-pdp-supplier-header__name:hover {
    color: var(--ifinsta-primary-700);
    text-decoration: underline;
}

.discover-pdp-supplier-header__meta,
.discover-pdp-supplier-header__flag {
    color: var(--ifinsta-text-muted);
}

@media (max-width: 640px) {
    .discover-pdp-header {
        padding: var(--ifinsta-space-3) 14px var(--ifinsta-space-2);
        background: var(--ifinsta-surface);
        border-bottom: 1px solid var(--ifinsta-border-light);
        margin-bottom: 0;
    }

    .discover-pdp-name--header {
        font-size: var(--ifinsta-text-lg);
    }

    .discover-pdp-meta-header,
    .discover-pdp-supplier-header {
        font-size: var(--ifinsta-text-xs);
        gap: var(--ifinsta-space-1-5);
    }
}

/* ── PDP: breadcrumb mobile padding ───────────────────────────────────── */
@media (max-width: 640px) {
    .discover-pdp-page {
        padding: 0 0 var(--ifinsta-space-10);
    }

    .discover-pdp-breadcrumb {
        padding: 10px 14px 0;
        font-size: 0.7rem;
        gap: 4px;
        margin-bottom: var(--ifinsta-space-2);
    }

    /* Truncate middle breadcrumb items so they don't wrap to two lines */
    .discover-pdp-breadcrumb__link:not(:first-child):not(:last-child) {
        max-width: 90px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        display: inline-block;
        vertical-align: middle;
    }
}

/* ── PDP: gallery + info mobile sizing ────────────────────────────────── */
@media (max-width: 640px) {

    /* Square main image, max 80vw so it never overshoots the screen */
    .discover-pdp-main-wrap {
        aspect-ratio: 1 / 1;
        max-height: min(80vw, 420px);
        border-radius: 0;
        box-shadow: none;
    }

    /* Thumbnail strip: hide scrollbar, smaller thumbs */
    .discover-pdp-thumbstrip {
        gap: 6px;
    }

    .discover-pdp-thumb {
        width: 60px;
        height: 60px;
    }

    /* Nav arrows: smaller on mobile */
    .discover-pdp-nav-btn {
        width: 36px;
        height: 36px;
    }

    /* Action buttons (favorite/zoom) */
    .discover-pdp-media-action {
        width: 34px;
        height: 34px;
    }

    /* Info panel padding with safe space at bottom for sticky CTA */
    .discover-pdp-info {
        padding-top: 14px;
        padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 80px);
    }

    /* Details section: full-bleed on mobile */
    .discover-pdp-details-section {
        border-left: none;
        border-right: none;
        border-radius: 0;
        margin-top: 0;
    }

    .discover-pdp-tab-panel {
        padding: var(--ifinsta-space-4) 14px;
    }

    /* Attributes: 2-col on mobile (label + value) */
    .discover-pdp-attr-grid {
        grid-template-columns: max-content 1fr;
    }

    /* Variation/shipping panels: edge-to-edge */
    .discover-pdp-panel {
        border-left: none;
        border-right: none;
        border-radius: 0;
        margin-top: 0;
        margin-left: 0;
        margin-right: 0;
    }

    /* Price band: compact on mobile */
    .discover-pdp-price-band {
        padding: var(--ifinsta-space-2) var(--ifinsta-space-3);
    }

    /* Related grid: 2 columns on narrow mobile */
    .discover-pdp-related-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
    }

    .discover-pdp-related {
        margin-top: var(--ifinsta-space-5);
    }
}

@media (max-width: 375px) {
    .discover-pdp-thumb {
        width: 52px;
        height: 52px;
    }
}

/* ── PDP: price tiers — 2-up on very small screens ────────────────────── */
@media (max-width: 400px) {
    .discover-pdp-price-tiers {
        flex-wrap: wrap;
    }

    .discover-pdp-price-tier {
        flex: 0 0 calc(50% - 1px);
    }
}

/* ── Product card touch improvements ──────────────────────────────────────
   On hover-free (touch) devices: always show carousel arrows and hide the
   desktop hover-popup that can't be triggered by touch.
   ─────────────────────────────────────────────────────────────────────── */
@media (hover: none) and (pointer: coarse) {

    /* Always show carousel arrows — not just on hover */
    .discover-card__carousel-btn {
        opacity: 0.88;
        width: 30px;
        height: 30px;
        background: rgba(255, 255, 255, 0.95);
    }

    /* Bigger carousel dots — easier to see */
    .discover-card__carousel-dot {
        width: 6px;
        height: 6px;
    }

    /* Hide hover-triggered popup — not reachable on touch */
    .discover-card__popup {
        display: none !important;
    }

    /* Hover scale effect on card is distracting on touch */
    .discover-card:hover {
        transform: none;
    }
}

/* Touch-friendly "Add to cart" button on mobile */
@media (max-width: 640px) {
    .discover-card__cta-btn {
        min-height: 40px;
        font-size: 0.68rem;
        padding: var(--ifinsta-space-2) var(--ifinsta-space-2-5);
        border-radius: var(--ifinsta-radius-full);
    }

    /* Keep image perfectly square with rounded top corners */
    .discover-card__slides {
        border-radius: var(--ifinsta-radius-md) var(--ifinsta-radius-md) 0 0;
    }
}

/* ── Store profile: fix min-width overflow at tablet ──────────────────── */
@media (max-width: 900px) {
    .discover-store-info {
        min-width: 0;
        /* was 200px — prevents overflow at 768px–900px */
    }
}

/* ── Store profile refinements at ≤640px ─────────────────────────────── */
@media (max-width: 640px) {

    /* Store name: trim to 1 line */
    .discover-store-name {
        font-size: var(--ifinsta-text-base);
        line-height: 1.3;
    }

    /* Tagline: clamp to 2 lines */
    .discover-store-tagline {
        font-size: var(--ifinsta-text-xs);
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
        margin-top: 2px;
    }

    /* Meta row: horizontal scroll instead of wrapping */
    .discover-store-meta {
        gap: var(--ifinsta-space-2);
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: 2px;
        margin-top: var(--ifinsta-space-1-5);
    }

    .discover-store-meta::-webkit-scrollbar {
        display: none;
    }

    .discover-store-meta__chip,
    .discover-store-meta__item {
        flex-shrink: 0;
    }

    /* Storefront sidebar cards: consistent with edge-to-edge style */
    .storefront-sidebar__card {
        border-left: none;
        border-right: none;
        border-radius: 0;
        box-shadow: none;
    }
}

/* ── Storefront products page: edge-to-edge on mobile ─────────────────── */
@media (max-width: 640px) {
    .discover-products-panel {
        padding: 0;
        border: none;
        border-radius: 0;
        box-shadow: none;
    }

    .discover-products-panel .discover-section-header {
        padding: var(--ifinsta-space-3) 14px;
        border-bottom: 1px solid var(--ifinsta-border-light);
        margin-bottom: 0;
    }

    .discover-grid--products {
        padding: 8px 8px 0;
    }
}

/* ── Browse page: tighter mobile topbar ──────────────────────────────── */
@media (max-width: 480px) {
    .discover-browse-topbar {
        padding: 8px 12px;
        gap: 6px;
    }

    /* Tab count badge: keep visible but compact */
    .discover-tab__count {
        min-width: 1.1rem;
        font-size: 0.55rem;
    }

    /* Mobile filter button: more prominent */
    .discover-mobile-filter-btn {
        padding: 7px 14px;
        font-size: 0.8125rem;
        font-weight: 600;
        border-radius: var(--ifinsta-radius-full);
        background: var(--ifinsta-primary-alpha-08);
        border-color: var(--ifinsta-primary-400);
        color: var(--ifinsta-primary-700);
    }
}

/* ── Infinite scroll loading indicator ───────────────────────────────── */
.discover-infinite-sentinel {
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--ifinsta-space-2) 0;
}

.discover-infinite-sentinel--loading::after {
    content: "";
    width: 20px;
    height: 20px;
    border: 2px solid var(--ifinsta-border);
    border-top-color: var(--ifinsta-primary-600);
    border-radius: 50%;
    animation: discover-sentinel-spin 0.7s linear infinite;
    display: block;
}

@keyframes discover-sentinel-spin {
    to {
        transform: rotate(360deg);
    }
}

/* ── Browse page: extra small screen (320px phones) ─────────────────── */
@media (max-width: 360px) {

    .discover-grid--browse,
    .discover-grid--products,
    .discover-grid--compact {
        grid-template-columns: repeat(2, 1fr);
        gap: 6px;
        padding: 6px 6px 0;
    }

    .discover-container--public {
        padding: 0;
    }
}

/* ── Store masthead banner: taller on small screens ─────────────────── */
@media (max-width: 480px) {
    .discover-store-banner {
        height: clamp(80px, 22vw, 140px);
    }
}

/* ── Storefront about sidebar: horizontal chips row on mobile ─────────
   Instead of a full card above the products, show a compact action row.
   ─────────────────────────────────────────────────────────────────── */
@media (max-width: 640px) {

    /* Make sidebar action buttons horizontal on mobile */
    .storefront-sidebar__actions {
        flex-direction: row;
        flex-wrap: wrap;
    }

    .storefront-sidebar__btn {
        flex: 1;
        min-width: 0;
        font-size: var(--ifinsta-text-xs);
        padding: var(--ifinsta-space-2) var(--ifinsta-space-3);
    }

    /* Share buttons row: bigger touch targets */
    .storefront-sidebar__share-btn {
        width: 44px;
        height: 44px;
    }
}

/* ── Store breadcrumb / back link on mobile ──────────────────────────── */
@media (max-width: 640px) {
    .discover-brand-context__back {
        padding: 0 14px;
    }
}

/* ── Checkout page: stacked on mobile ────────────────────────────────── */
@media (max-width: 640px) {
    .discover-checkout-layout {
        grid-template-columns: 1fr;
    }

    .discover-checkout-panel--summary {
        position: static;
    }

    .discover-checkout-panel {
        padding: var(--ifinsta-space-4);
    }
}

/* ── PDP: sticky info panel — only sticky on wide screens ────────────── */
@media (max-width: 900px) {
    .discover-pdp-info {
        position: static;
    }

    .discover-pdp-gallery {
        position: static;
    }
}

/* ==========================================================================
   v3 — PREMIUM SHOPPING REVAMP
   Product card polish · Floating Cart FAB · Layout refinements
   ========================================================================== */

/* ── Product card: portrait image (3:4) ────────────────────────────────── */
.discover-card--product .discover-card__anchor--image {
    border-radius: var(--ifinsta-radius-md) var(--ifinsta-radius-md) 0 0;
}

.discover-card--product .discover-card__slides {
    aspect-ratio: 3 / 4;
    border-radius: 0;
}

/* ── Card body: tighter padding + gap ──────────────────────────────────── */
.discover-card--product .discover-card__body {
    padding: 10px 10px 12px;
    gap: 4px;
}

/* ── Title: sharper letter-spacing ─────────────────────────────────────── */
.discover-card--product .discover-card__title {
    font-size: 0.8125rem;
    letter-spacing: -0.01em;
    margin-bottom: 0;
}

/* ── Price: clean 1rem bold ─────────────────────────────────────────────── */
.discover-card--product .discover-card__price-main {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.2;
}

.discover-card--product .discover-card__price-old {
    font-size: 0.68rem;
}

/* ── Sale badge: red pill ────────────────────────────────────────────────── */
.discover-card--product .discover-card__badge:not(.discover-card__badge--verified) {
    background: #ef4444;
    color: #fff;
    font-size: 0.6rem;
    font-weight: 700;
    padding: 2px 7px;
    border-radius: var(--ifinsta-radius-full);
    letter-spacing: 0.02em;
    box-shadow: none;
}

/* ── Supplier: compact ─────────────────────────────────────────────────── */
.discover-card--product .discover-card__supplier {
    padding-top: var(--ifinsta-space-1);
    gap: 2px;
}

.discover-card--product .discover-card__supplier-meta {
    flex-wrap: nowrap;
    overflow: hidden;
}

.discover-card--product .discover-card__supplier-name {
    font-size: 0.72rem;
}

.discover-card--product .discover-card__rating-inline,
.discover-card--product .discover-card__supplier-city {
    font-size: 0.68rem;
}

/* ── CTA button: tighter + primary fill on mobile ───────────────────────── */
.discover-card--product .discover-card__cta {
    margin-top: var(--ifinsta-space-1-5);
}

.discover-card--product .discover-card__cta-btn {
    min-height: 34px;
    padding: 6px var(--ifinsta-space-3);
    font-size: 0.78rem;
    font-weight: var(--ifinsta-font-semibold);
}

@media (max-width: 900px) {
    .discover-card--product .discover-card__cta-btn {
        background: var(--ifinsta-primary-600);
        border-color: var(--ifinsta-primary-600);
        color: #fff;
    }

    .discover-card--product .discover-card__cta-btn:hover {
        background: var(--ifinsta-primary-700);
        border-color: var(--ifinsta-primary-700);
    }
}

/* ── Carousel dots: 4px pill style ─────────────────────────────────────── */
.discover-card__carousel-dot {
    width: 4px;
    height: 4px;
}

.discover-card__carousel-dot--active {
    width: 12px;
    height: 4px;
    border-radius: 2px;
    transform: none;
}

.discover-card__carousel-dots {
    gap: 5px;
}

/* ── Arrow buttons: always visible on touch ─────────────────────────────── */
@media (hover: none) and (pointer: coarse) {
    .discover-card__carousel-btn {
        opacity: 0.88;
    }

    .discover-card__popup {
        display: none !important;
    }
}

/* ── Grid: tighter gap on mobile ─────────────────────────────────────────── */
@media (max-width: 640px) {

    .discover-grid,
    .discover-grid--browse,
    .discover-grid--products,
    .discover-grid--compact {
        gap: 8px;
    }
}

/* ── Floating Cart FAB ──────────────────────────────────────────────────── */
.discover-cart-fab {
    position: fixed;
    bottom: 24px;
    right: 20px;
    z-index: 350;
}

.discover-cart-fab__btn {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: var(--ifinsta-radius-full);
    background: var(--ifinsta-primary-600);
    color: #fff;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.18);
    text-decoration: none;
    transition: transform 150ms cubic-bezier(0.34, 1.56, 0.64, 1),
        box-shadow 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

.discover-cart-fab__btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.22);
}

.discover-cart-fab__btn:active {
    transform: translateY(0) scale(0.96);
}

.discover-cart-fab__count {
    position: absolute;
    top: -4px;
    right: -4px;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    background: #ef4444;
    color: #fff;
    border-radius: var(--ifinsta-radius-full);
    border: 2px solid var(--ifinsta-bg, #f8fafc);
    font-size: 0.625rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

/* Browse variant: pill with store name */
.discover-cart-fab--browse .discover-cart-fab__btn {
    width: auto;
    height: 48px;
    padding: 0 16px 0 14px;
    gap: 8px;
    font-size: 0.8rem;
    font-weight: 600;
    white-space: nowrap;
}

.discover-cart-fab--browse .discover-cart-fab__count {
    position: static;
    min-width: 20px;
    height: 20px;
    border: none;
    font-size: 0.7rem;
    order: -1;
}

.discover-cart-fab__store-name {
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    text-transform: capitalize;
    font-size: 0.75rem;
    opacity: 0.88;
}

@media (max-width: 900px) {
    .discover-cart-fab {
        bottom: calc(env(safe-area-inset-bottom, 0px) + 72px);
        right: 16px;
    }

    .discover-cart-fab__btn {
        width: 52px;
        height: 52px;
    }

    .discover-cart-fab--browse .discover-cart-fab__btn {
        width: auto;
        height: 46px;
        padding: 0 14px 0 12px;
        font-size: 0.75rem;
    }

    .discover-cart-fab__store-name {
        max-width: 80px;
    }
}

/* ── Browse: search bar height ───────────────────────────────────────────── */
.discover-search__input {
    min-height: 44px;
}

@media (max-width: 640px) {
    .discover-search__input:focus {
        box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
        outline: none;
    }
}

/* ── Browse: active filter chips as pills ────────────────────────────────── */
.discover-active-chip {
    border-radius: var(--ifinsta-radius-full);
}

/* ── Storefront: banner cinema proportions ───────────────────────────────── */
.discover-store-banner {
    aspect-ratio: 3 / 1;
    height: auto;
    min-height: 80px;
    max-height: 160px;
}

@media (max-width: 480px) {
    .discover-store-banner {
        max-height: 120px;
    }
}

/* ── Storefront: logo ring ───────────────────────────────────────────────── */
.discover-store-logo {
    box-shadow: 0 0 0 2px #fff, 0 0 0 3.5px var(--ifinsta-border);
}

/* ── Storefront tabs: pill active state ──────────────────────────────────── */
.discover-tabs--storefront .discover-tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: var(--discover-store-control-height, 2.5rem);
    padding: 0 var(--discover-store-control-padding-x, 0.875rem);
    line-height: 1;
    transition: background var(--ifinsta-transition-fast),
        color var(--ifinsta-transition-fast);
}

.discover-tabs--storefront .discover-tab--active {
    background: rgba(37, 99, 235, 0.08);
    color: var(--ifinsta-primary-600);
}

.discover-tabs--storefront .discover-tab:not(.discover-tab--active):hover {
    background: rgba(0, 0, 0, 0.04);
}

/* Remove underline indicator (replaced by pill) */
.discover-tabs--storefront .discover-tab--active::after {
    display: none;
}

/* ── PDP: price block ─────────────────────────────────────────────────────── */
.discover-pdp-price {
    font-size: 1.4rem;
    font-weight: 700;
}

.discover-pdp-price-old {
    font-size: 0.9rem;
}

/* ── PDP: CTA buttons ─────────────────────────────────────────────────────── */
.discover-pdp-cta-btn {
    min-height: 48px;
}

@media (max-width: 900px) {
    .discover-pdp-cta-btn {
        min-height: 44px;
        padding: 11px 20px;
    }
}

/* ==========================================================================
   MOBILE RESPONSIVENESS v3.2 — Marketplace UX Refinements
   Targets: PDP gallery tabs · store profile · contact page · price tiers ·
            browse tabs · mobile CTA bar
   ========================================================================== */

/* ── 1. PDP media tabs → Alibaba-style horizontal scroll strip ────────────
   Desktop: centred pill group. Mobile: full-width underline tab strip        */
@media (max-width: 640px) {
    .discover-pdp-media-tabs {
        width: 100%;
        max-width: 100%;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        /* reset pill container styles */
        background: transparent;
        border-radius: 0;
        padding: 0;
        gap: 0;
        justify-content: flex-start;
        border-bottom: 1px solid var(--ifinsta-border-light);
        margin: 0 0 0;
    }

    .discover-pdp-media-tabs::-webkit-scrollbar {
        display: none;
    }

    .discover-pdp-media-tab {
        flex-shrink: 0;
        border-radius: 0;
        background: transparent !important;
        box-shadow: none !important;
        padding: 10px 18px;
        font-size: 0.8125rem;
        font-weight: 500;
        color: var(--ifinsta-text-muted);
        border-bottom: 2px solid transparent;
        white-space: nowrap;
        transition: color 0.15s ease, border-color 0.15s ease;
    }

    .discover-pdp-media-tab--active {
        color: var(--ifinsta-primary-600);
        border-bottom-color: var(--ifinsta-primary-600);
        font-weight: 600;
    }

    .discover-pdp-media-tab:hover:not(.discover-pdp-media-tab--active) {
        color: var(--ifinsta-text);
    }
}

/* ── 2. Store profile: nav tabs → own row at ≤480px ──────────────────────
   On very small screens the logo + info + actions + tabs can get cramped.
   Force the tab strip to its own full-width row below the logo/actions.     */
@media (max-width: 480px) {
    .discover-tabs--storefront {
        /* Take a full-width row inside the wrapping flex container */
        flex-basis: 100%;
        width: 100%;
        order: 10;
        /* always after logo, info, actions */
        border-top: 1px solid var(--ifinsta-border-light);
        padding-top: var(--ifinsta-space-1-5);
        margin-top: 2px;
    }

    /* Slightly smaller logo to reclaim space for info/actions row */
    .discover-store-logo {
        width: 46px;
        height: 46px;
    }
}

/* ── 3. Browse tabs → equal-width segments at ≤640px ─────────────────────
   With just three tabs (All / Products / Stores) even distribution looks
   cleaner than centred-and-wrapping.                                         */
@media (max-width: 640px) {
    .discover-tabs--browse {
        width: 100%;
    }

    .discover-tabs--browse .discover-tab {
        flex: 1;
        justify-content: center;
        text-align: center;
    }
}

/* ── 4. Price tiers: subtle highlight on the first (lowest-qty) tier ──────
   Mirrors the Alibaba "lower-priced" badge on the lead tier.                 */
.discover-pdp-price-tier:first-child {
    background: rgba(37, 99, 235, 0.04);
}

.discover-pdp-price-tier:first-child .discover-pdp-price-tier__price {
    color: var(--ifinsta-primary-700, #1d4ed8);
}

/* Tighter padding on very narrow screens */
@media (max-width: 380px) {
    .discover-pdp-price-tier {
        padding: var(--ifinsta-space-2) var(--ifinsta-space-2);
    }

    .discover-pdp-price-tier__label {
        font-size: 0.63rem;
    }

    .discover-pdp-price-tier__price {
        font-size: 13px;
    }
}

/* ── 5. Contact page: collapse accent sidebar copy on mobile ──────────────
   The long title / lead text wastes vertical space on small screens.
   Keep just the contact-method cards; hide the decorative copy block.        */
@media (max-width: 768px) {

    /* Reverse stacking order so the form appears first (primary action) */
    .discover-contact-layout {
        display: flex;
        flex-direction: column-reverse;
        gap: var(--ifinsta-space-4);
    }

    /* Compact the accent sidebar */
    .discover-contact-card--accent {
        padding: var(--ifinsta-space-4);
        gap: var(--ifinsta-space-3);
    }

    /* Hide marketing copy — keep only the actionable methods & footer */
    .discover-contact-copy,
    .discover-contact-footer {
        display: none;
    }
}

/* ── 6. PDP mobile CTA bar: 3-button layout refinement ───────────────────
   Ensure all three buttons (Add to cart / Inquire / Chat) display cleanly
   at widths as narrow as 320px.                                              */
@media (max-width: 640px) {
    .discover-pdp-mobile-cta-bar {
        gap: 8px;
        padding: 10px 12px calc(env(safe-area-inset-bottom, 0px) + 10px);
    }

    /* Primary CTA gets 2× share; secondary/whatsapp share the rest equally */
    .discover-pdp-mobile-cta-bar .discover-pdp-cta-btn--primary {
        flex: 2;
    }

    .discover-pdp-mobile-cta-bar .discover-pdp-cta-btn--secondary,
    .discover-pdp-mobile-cta-bar .discover-pdp-cta-btn--whatsapp {
        flex: 1;
    }

    /* Keep icon + label visible; allow label to shrink */
    .discover-pdp-mobile-cta-bar .discover-pdp-cta-btn {
        min-height: 46px;
        font-size: 0.78rem;
        padding: 10px 10px;
        gap: 5px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        justify-content: center;
    }

    .discover-pdp-mobile-cta-bar .discover-pdp-cta-btn svg {
        flex-shrink: 0;
    }
}

/* ── 7. PDP: gallery image border-radius — edge-to-edge on mobile ─────────
   At ≤640px the main image is already borderless; ensure the thumbstrip
   has matching minimal styling.                                              */
@media (max-width: 640px) {
    .discover-pdp-thumbstrip {
        padding: var(--ifinsta-space-2) 14px;
        background: var(--ifinsta-bg);
        border-bottom: 1px solid var(--ifinsta-border-light);
    }
}

/* ── 8. Storefront home: sidebar → compact action row on mobile ───────────
   Below 640px the sidebar already has order:2. Add a visible divider and
   compress the card padding so it doesn't dominate the viewport.            */
@media (max-width: 640px) {
    .storefront-sidebar__card:first-child {
        border-top: 1px solid var(--ifinsta-border-light);
        padding-top: var(--ifinsta-space-3);
    }
}

/* ── 9. Browse actions bar: filter + sort always in one line ─────────────
   At ≤640px the actions-right row is `justify-content: space-between`.
   Prevent the sort select from being squashed on narrower phones.           */
@media (max-width: 480px) {
    .discover-sort-select {
        max-width: 130px;
        font-size: 0.78rem;
    }

    .discover-sort-select-wrap__label {
        display: none;
        /* "Sort by" label hidden; select label is self-descriptive */
    }
}

/* ── 10. Store card: touch-friendly highlight ─────────────────────────────
   On touch devices cards don't respond to :hover; add a :active state so
   the user gets tactile feedback when tapping a store card.                  */
@media (hover: none) and (pointer: coarse) {
    .discover-card:active {
        transform: scale(0.98);
        opacity: 0.9;
        transition: transform 0.1s ease, opacity 0.1s ease;
    }
}

/* ==========================================================================
   MARKETPLACE REFRESH — Browse, cards, storefront, PDP, checkout
   ========================================================================== */

.discover-market-promo {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(240px, 0.9fr);
    gap: var(--ifinsta-space-4);
    padding: var(--ifinsta-space-5) clamp(1.25rem, 2vw, 1.75rem);
    border-radius: 4px;
    color: #fff;
    background:
        radial-gradient(circle at top right, rgba(255, 255, 255, 0.16), transparent 32%),
        linear-gradient(135deg, #2254f4 0%, #2766d8 52%, #f97316 100%);
}

.discover-market-promo__copy {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-market-promo__eyebrow {
    margin: 0;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    opacity: 0.92;
}

.discover-market-promo__title {
    margin: 0;
    max-width: 18ch;
    font-size: clamp(1.75rem, 3vw, 2.7rem);
    line-height: 0.98;
    letter-spacing: -0.04em;
}

.discover-market-promo__text {
    margin: 0;
    max-width: 58ch;
    color: rgba(255, 255, 255, 0.9);
    line-height: 1.6;
}

.discover-market-promo__stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--ifinsta-space-2);
    align-self: center;
    align-content: start;
}

.discover-market-promo__stat {
    display: grid;
    align-content: center;
    gap: 0.25rem;
    padding: var(--ifinsta-space-3) var(--ifinsta-space-3);
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.18);
}

.discover-market-promo__stat strong {
    font-size: clamp(1.3rem, 2.4vw, 1.9rem);
    line-height: 1;
}

.discover-market-promo__stat span {
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.84);
}

.discover-browse-categories {
    display: flex;
    gap: var(--ifinsta-space-2);
    overflow-x: auto;
    padding-bottom: 2px;
    scrollbar-width: none;
}

.discover-browse-categories::-webkit-scrollbar {
    display: none;
}

.discover-browse-categories__chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.5rem;
    padding: 0 var(--ifinsta-space-4);
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, 0.10);
    background: #fff;
    color: var(--ifinsta-text);
    text-decoration: none;
    white-space: nowrap;
}

.discover-browse-categories__chip--active {
    border-color: rgba(249, 115, 22, 0.26);
    background: rgba(249, 115, 22, 0.08);
    color: #c2410c;
}

.discover-feature-tiles {
    display: flex;
    flex-wrap: nowrap;
    gap: var(--ifinsta-space-3);
    overflow-x: auto;
    overflow-y: hidden;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
}

.discover-feature-tile {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-3);
    flex: 0 0 auto;
    min-width: 220px;
    border-radius: 4px;
    border: 1px solid #e8eaed;
    background: #fff;
    color: var(--ifinsta-text);
    text-decoration: none;
    transition: border-color 0.15s ease;
    cursor: pointer;
}

.discover-feature-tile:hover {
    border-color: var(--ifinsta-primary-400);
    color: var(--ifinsta-primary-600);
}

.discover-feature-tile__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 4px;
    background: rgba(37, 99, 235, 0.06);
    color: var(--ifinsta-primary-600);
    flex-shrink: 0;
}

.discover-feature-tile__copy {
    display: grid;
    gap: 0.15rem;
    text-align: left;
}

.discover-feature-tile__copy strong {
    font-size: var(--ifinsta-text-sm);
}

.discover-feature-tile__copy span {
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-text-muted);
}

.discover-market-showcase {
    display: grid;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-4);
    border-radius: 4px;
    background: #fff;
    border: 1px solid #e8eaed;
}

.discover-market-showcase__header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--ifinsta-space-3);
}

.discover-market-showcase__title {
    margin: 0;
    font-size: clamp(1.35rem, 2vw, 1.9rem);
    line-height: 1.05;
}

.discover-market-showcase__text {
    margin: 0.35rem 0 0;
    color: var(--ifinsta-text-secondary);
}

.discover-market-showcase__lane {
    grid-auto-columns: minmax(230px, 280px);
}

.discover-card--product.discover-card--browse,
.discover-card--product.discover-card--lane,
.discover-card--product.discover-card--grid {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 0;
    border-radius: 4px;
    background: #fff;
    transition: border-color 0.15s ease;
}

.discover-card--product.discover-card--lane {
    min-width: 0;
}

.discover-card--product .discover-card__carousel-wrap {
    padding: 0;
}

.discover-card--product .discover-card__anchor--image {
    border-radius: 20px;
    box-shadow: none;
}

.discover-card--product .discover-card__slides {
    aspect-ratio: 0.94;
    background: linear-gradient(180deg, #f8fafc, #eef2ff);
    border-radius: 20px;
}

.discover-card--product .discover-card__slide {
    object-fit: cover;
}

.discover-card__price-notes,
.discover-card__trust-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.discover-card__tag,
.discover-card__trust-tag {
    display: inline-flex;
    align-items: center;
    min-height: 1.4rem;
    padding: 0;
    border-radius: 0;
    background: transparent;
    border: none;
    color: var(--ifinsta-text-muted);
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.01em;
}

.discover-card__tag--soft {
    color: var(--ifinsta-primary-600);
}

.discover-card__tag--accent {
    color: #c2410c;
}

.discover-card__trust-tag--verified {
    color: #166534;
}

.discover-card__trust-tags {
    margin-top: 0.2rem;
}

.discover-card--product .discover-card__title {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    min-height: 2.7em;
}

.discover-card--product .discover-card__cta-btn {
    border-color: var(--ifinsta-primary-500);
    display: grid;
    align-content: center;
    justify-content: center;
}

.discover-card--product .discover-card__cta-btn:hover {
    background: var(--ifinsta-primary-600);
    border-color: var(--ifinsta-primary-600);
    color: #fff;
}

.discover-store-overview {
    display: grid;
    gap: var(--ifinsta-space-3);
}

.discover-store-overview__panel {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(280px, 0.95fr);
    gap: var(--ifinsta-space-4);
    padding: clamp(1.2rem, 2vw, 1.7rem);
    border-radius: 4px;
    background: #fff;
    border: 1px solid #e8eaed;
}

.discover-store-overview__intro {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-store-overview__eyebrow {
    margin: 0;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ifinsta-primary-600);
}

.discover-store-overview__title {
    margin: 0;
    font-size: clamp(1.6rem, 2.6vw, 2.3rem);
    line-height: 0.98;
    letter-spacing: -0.04em;
}

.discover-store-overview__text {
    margin: 0;
    color: var(--ifinsta-text-secondary);
    line-height: 1.6;
}

.discover-store-overview__stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--ifinsta-space-2);
}

.discover-store-overview__stat {
    display: grid;
    gap: 0.2rem;
    padding: var(--ifinsta-space-3);
    border-radius: 4px;
    background: #f8f9fa;
    border: 1px solid #e8eaed;
}

.discover-store-overview__stat strong {
    font-size: 1.35rem;
    line-height: 1;
}

.discover-store-overview__stat span {
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-xs);
}

.discover-store-overview__actions {
    display: flex;
    gap: var(--ifinsta-space-2);
    flex-wrap: wrap;
}

.discover-store-overview__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.8rem;
    padding: 0 var(--ifinsta-space-4);
    border-radius: 4px;
    background: var(--ifinsta-primary-600);
    color: #fff;
    text-decoration: none;
    font-weight: 700;
}

.discover-store-overview__button:hover {
    background: var(--ifinsta-primary-700);
}

.discover-store-overview__button--ghost {
    background: #fff;
    border: 1px solid #e8eaed;
    color: var(--ifinsta-text);
}

.discover-store-overview__button--ghost:hover {
    border-color: var(--ifinsta-primary-400);
    color: var(--ifinsta-primary-600);
}

.discover-store-overview__tabs {
    display: flex;
    gap: var(--ifinsta-space-2);
    overflow-x: auto;
    padding-bottom: 2px;
    scrollbar-width: none;
}

.discover-store-overview__tabs::-webkit-scrollbar {
    display: none;
}

.discover-store-overview__tab {
    display: inline-flex;
    align-items: center;
    min-height: 2.5rem;
    padding: 0 var(--ifinsta-space-4);
    border-radius: 4px;
    background: #fff;
    border: 1px solid #e8eaed;
    color: var(--ifinsta-text);
    text-decoration: none;
    white-space: nowrap;
    font-size: var(--ifinsta-text-sm);
    transition: border-color 0.15s ease, color 0.15s ease;
}

.discover-store-overview__tab:hover {
    border-color: var(--ifinsta-primary-400);
    color: var(--ifinsta-primary-600);
}

.discover-pdp-promo-band {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    flex-wrap: wrap;
    margin-bottom: var(--ifinsta-space-4);
    padding: var(--ifinsta-space-3) 0;
    border-radius: 0;
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--ifinsta-border-light);
}

.discover-pdp-promo-band__label {
    display: inline-flex;
    align-items: center;
    min-height: 1.9rem;
    padding: 0 0.7rem;
    border-radius: 3px;
    background: var(--ifinsta-primary-600);
    color: #fff;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.discover-pdp-promo-band__text {
    color: var(--ifinsta-text);
    font-weight: 600;
}

.discover-pdp-price-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-top: -0.35rem;
}

.discover-pdp-price-summary__pill {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0 0.8rem;
    border-radius: 4px;
    background: var(--ifinsta-neutral-100);
    border: none;
    color: var(--ifinsta-text-secondary);
    font-size: 0.76rem;
    font-weight: 600;
}

.discover-pdp-price-summary__pill--accent {
    background: rgba(249, 115, 22, 0.1);
    color: #c2410c;
}

.discover-checkout-hero {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-4);
    border-radius: 4px;
    background: #fff;
    border: 1px solid #e8eaed;
}

.discover-checkout-hero__copy {
    display: grid;
    gap: 0.35rem;
}

.discover-checkout-hero__eyebrow {
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ifinsta-primary-600);
}

.discover-checkout-hero__meta {
    display: flex;
    gap: var(--ifinsta-space-2);
    flex-wrap: wrap;
    justify-content: flex-end;
}

.discover-checkout-hero__pill {
    display: inline-flex;
    align-items: center;
    min-height: 2.2rem;
    padding: 0 var(--ifinsta-space-3);
    border-radius: 4px;
    background: #f8f9fa;
    border: 1px solid #e8eaed;
    font-weight: 700;
}

.discover-checkout-hero__pill--muted {
    color: var(--ifinsta-text-muted);
}

.discover-checkout-item {
    grid-template-columns: auto minmax(0, 1fr) auto;
}

.discover-checkout-item__media {
    flex-shrink: 0;
}

.discover-checkout-item__image,
.discover-checkout-item__image--placeholder {
    width: 88px;
    height: 88px;
    border-radius: 18px;
}

.discover-checkout-item__image {
    object-fit: cover;
    display: block;
    background: #f8fafc;
}

.discover-checkout-item__image--placeholder {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #dbeafe, #ffedd5);
    color: var(--ifinsta-text);
    font-size: 1.4rem;
    font-weight: 800;
}

.discover-checkout-state__actions {
    display: flex;
    gap: var(--ifinsta-space-2);
    flex-wrap: wrap;
    justify-content: center;
}

.discover-checkout-pickup {
    display: grid;
    gap: var(--ifinsta-space-2);
    padding: var(--ifinsta-space-3);
    border-radius: 22px;
    background: linear-gradient(180deg, #fff, #f8fafc);
    border: 1px solid rgba(148, 163, 184, 0.16);
}

.discover-checkout-pickup__title {
    margin: 0;
    font-size: var(--ifinsta-text-base);
}

.discover-checkout-pickup__text,
.discover-checkout-pickup__meta {
    margin: 0;
    color: var(--ifinsta-text-secondary);
}

.discover-checkout-protection {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.discover-checkout-protection__item {
    display: inline-flex;
    align-items: center;
    min-height: 1.9rem;
    padding: 0 0.65rem;
    border-radius: 999px;
    background: rgba(37, 99, 235, 0.08);
    color: #1d4ed8;
    font-size: 0.72rem;
    font-weight: 700;
}

.discover-checkout-assurance,
.discover-checkout-recommendations {
    display: grid;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-4);
    border-radius: 28px;
    background: #fff;
    border: 1px solid rgba(148, 163, 184, 0.20);
}

.discover-checkout-assurance__header,
.discover-checkout-recommendations__header {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: var(--ifinsta-space-3);
}

.discover-checkout-assurance__title,
.discover-checkout-recommendations__title {
    margin: 0;
    font-size: clamp(1.2rem, 2vw, 1.7rem);
}

.discover-checkout-assurance__text {
    margin: 0.35rem 0 0;
    color: var(--ifinsta-text-secondary);
}

.discover-checkout-assurance__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--ifinsta-space-3);
}

.discover-checkout-assurance__card {
    display: grid;
    gap: 0.35rem;
    padding: var(--ifinsta-space-3);
    border-radius: 20px;
    background: linear-gradient(180deg, #f8fafc, #fff);
    border: 1px solid rgba(148, 163, 184, 0.14);
}

.discover-checkout-assurance__card strong {
    font-size: var(--ifinsta-text-sm);
}

.discover-checkout-assurance__card span {
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-text-xs);
    line-height: 1.5;
}

@media (max-width: 1024px) {

    .discover-market-promo,
    .discover-store-overview__panel {
        grid-template-columns: 1fr;
    }

    .discover-checkout-assurance__grid {
        grid-template-columns: 1fr;
    }

    .discover-checkout-item {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .discover-checkout-item__controls {
        grid-column: 1 / -1;
        justify-items: stretch;
    }
}

@media (max-width: 640px) {
    .discover-market-promo {
        padding: 1.1rem;
        border-radius: 24px;
    }

    .discover-market-promo__stats {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .discover-market-showcase,
    .discover-checkout-assurance,
    .discover-checkout-recommendations,
    .discover-store-overview__panel {
        padding: var(--ifinsta-space-3);
        border-radius: 24px;
    }

    .discover-market-showcase__header,
    .discover-checkout-assurance__header,
    .discover-checkout-recommendations__header,
    .discover-checkout-hero {
        flex-direction: column;
        align-items: stretch;
    }

    .discover-checkout-item {
        gap: var(--ifinsta-space-3);
    }

    .discover-checkout-item__image,
    .discover-checkout-item__image--placeholder {
        width: 74px;
        height: 74px;
    }

    .discover-pdp-promo-band {
        padding: var(--ifinsta-space-2-5) var(--ifinsta-space-3);
    }

    .discover-store-overview__stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* ==========================================================================
   2026 PUBLIC DISCOVER REFRAME
   Flatter, denser marketplace language for public discover surfaces.
   ========================================================================== */

.discover-body--public,
.discover-public-page,
.discover-market-page,
.discover-pdp-page {
    background: #ffffff;
}

.discover-body--public {
    padding-bottom: var(--ifinsta-space-10);
}

.discover-market-stack,
.discover-page-stack {
    gap: 0;
}

.discover-market-promo,
.discover-browse-topbar,
.discover-market-showcase,
.discover-actions-bar,
.discover-sidebar-panel,
.discover-main-panel,
.discover-store-header,
.discover-store-overview__panel,
.storefront-sidebar__card,
.discover-products-panel,
.discover-checkout-shell,
.discover-checkout-panel,
.discover-checkout-assurance,
.discover-checkout-recommendations,
.discover-contact-card,
.discover-pdp-gallery,
.discover-pdp-info,
.discover-pdp-details-section,
.discover-pdp-supplier-card,
.discover-story-viewer-frame,
.discover-story-viewer-panel,
.discover-section {
    background: #fff;
    border: none;
    border-radius: 0;
    box-shadow: none !important;
}

.discover-market-promo,
.discover-market-showcase,
.discover-actions-bar,
.discover-store-overview__panel,
.discover-checkout-assurance,
.discover-checkout-recommendations,
.discover-contact-card,
.discover-story-viewer-frame,
.discover-story-viewer-panel,
.discover-section {
    padding: var(--ifinsta-space-4);
}

.discover-market-promo,
.discover-contact-card--accent,
.discover-checkout-pickup,
.discover-market-spotlight,
.discover-pdp-promo-band,
.discover-pdp-shipping__box,
.discover-pdp-discount {
    background: #fff;
    border: none;
    box-shadow: none;
}

.discover-market-promo,
.discover-contact-card--accent,
.discover-market-spotlight,
.discover-pdp-promo-band,
.discover-pdp-discount {
    background-image: none;
}

.discover-market-promo__title,
.discover-store-overview__title,
.discover-pdp-name--header,
.discover-contact-title,
.discover-contact-form__title,
.discover-checkout-assurance__title,
.discover-checkout-recommendations__title {
    letter-spacing: -0.02em;
}

.discover-market-promo__text,
.discover-market-header__summary,
.discover-store-overview__text,
.discover-contact-lead,
.discover-contact-form__lead,
.discover-checkout-panel__copy,
.discover-checkout-assurance__text {
    color: var(--ifinsta-text-secondary);
}

.discover-market-promo__stats,
.discover-store-overview__stats,
.discover-checkout-assurance__grid {
    gap: var(--ifinsta-space-2);
}

.discover-market-promo__stat,
.discover-store-overview__stat,
.discover-checkout-assurance__card {
    border: 1px solid #e5e7eb;
    border-radius: 4px;
    background: #fff;
    box-shadow: none;
}

.discover-market-promo__stat,
.discover-store-overview__stat {
    padding: var(--ifinsta-space-3);
}

.discover-browse-topbar {
    display: grid;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-4);
}

.discover-search__input,
.discover-sort-select,
.discover-price-filter__input,
.discover-form-control,
.discover-manage-field__control,
.discover-pdp-ship-to__input {
    border-radius: 4px;
    border-color: #d1d5db;
    box-shadow: none;
}

.discover-search__input {
    background: #f5f6f8;
    border: 2px solid #ff6a00;
    border-radius: 24px;
}

.discover-tabs,
.discover-tabs--storefront {
    gap: var(--ifinsta-space-4);
}

.discover-tab,
.discover-browse-categories__chip,
.discover-category-chip,
.discover-quick-link,
.discover-active-chip,
.discover-story-chip,
.discover-checkout-hero__pill,
.discover-checkout-protection__item,
.discover-pdp-price-summary__pill,
.discover-card__tag,
.discover-card__trust-tag,
.discover-pdp-verified-badge,
.discover-store-meta__chip {
    border-radius: 4px;
    border: none;
    background: #f5f6f8;
    box-shadow: none;
}

.discover-tab {
    padding: var(--ifinsta-space-2) 0;
}

.discover-tab--active,
.discover-browse-categories__chip--active,
.discover-category-chip--active,
.discover-quick-link--active,
.discover-story-chip--active {
    color: #ff6a00;
    border-color: #ff6a00;
    background: transparent;
    font-weight: 700;
}

.discover-tab__count {
    background: rgba(15, 23, 42, 0.05);
    color: var(--ifinsta-text-secondary);
}

.discover-feature-tiles {
    gap: var(--ifinsta-space-2);
    padding-bottom: 0.1rem;
}

.discover-feature-tile,
.discover-market-hero__signal,
.discover-market-stat {
    border: none;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.discover-feature-tile:hover,
.discover-card:hover,
.discover-story-card:hover,
.discover-story-viewer-list__item:hover,
.discover-banner-btn:hover {
    transform: none;
    box-shadow: none;
}

.discover-sidebar-panel,
.discover-main-panel {
    padding: var(--ifinsta-space-4);
}

.discover-sidebar-panel__inner,
.discover-main-panel {
    display: grid;
    gap: 0;
}

.discover-sidebar-section+.discover-sidebar-section,
.discover-card__supplier,
.discover-card__cta,
.discover-card__price-notes,
.discover-story-card__footer,
.discover-story-viewer-foot,
.discover-story-viewer-panel+.discover-story-viewer-panel,
.discover-contact-methods,
.discover-checkout-summary,
.discover-checkout-pickup,
.discover-pdp-panel,
.discover-pdp-supplier-card,
.discover-pdp-trust-row,
.discover-pdp-price-tiers,
.discover-pdp-details-section,
.storefront-sidebar__share,
.storefront-sidebar__actions {
    border-top: 1px solid #edf0f2;
}

.discover-sidebar-section+.discover-sidebar-section,
.discover-contact-methods,
.discover-checkout-summary,
.discover-checkout-pickup,
.discover-pdp-panel,
.discover-pdp-supplier-card,
.discover-pdp-trust-row,
.discover-pdp-price-tiers,
.discover-pdp-details-section,
.storefront-sidebar__share {
    padding-top: var(--ifinsta-space-3);
}

.discover-card {
    border: none;
    border-radius: 4px;
    background: #fff;
    overflow: hidden;
    box-shadow: none !important;
}

.discover-card__image-wrap {
    background: #fff;
    border-bottom: 1px solid #edf0f2;
}

.discover-card__body,
.discover-card__content {
    display: grid;
    gap: var(--ifinsta-space-2);
    padding: var(--ifinsta-space-3);
}

.discover-card__title {
    font-size: var(--ifinsta-text-sm);
    line-height: 1.45;
}

.discover-card__price-main,
.discover-card__popup-price,
.discover-pdp-price,
.discover-product-price {
    color: var(--ifinsta-text);
    font-family: var(--ifinsta-font-mono);
    font-weight: var(--ifinsta-font-bold);
}

.discover-card__price-notes,
.discover-card__supplier,
.discover-card__cta {
    margin-top: 0;
}

.discover-card__supplier {
    display: grid;
    gap: 0.35rem;
}

.discover-card__supplier-meta,
.discover-card__trust-tags,
.discover-pdp-trust-row,
.discover-store-meta,
.discover-story-card__footer {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.discover-card__cta-btn,
.discover-pdp-cta-btn,
.discover-store-overview__button,
.storefront-sidebar__btn,
.discover-contact-method,
.discover-btn {
    border-radius: 4px;
    box-shadow: none;
}

.discover-card__cta-btn,
.discover-pdp-cta-btn,
.discover-store-overview__button {
    min-height: 2.75rem;
}

.discover-card__cta {
    display: block;
}

.discover-card__cta-btn {
    width: 100%;
}

.discover-card__badge,
.discover-pdp-discount-badge {
    border-radius: 4px;
    box-shadow: none;
}

.discover-card--product.discover-card--browse,
.discover-card--product.discover-card--lane,
.discover-card--product.discover-card--grid {
    border: none;
    background: transparent;
    width: 100%;
    max-width: min(100%, 236px);
    justify-self: start;
}

.discover-card--product .discover-card__carousel-wrap {
    position: relative;
    padding: 0;
    width: 100%;
    max-width: 100%;
}

.discover-card--product .discover-card__anchor--image {
    display: block;
    width: 100%;
    max-width: 100%;
    border-radius: 6px;
    overflow: hidden;
}

.discover-card--product .discover-card__slides {
    aspect-ratio: 1 / 1;
    width: 100%;
    max-width: 100%;
    border-radius: 6px;
    background: #f6f7f9;
}

.discover-card--product .discover-card__image-wrap {
    border-bottom: none;
}

.discover-card--product .discover-card__body {
    gap: 0.25rem;
    padding: 0.5rem 0.125rem 0;
}

.discover-card--product .discover-card__title {
    font-size: 0.88rem;
    line-height: 1.35;
    min-height: 2.4em;
}

.discover-card--product .discover-card__price-block {
    display: flex;
    align-items: baseline;
    gap: 0.35rem;
}

.discover-card--product .discover-card__price-main {
    font-size: 1.05rem;
    line-height: 1.2;
}

.discover-card--product .discover-card__price-old {
    font-size: 0.72rem;
}

.discover-card--product .discover-card__price-notes,
.discover-card--product .discover-card__supplier {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    align-items: center;
    margin-top: 0;
    padding-top: 0;
    border-top: none;
}

.discover-card--product .discover-card__tag,
.discover-card--product .discover-card__trust-tag,
.discover-card--product .discover-card__supplier-name,
.discover-card--product .discover-card__rating-inline,
.discover-card--product .discover-card__supplier-city {
    min-height: auto;
    padding: 0;
    border: none;
    background: transparent;
    font-size: 0.74rem;
    color: var(--ifinsta-text-secondary);
}

.discover-card--product .discover-card__supplier-meta,
.discover-card--product .discover-card__supplier-sep,
.discover-card--product .discover-card__trust-tag:not(.discover-card__trust-tag--verified) {
    display: none;
}

.discover-card--product .discover-card__supplier-name {
    font-weight: var(--ifinsta-font-normal);
}

.discover-card--product .discover-card__trust-tag--verified {
    color: var(--ifinsta-primary-700);
    font-weight: var(--ifinsta-font-semibold);
}

.discover-card--product .discover-card__cta {
    display: none;
}

.discover-card__quick-action {
    position: absolute;
    left: 0.6rem;
    bottom: 0.6rem;
    z-index: 2;
}

.discover-card__cta-btn--overlay {
    width: 2rem;
    height: 2rem;
    min-width: 2rem;
    min-height: 2rem;
    padding: 0;
    border-radius: 999px;
    border: 1px solid rgba(17, 24, 39, 0.08);
    background: rgba(255, 255, 255, 0.96);
    color: var(--ifinsta-text);
}

.discover-card__cta-btn--overlay svg {
    width: 0.95rem;
    height: 0.95rem;
}

.discover-card__cta-btn--overlay:hover {
    background: #fff;
    color: var(--ifinsta-primary-700);
    border-color: rgba(37, 99, 235, 0.18);
}

.discover-card--product .discover-card__badge {
    top: 0.55rem;
    left: 0.55rem;
    padding: 0.12rem 0.4rem;
    border-radius: 999px;
    font-size: 0.62rem;
}

.discover-card--product .discover-card__badge--verified {
    top: 0.55rem;
    bottom: auto;
    left: auto;
    right: 0.55rem;
    background: rgba(255, 255, 255, 0.96);
    color: var(--ifinsta-primary-700);
    border: 1px solid rgba(37, 99, 235, 0.18);
}

.discover-store-header {
    padding: var(--ifinsta-space-3);
    --discover-store-control-height: 2.5rem;
    --discover-store-control-padding-x: 0.875rem;
    --discover-store-control-radius: 999px;
    --discover-store-icon-size: 1rem;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    background: #fff;
}

.discover-store-banner {
    height: clamp(5.75rem, 15vw, 7.5rem);
    border-radius: 4px 4px 0 0;
    overflow: hidden;
}

.discover-store-banner__overlay {
    top: 0.75rem;
    right: 0.75rem;
}

.discover-banner-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.375rem;
    height: var(--discover-store-control-height);
    min-height: var(--discover-store-control-height);
    padding: 0 var(--discover-store-control-padding-x);
    border-radius: var(--discover-store-control-radius);
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid #d1d5db;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-semibold);
    line-height: 1;
}

.discover-banner-btn--icon {
    width: var(--discover-store-control-height);
    min-width: var(--discover-store-control-height);
    padding: 0;
}

.discover-store-icon-btn {
    width: var(--discover-store-control-height);
    height: var(--discover-store-control-height);
    min-width: var(--discover-store-control-height);
    min-height: var(--discover-store-control-height);
    padding: 0;
    border-radius: var(--discover-store-control-radius);
}

.discover-store-profile {
    margin-top: calc(-1 * var(--ifinsta-space-3));
    padding: 0 0.75rem 0.75rem;
    display: grid;
    gap: 0.625rem;
    align-items: stretch;
}

.discover-store-profile__main {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    width: 100%;
    padding: 0.875rem 1rem;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
}

.discover-store-profile__identity {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.875rem;
    min-width: 0;
    flex: 1;
}

.discover-store-logo {
    width: 4rem;
    height: 4rem;
    margin-top: -1.5rem;
    border-radius: 4px;
    border-width: 1px;
    border-color: #d1d5db;
    box-shadow: 0 0 0 3px #fff;
    transition: all 0.3s ease;
    cursor: pointer;
    background: #fff;
}

.discover-store-logo:hover {
    transform: scale(1.05) translateY(-2px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12), 0 0 0 3px #fff;
    border-color: var(--discover-primary);
}

.discover-banner-btn svg,
.discover-store-icon-btn svg {
    width: var(--discover-store-icon-size);
    height: var(--discover-store-icon-size);
    flex: 0 0 auto;
}

.discover-store-overview__actions,
.discover-checkout-assurance__header,
.discover-checkout-recommendations__header,
.discover-story-viewer-head,
.discover-story-viewer-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ifinsta-space-3);
}

.discover-layout-sidebar--public {
    gap: var(--ifinsta-space-3);
}

.discover-store-info {
    min-width: 0;
    width: 100%;
    padding-bottom: 0;
}

.discover-store-name {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    font-size: clamp(1.55rem, 2.4vw, 2rem);
    line-height: 1.08;
}

.discover-store-tagline {
    margin-top: 0.25rem;
    max-width: 42rem;
    line-height: 1.45;
}

.discover-store-meta {
    gap: 0.625rem;
    margin-top: 0.5rem;
}

.discover-store-actions {
    display: flex;
    gap: 0.5rem;
    align-self: center;
    justify-self: end;
    flex-shrink: 0;
}

.discover-btn--cart .discover-cart-pill {
    position: absolute;
    top: -0.35rem;
    right: -0.35rem;
    min-width: 1.3rem;
    height: 1.3rem;
    padding: 0 0.35rem;
    z-index: 2;
    pointer-events: none;
}

.discover-tabs--storefront {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    padding: 0.625rem 0.75rem;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    background: #fff;
    overflow-x: auto;
    border-bottom: 1px solid #e5e7eb;
}

.discover-tabs--storefront .discover-tab {
    flex: 0 0 auto;
}

@media (max-width: 480px) {
    .discover-store-header {
        --discover-store-control-height: 2.25rem;
        --discover-store-control-padding-x: 0.75rem;
        --discover-store-icon-size: 0.95rem;
    }

    .discover-store-profile {
        padding: 0 0.625rem 0.625rem;
    }

    .discover-store-profile__main {
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 0.875rem;
        padding: 0.625rem 0.75rem;
    }

    .discover-store-profile__identity {
        display: flex;
        flex-direction: row;
        align-items: center;
        gap: 0.625rem;
        min-width: 0;
        flex: 1;
    }

    .discover-store-logo {
        width: 2.875rem;
        height: 2.875rem;
        margin-top: -0.875rem;
    }

    .discover-store-name {
        font-size: 1.08rem;
        line-height: 1.12;
        gap: 0.35rem;
    }

    .discover-store-tagline {
        margin-top: 0.15rem;
        font-size: 0.78rem;
        line-height: 1.35;
    }

    .discover-store-meta {
        margin-top: 0.35rem;
        gap: 0.45rem;
    }

    .discover-store-actions {
        justify-self: end;
    }

    .discover-tabs--storefront {
        padding: 0.5rem;
    }
}

@media (max-width: 900px) {
    .discover-store-profile__main {
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }

    .discover-store-actions {
        justify-self: end;
    }
}

.storefront-sidebar__card,
.discover-contact-card,
.discover-checkout-panel,
.discover-checkout-assurance,
.discover-checkout-recommendations {
    padding: var(--ifinsta-space-4);
}

.discover-contact-card--accent {
    overflow: visible;
}

.discover-contact-method {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-3);
    text-decoration: none;
    color: inherit;
}

.discover-checkout-layout,
.discover-contact-layout,
.discover-story-viewer-shell {
    gap: var(--ifinsta-space-3);
}

.discover-checkout-pickup,
.discover-checkout-assurance__card,
.discover-pdp-panel,
.discover-pdp-shipping__box {
    border-radius: 4px;
}

.discover-checkout-protection__item,
.discover-pdp-price-summary__pill,
.discover-card__tag,
.discover-card__trust-tag {
    min-height: 1.9rem;
    padding: 0 0.65rem;
    color: var(--ifinsta-text-secondary);
}

.discover-pdp-page .discover-container--public {
    display: grid;
    gap: var(--ifinsta-space-3);
}

.discover-pdp-header,
.discover-pdp-promo-band,
.discover-pdp-breadcrumb,
.discover-pdp-related {
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    background: #fff;
    box-shadow: none;
}

.discover-pdp-header,
.discover-pdp-related {
    padding: var(--ifinsta-space-4);
}

.discover-pdp-breadcrumb {
    padding: var(--ifinsta-space-3) var(--ifinsta-space-4);
}

.discover-pdp-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
    gap: var(--ifinsta-space-3);
    align-items: start;
}

.discover-pdp-gallery,
.discover-pdp-info {
    padding: var(--ifinsta-space-4);
}

.discover-pdp-thumb,
.discover-pdp-media-tab,
.discover-pdp-tab,
.discover-pdp-variant-swatch,
.discover-pdp-media-action,
.discover-pdp-nav-btn {
    border-radius: 4px;
    border-color: #d1d5db;
    box-shadow: none;
}

.discover-pdp-main-wrap,
.discover-pdp-media-display,
.discover-pdp-main-img--placeholder {
    border-radius: 4px;
    background: #f8fafc;
}

.discover-pdp-supplier-card,
.discover-pdp-details-section,
.discover-pdp-related {
    box-shadow: none;
}

.discover-story-toolbar {
    display: flex;
    justify-content: space-between;
    gap: var(--ifinsta-space-3);
    flex-wrap: wrap;
}

.discover-story-toolbar__group {
    display: flex;
    gap: var(--ifinsta-space-2);
    flex-wrap: wrap;
}

.discover-story-chip {
    display: inline-flex;
    align-items: center;
    min-height: 2.1rem;
    padding: 0 var(--ifinsta-space-3);
    border: 1px solid #d1d5db;
    border-radius: 4px;
    background: #fff;
    color: var(--ifinsta-text);
    text-decoration: none;
    font-size: var(--ifinsta-text-sm);
    font-weight: var(--ifinsta-font-medium);
}

.discover-story-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: var(--ifinsta-space-3);
}

.discover-story-card {
    display: grid;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    background: #fff;
    overflow: hidden;
}

.discover-story-card__media {
    position: relative;
    display: block;
    aspect-ratio: 4 / 5;
    background: #f8fafc;
}

.discover-story-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.discover-story-card__img--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ifinsta-text-muted);
}

.discover-story-card__status {
    position: absolute;
    top: var(--ifinsta-space-2);
    left: var(--ifinsta-space-2);
    min-height: 1.7rem;
    padding: 0 0.5rem;
    display: inline-flex;
    align-items: center;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid #d1d5db;
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
}

.discover-story-card__status--live {
    color: var(--ifinsta-primary-700);
    border-color: var(--ifinsta-primary-300);
}

.discover-story-card__body {
    display: grid;
    gap: var(--ifinsta-space-3);
    padding: var(--ifinsta-space-3);
}

.discover-story-card__store {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: var(--ifinsta-space-2);
    align-items: center;
}

.discover-story-card__logo,
.discover-story-card__logo--fallback {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 4px;
    object-fit: cover;
    border: 1px solid #d1d5db;
}

.discover-story-card__logo--fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f8fafc;
    color: var(--ifinsta-text);
    font-weight: var(--ifinsta-font-bold);
}

.discover-story-card__store-copy,
.discover-story-viewer-store__copy,
.discover-story-viewer-list__copy {
    min-width: 0;
    display: grid;
    gap: 0.15rem;
}

.discover-story-card__store-name,
.discover-story-viewer-list__copy strong {
    font-size: var(--ifinsta-text-sm);
}

.discover-story-card__meta,
.discover-story-viewer-store__copy span,
.discover-story-viewer-list__copy span {
    color: var(--ifinsta-text-muted);
    font-size: var(--ifinsta-text-xs);
}

.discover-story-card__caption {
    margin: 0;
    color: var(--ifinsta-text);
    line-height: 1.55;
}

.discover-story-card__caption--muted {
    color: var(--ifinsta-text-muted);
}

.discover-story-card__type,
.discover-story-viewer-tag {
    display: inline-flex;
    align-items: center;
    min-height: 1.8rem;
    padding: 0 0.6rem;
    border: 1px solid #d1d5db;
    border-radius: 4px;
    background: #fff;
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-text-xs);
    font-weight: var(--ifinsta-font-semibold);
}

.discover-story-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: var(--ifinsta-primary-700);
    font-weight: var(--ifinsta-font-semibold);
    text-decoration: none;
}

.discover-story-viewer-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    align-items: start;
}

.discover-story-viewer-frame,
.discover-story-viewer-panel {
    padding: var(--ifinsta-space-4);
}

.discover-story-viewer-frame {
    display: grid;
    gap: var(--ifinsta-space-3);
}

.discover-story-viewer-progress {
    display: flex;
    gap: 0.35rem;
}

.discover-story-viewer-progress__track {
    flex: 1;
    height: 4px;
    overflow: hidden;
    background: #e5e7eb;
    border-radius: 999px;
}

.discover-story-viewer-progress__fill {
    width: 0;
    height: 100%;
    background: var(--ifinsta-primary-500);
}

.discover-story-viewer-progress__fill--active {
    animation: discover-story-progress 5s linear forwards;
}

.discover-story-viewer-store {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: var(--ifinsta-space-2);
    align-items: center;
}

.discover-story-viewer-store__logo,
.discover-story-viewer-store__logo--fallback {
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 4px;
    object-fit: cover;
    border: 1px solid #d1d5db;
}

.discover-story-viewer-store__logo--fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f8fafc;
    font-weight: var(--ifinsta-font-bold);
}

.discover-story-viewer-actions,
.discover-story-viewer-panel__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ifinsta-space-2);
}

.discover-story-viewer-panel__actions--stack {
    display: grid;
}

.discover-story-viewer-media {
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    overflow: hidden;
    background: #f8fafc;
}

.discover-story-viewer-media__asset {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
}

.discover-story-viewer-media__asset--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ifinsta-text-muted);
}

.discover-story-viewer-copy {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-story-viewer-caption {
    margin: 0;
    line-height: 1.6;
}

.discover-story-viewer-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ifinsta-space-2);
}

.discover-story-viewer-nav {
    display: flex;
    gap: var(--ifinsta-space-2);
    justify-content: flex-end;
}

.discover-story-viewer-panel__title {
    margin: 0 0 var(--ifinsta-space-3);
    font-size: var(--ifinsta-text-base);
}

.discover-story-viewer-list {
    display: grid;
    gap: var(--ifinsta-space-2);
}

.discover-story-viewer-list__item {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr);
    gap: var(--ifinsta-space-2);
    align-items: center;
    padding: var(--ifinsta-space-2);
    border: 1px solid #e5e7eb;
    border-radius: 4px;
    background: #fff;
    text-decoration: none;
    color: inherit;
}

.discover-story-viewer-list__thumb,
.discover-story-viewer-list__thumb--fallback {
    width: 72px;
    height: 72px;
    object-fit: cover;
    border-radius: 4px;
    background: #f8fafc;
}

@keyframes discover-story-progress {
    from {
        width: 0;
    }

    to {
        width: 100%;
    }
}

@media (max-width: 1024px) {

    .discover-pdp-layout,
    .discover-story-viewer-shell {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {

    .discover-market-promo,
    .discover-browse-topbar,
    .discover-sidebar-panel,
    .discover-main-panel,
    .discover-section,
    .discover-store-header,
    .discover-store-overview__panel,
    .storefront-sidebar__card,
    .discover-checkout-shell,
    .discover-checkout-panel,
    .discover-checkout-assurance,
    .discover-checkout-recommendations,
    .discover-contact-card,
    .discover-pdp-gallery,
    .discover-pdp-info,
    .discover-pdp-details-section,
    .discover-pdp-supplier-card,
    .discover-story-viewer-frame,
    .discover-story-viewer-panel {
        padding: 0 var(--ifinsta-space-3);
    }

    .discover-story-toolbar,
    .discover-store-overview__actions,
    .discover-checkout-assurance__header,
    .discover-checkout-recommendations__header,
    .discover-story-viewer-head,
    .discover-story-viewer-foot {
        flex-direction: column;
        align-items: stretch;
    }

    .discover-story-grid {
        grid-template-columns: 1fr;
    }

    .discover-story-viewer-nav {
        justify-content: stretch;
    }
}

/* ── PDP Content Header (inserted into info panel) ── */
.discover-pdp-content-header {
    margin: var(--ifinsta-space-6) 0 var(--ifinsta-space-4);
    padding-top: var(--ifinsta-space-6);
    border-top: 1px solid var(--ifinsta-border-light);
}

.discover-pdp-name {
    font-size: var(--ifinsta-text-xl);
    font-weight: var(--ifinsta-font-bold);
    color: var(--ifinsta-neutral-900);
    line-height: 1.35;
    margin-bottom: var(--ifinsta-space-2-5);
    letter-spacing: -0.01em;
}

.discover-pdp-content-meta {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-3);
    margin-bottom: var(--ifinsta-space-4);
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-neutral-500);
}

.discover-pdp-content-meta__item {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-1);
}

.discover-pdp-content-meta__item--rating {
    color: var(--ifinsta-neutral-700);
    font-weight: var(--ifinsta-font-semibold);
}

.discover-pdp-content-supplier {
    display: flex;
    align-items: center;
    gap: var(--ifinsta-space-2);
    font-size: var(--ifinsta-text-sm);
}

.discover-pdp-content-supplier__name {
    color: var(--ifinsta-neutral-700);
    font-weight: var(--ifinsta-font-medium);
    text-decoration: none;
}

.discover-pdp-content-supplier__name:hover {
    color: var(--ifinsta-primary-600);
    text-decoration: underline;
}

.discover-pdp-content-supplier__yrs {
    font-size: var(--ifinsta-text-xs);
    color: var(--ifinsta-neutral-400);
    padding: 1px 6px;
    background: var(--ifinsta-neutral-100);
    border-radius: 4px;
}

@media (max-width: 900px) {
    .discover-pdp-gallery {
        grid-template-columns: 1fr;
        gap: 0;
        margin: 0 calc(-1 * var(--ifinsta-space-4));
        width: calc(100% + (2 * var(--ifinsta-space-4)));
        max-height: 72vh;
    }

    .discover-pdp-media-container {
        gap: 0;
        width: 100%;
        max-height: inherit;
    }

    .discover-pdp-media-display {
        width: 100%;
        display: flex;
        justify-content: center;
        background: #f8fafc;
        max-height: inherit;
    }

    .discover-pdp-main-img {
        width: 100%;
        max-height: 72vh;
        object-fit: contain;
    }

    .discover-pdp-thumbstrip {
        display: none !important;
    }

    .discover-pdp-main-wrap {
        border-radius: 0;
        aspect-ratio: 1 / 1;
        width: 100%;
        max-height: 72vh;
    }
}

/* ── PDP Zoom Modal (Premium Lightbox) ── */
.discover-pdp-zoom-modal {
    position: fixed;
    inset: 0;
    z-index: 10000;
    background: rgba(0, 0, 0, 0.85);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: zoom-out;
    opacity: 0;
    animation: discover-pdp-zoom-fade 0.35s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

@keyframes discover-pdp-zoom-fade {
    to {
        opacity: 1;
    }
}

.discover-pdp-zoom-modal__img {
    max-width: 92%;
    max-height: 92%;
    object-fit: contain;
    border-radius: var(--ifinsta-radius-lg);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);
    transform: scale(0.95);
    animation: discover-pdp-zoom-in 0.35s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

@keyframes discover-pdp-zoom-in {
    to {
        transform: scale(1);
    }
}

.discover-pdp-zoom-modal__close {
    position: absolute;
    top: 2rem;
    right: 2rem;
    width: 48px;
    height: 48px;
    background: rgba(255, 255, 255, 0.15);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
    z-index: 10001;
}

.discover-pdp-zoom-modal__close:hover {
    background: rgba(255, 255, 255, 0.25);
    transform: rotate(90deg);
}

.discover-pdp-zoom-modal__close svg {
    width: 24px;
    height: 24px;
}

@media (max-width: 640px) {
    .discover-pdp-zoom-modal__close {
        top: 1rem;
        right: 1rem;
    }
}