/**
 * Mary Storefront — Jobs-Level Design System
 * Premium, minimal, human. Every pixel intentional.
 * 2026-03-30
 */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

/* ==========================================================================
   1. DESIGN TOKENS
   ========================================================================== */

:root {
    /* Core palette */
    --sf-black: #1d1d1f;
    --sf-gray-900: #2d2d2f;
    --sf-gray-700: #424245;
    --sf-gray-500: #86868b;
    --sf-gray-300: #d2d2d7;
    --sf-gray-100: #f5f5f7;
    --sf-white: #ffffff;

    /* Dynamic — overridden per storefront via inline style */
    --couleur-primaire: #10b981;
    --couleur-secondaire: #1d1d1f;

    /* Computed from primaire */
    --sf-accent: var(--couleur-primaire);
    --sf-accent-hover: color-mix(in srgb, var(--couleur-primaire), black 15%);
    --sf-accent-light: color-mix(in srgb, var(--couleur-primaire), white 90%);
    --sf-accent-glow: color-mix(in srgb, var(--couleur-primaire), transparent 85%);

    /* Typography — Inter for premium feel */
    --sf-font: 'Inter', -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Segoe UI', Roboto, sans-serif;

    /* Spacing / Radius */
    --sf-radius-sm: 8px;
    --sf-radius-md: 12px;
    --sf-radius-lg: 16px;
    --sf-radius-xl: 20px;
    --sf-radius-pill: 50px;

    /* Shadows */
    --sf-shadow-sm: 0 1px 3px rgba(0,0,0,0.04);
    --sf-shadow-md: 0 4px 12px rgba(0,0,0,0.08);
    --sf-shadow-lg: 0 8px 32px rgba(0,0,0,0.12);
    --sf-shadow-xl: 0 16px 48px rgba(0,0,0,0.16);

    /* Transitions */
    --sf-ease: cubic-bezier(0.16, 1, 0.3, 1);
    --sf-duration: 0.3s;

    /* System */
    --sf-success: #34c759;
    --sf-danger: #ff3b30;
    --sf-warning: #ff9500;
    --sf-info: #007aff;

    /* Page background (overridable per theme) */
    --sf-page-bg: var(--sf-white);

    /* Warm palette (used by bakery/artisan themes) */
    --sf-warm-bg: #FAF6F1;
    --sf-warm-bg-deep: #F3ECE2;
    --sf-cream: #FFFBF5;
}


/* ==========================================================================
   1b. SECTORAL THEMES — Automatic via body class sf-type-*
   ========================================================================== */

/* ── Boulangerie — warm, inviting, amber tones ── */
.sf-type-boulangerie {
    --couleur-primaire: #D4A574;
    --couleur-secondaire: #1d1d1f;
    --sf-accent: #D4A574;
    --sf-accent-hover: #B8845C;
    --sf-accent-light: #E8C9A8;
    --sf-accent-glow: rgba(212,165,116,.15);
    --sf-page-bg: var(--sf-cream);
    --sf-hero-gradient: linear-gradient(165deg, #F3E8D8 0%, #E8D5BE 40%, #D4A574 100%);
}

/* ── Restaurant / Café — dark, elegant, gold accents ── */
.sf-type-restaurant {
    --couleur-primaire: #C9A96E;
    --couleur-secondaire: #f5f5f7;
    --sf-accent: #C9A96E;
    --sf-accent-hover: #B8944A;
    --sf-accent-light: rgba(201,169,110,.12);
    --sf-accent-glow: rgba(201,169,110,.15);
    --sf-page-bg: #0d0d0d;
    --sf-hero-gradient: linear-gradient(165deg, #1a1a1a 0%, #2d2520 60%, #3d2e1e 100%);
}

.sf-type-restaurant {
    color: #e8e8ed;
}

.sf-type-restaurant .sf-header {
    background: rgba(13,13,13,.85);
    border-color: rgba(255,255,255,.06);
}

.sf-type-restaurant .sf-product-card {
    background: #1a1a1a;
    border-color: rgba(255,255,255,.06);
}

.sf-type-restaurant .sf-product-info h3,
.sf-type-restaurant .sf-product-name {
    color: #f5f5f7;
}

.sf-type-restaurant .sf-footer {
    background: #0d0d0d;
    border-color: rgba(255,255,255,.06);
}

/* ── Boutique — clean, airy, rose/blush tones ── */
.sf-type-boutique {
    --couleur-primaire: #D4A0A0;
    --couleur-secondaire: #1d1d1f;
    --sf-accent: #D4A0A0;
    --sf-accent-hover: #B87878;
    --sf-accent-light: rgba(212,160,160,.1);
    --sf-accent-glow: rgba(212,160,160,.12);
    --sf-page-bg: #FDFBFB;
    --sf-hero-gradient: linear-gradient(165deg, #FDF5F5 0%, #F5E0E0 40%, #D4A0A0 100%);
}

/* ── Artisan / Service — earthy, authentic, olive ── */
.sf-type-artisan {
    --couleur-primaire: #8B9B60;
    --couleur-secondaire: #1d1d1f;
    --sf-accent: #8B9B60;
    --sf-accent-hover: #6B7840;
    --sf-accent-light: rgba(139,155,96,.1);
    --sf-accent-glow: rgba(139,155,96,.12);
    --sf-page-bg: #FAFAF5;
    --sf-hero-gradient: linear-gradient(165deg, #F0EDE5 0%, #D4C4A8 40%, #8B7355 100%);
}

/* ── Fleuriste — garden, soft green/pink ── */
.sf-type-fleuriste {
    --couleur-primaire: #9CB86B;
    --couleur-secondaire: #1d1d1f;
    --sf-accent: #9CB86B;
    --sf-accent-hover: #7A9A48;
    --sf-accent-light: rgba(156,184,107,.1);
    --sf-accent-glow: rgba(156,184,107,.12);
    --sf-page-bg: #FAFDF5;
    --sf-hero-gradient: linear-gradient(165deg, #F0F5E8 0%, #D4E8C0 40%, #9CB86B 100%);
}


/* ==========================================================================
   2. RESET & BASE
   ========================================================================== */

*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body {
    font-family: var(--sf-font);
    font-size: 16px;
    line-height: 1.6;
    color: var(--sf-black);
    background: var(--sf-page-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
}

::selection {
    background: var(--sf-accent);
    color: var(--sf-white);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    color: inherit;
    text-decoration: none;
}

button {
    font-family: inherit;
    cursor: pointer;
}

input, textarea, select {
    font-family: inherit;
    font-size: inherit;
}


/* ==========================================================================
   3. CONTAINER
   ========================================================================== */

.sf-container,
.container {
    width: 100%;
    max-width: 1100px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
}

@media (min-width: 768px) {
    .sf-container,
    .container {
        padding-left: 32px;
        padding-right: 32px;
    }
}

@media (min-width: 1024px) {
    .sf-container,
    .container {
        padding-left: 48px;
        padding-right: 48px;
    }
}


/* ==========================================================================
   4. HEADER / NAV — Frosted Glass
   ========================================================================== */

.sf-header,
body > header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(255,255,255,0.72);
    backdrop-filter: saturate(180%) blur(20px);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    border-bottom: 1px solid rgba(0,0,0,0.06);
    padding: 0;
    box-shadow: none;
}

.sf-header-inner,
.header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1.5rem;
    height: 52px;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
}

@media (min-width: 768px) {
    .sf-header-inner,
    .header-content {
        padding: 0 32px;
    }
}

.header-left {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    flex: 1;
    min-width: 0;
}

.sf-logo,
.logo {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

.sf-logo img,
.logo img {
    max-height: 36px;
    width: auto;
    border-radius: 6px;
}

.sf-logo h1,
.logo h1 {
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--sf-black);
    white-space: nowrap;
    margin: 0;
}

.sf-nav ul,
nav ul {
    list-style: none;
    display: flex;
    gap: 1.75rem;
    align-items: center;
    margin: 0;
    padding: 0;
}

.sf-nav a,
nav a {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--sf-gray-700);
    transition: color var(--sf-duration) var(--sf-ease);
    padding: 0.25rem 0;
    letter-spacing: -0.01em;
}

.sf-nav a:hover,
nav a:hover {
    color: var(--sf-accent);
}

/* Cart button — pill style */
.sf-cart-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: var(--sf-gray-100);
    border: none;
    border-radius: var(--sf-radius-pill);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--sf-black);
    transition: all var(--sf-duration) var(--sf-ease);
}

.sf-cart-btn:hover {
    background: var(--sf-gray-300);
}

.sf-cart-btn svg {
    width: 18px;
    height: 18px;
}

.sf-cart-count,
.sf-cart-badge,
.cart-badge {
    position: absolute;
    top: -4px;
    right: -6px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    background: var(--sf-accent);
    color: var(--sf-white);
    font-size: 0.65rem;
    font-weight: 700;
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

/* Header search */
.search-form {
    flex: 1;
    max-width: 400px;
}

.search-container {
    position: relative;
    display: flex;
    align-items: center;
}

body > header .search-input,
.sf-header .search-input {
    width: 100%;
    padding: 8px 40px 8px 14px;
    border: 1.5px solid var(--sf-gray-300);
    border-radius: var(--sf-radius-pill);
    font-size: 0.875rem;
    background: var(--sf-gray-100);
    color: var(--sf-black);
    transition: all var(--sf-duration) var(--sf-ease);
}

body > header .search-input:focus,
.sf-header .search-input:focus {
    outline: none;
    border-color: var(--sf-accent);
    background: var(--sf-white);
    box-shadow: 0 0 0 3px var(--sf-accent-glow);
}

.search-btn {
    position: absolute;
    right: 8px;
    padding: 4px;
    background: none;
    border: none;
    color: var(--sf-gray-500);
    transition: color var(--sf-duration);
}

.search-btn:hover {
    color: var(--sf-accent);
}

@media (max-width: 1024px) {
    .search-form { display: none; }
}

@media (max-width: 768px) {
    .header-content { gap: 0.75rem; }
    nav ul,
    .sf-nav ul { gap: 1rem; font-size: 0.85rem; }

    /* Hide desktop-only nav links on mobile */
    .sf-nav-link-desktop { display: none; }

    /* Cart toggle: make it more compact on mobile */
    .sf-cart-toggle span { display: none; }
}


/* ==========================================================================
   5. HERO SECTION
   ========================================================================== */

.sf-hero,
.hero {
    position: relative;
    min-height: 65vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    margin-bottom: 0;
}

.sf-hero-gradient,
.hero-gradient {
    position: absolute;
    inset: 0;
    background: var(--sf-hero-gradient, linear-gradient(160deg, var(--sf-accent) 0%, var(--couleur-secondaire) 100%));
    opacity: 0.92;
}

/* Decorative orbs for depth (bakery/artisan) */
.sf-type-boulangerie .sf-hero::before,
.sf-type-artisan .sf-hero::before {
    content: '';
    position: absolute;
    top: -80px; right: -80px;
    width: 300px; height: 300px;
    background: radial-gradient(circle, rgba(255,255,255,.25) 0%, transparent 70%);
    border-radius: 50%;
    z-index: 1;
    pointer-events: none;
}
.sf-type-boulangerie .sf-hero::after,
.sf-type-artisan .sf-hero::after {
    content: '';
    position: absolute;
    bottom: -40px; left: -40px;
    width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(184,132,92,.3) 0%, transparent 70%);
    border-radius: 50%;
    z-index: 1;
    pointer-events: none;
}

.sf-hero-image,
.hero-image {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.sf-hero-image::before,
.hero-image::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(160deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.25) 100%);
}

.sf-hero-content,
.hero-content {
    position: relative;
    z-index: 2;
    text-align: center;
    color: var(--sf-white);
    padding: 2rem 1.5rem;
    max-width: 720px;
}

.sf-hero-label,
.sf-hero-type {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    padding: 6px 16px;
    background: rgba(255,255,255,0.15);
    backdrop-filter: blur(10px);
    border-radius: var(--sf-radius-pill);
    margin-bottom: 1.25rem;
    color: rgba(255,255,255,0.7);
}

.sf-hero-title,
.hero-title {
    font-size: clamp(2.25rem, 6vw, 4rem);
    font-weight: 900;
    line-height: 1.05;
    letter-spacing: -0.04em;
    margin-bottom: 1rem;
    text-shadow: 0 2px 20px rgba(0,0,0,0.08);
}

.sf-hero-tagline,
.hero-slogan {
    font-size: clamp(1rem, 2.2vw, 1.15rem);
    font-weight: 400;
    font-style: italic;
    line-height: 1.5;
    margin-bottom: 2rem;
    color: rgba(255,255,255,0.85);
}

.sf-hero-actions,
.hero-actions {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}

.sf-hero-hours {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 2rem;
    padding: 8px 18px;
    background: rgba(255,255,255,0.12);
    backdrop-filter: blur(10px);
    border-radius: var(--sf-radius-pill);
    font-size: 0.85rem;
    color: rgba(255,255,255,0.88);
}

.sf-hero-hours .sf-dot-open {
    width: 8px;
    height: 8px;
    background: var(--sf-success);
    border-radius: 50%;
    display: inline-block;
    animation: sf-pulse 2s ease-in-out infinite;
}


/* ==========================================================================
   6. CATEGORY PILLS
   ========================================================================== */

.sf-categories {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding: 24px 0;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.sf-categories::-webkit-scrollbar {
    display: none;
}

.sf-category-pill {
    flex-shrink: 0;
    padding: 8px 20px;
    border: 1.5px solid var(--sf-gray-300);
    border-radius: var(--sf-radius-pill);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--sf-gray-700);
    background: var(--sf-white);
    cursor: pointer;
    transition: all var(--sf-duration) var(--sf-ease);
    white-space: nowrap;
    text-decoration: none;
}

.sf-category-pill:hover {
    border-color: var(--sf-accent);
    color: var(--sf-accent);
}

.sf-category-pill.active,
.sf-category-pill--active {
    background: var(--sf-accent);
    border-color: var(--sf-accent);
    color: var(--sf-white);
}


/* ==========================================================================
   7. PRODUCT GRID
   ========================================================================== */

.sf-product-grid,
.products-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 20px;
}

@media (max-width: 480px) {
    .sf-product-grid,
    .products-grid {
        grid-template-columns: 1fr 1fr;
        gap: 12px;
    }
}


/* ==========================================================================
   8. PRODUCT CARDS
   ========================================================================== */

.sf-product-card,
.product-card {
    background: var(--sf-white);
    border-radius: var(--sf-radius-lg);
    border: 1px solid rgba(0,0,0,0.04);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    height: 100%;
    cursor: pointer;
    transition: all var(--sf-duration) var(--sf-ease);
}

.sf-product-card:hover,
.product-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--sf-shadow-lg);
}

.sf-product-card-image,
.product-image-wrapper {
    position: relative;
    width: 100%;
    aspect-ratio: 1;
    background: var(--sf-gray-100);
    overflow: hidden;
}

/* Legacy padding-based ratio fallback */
.product-image-wrapper {
    padding-top: 0;
    aspect-ratio: 1;
}

.sf-product-card-image img,
.product-image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s var(--sf-ease);
}

.sf-product-card:hover .sf-product-card-image img,
.product-card:hover .product-image {
    transform: scale(1.06);
}

/* Add button overlay */
.sf-product-add-overlay {
    position: absolute;
    bottom: 12px;
    right: 12px;
    width: 40px;
    height: 40px;
    background: var(--sf-white);
    border: none;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--sf-shadow-md);
    opacity: 0;
    transform: translateY(8px);
    transition: all var(--sf-duration) var(--sf-ease);
    color: var(--sf-accent);
    font-size: 1.25rem;
}

.sf-product-card:hover .sf-product-add-overlay,
.product-card:hover .sf-product-add-overlay {
    opacity: 1;
    transform: translateY(0);
}

.sf-product-add-overlay:hover {
    background: var(--sf-accent);
    color: var(--sf-white);
}

.product-image-placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--sf-gray-300);
    gap: 8px;
}

.product-image-placeholder svg {
    width: 48px;
    height: 48px;
}

.product-image-placeholder span {
    font-size: 0.8rem;
    font-weight: 500;
}

.sf-product-card-info,
.product-info {
    padding: 16px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.sf-product-card-name,
.product-name {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--sf-black);
    line-height: 1.35;
    margin: 0 0 4px 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sf-product-card-desc,
.product-description {
    font-size: 0.82rem;
    line-height: 1.5;
    color: var(--sf-gray-500);
    margin: 0 0 12px 0;
    flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sf-product-card-price,
.product-price {
    display: flex;
    align-items: baseline;
    gap: 8px;
    margin: auto 0 0 0;
}

.sf-price-current,
.price-current {
    font-size: 1rem;
    font-weight: 800;
    color: var(--sf-accent-hover, var(--sf-accent));
}

.sf-price-original,
.price-original {
    font-size: 0.85rem;
    text-decoration: line-through;
    color: var(--sf-gray-500);
}


/* ==========================================================================
   9. SECTION HEADERS
   ========================================================================== */

.sf-section {
    padding: 56px 0;
}

.sf-section--gray,
.section-gray {
    background: var(--sf-gray-100);
}

.sf-section-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 28px;
    gap: 16px;
}

.sf-section-title,
.section-title {
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--sf-black);
    position: relative;
    padding-bottom: 0;
    margin-bottom: 0;
}

.section-title::after {
    content: none;
}

.sf-section-link {
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--sf-accent);
    transition: opacity var(--sf-duration);
    flex-shrink: 0;
}

.sf-section-link:hover {
    opacity: 0.7;
}

.section-title-center,
.sf-section-title--center {
    text-align: center;
}

.section-title-center::after {
    content: none;
}

.section {
    padding: 56px 0;
}


/* ==========================================================================
   10. STORY / NOTRE HISTOIRE
   ========================================================================== */

.sf-story {
    padding: 80px 0;
    background: var(--sf-warm-bg, linear-gradient(180deg, var(--sf-gray-100) 0%, #faf8f5 100%));
    text-align: center;
}

.sf-story-inner {
    max-width: 640px;
    margin: 0 auto;
}

.sf-story-label {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--sf-accent-hover, var(--sf-accent));
    margin-bottom: 1.5rem;
}

.sf-story-quote {
    font-size: clamp(1.25rem, 2.8vw, 1.375rem);
    font-style: italic;
    font-weight: 400;
    line-height: 1.7;
    color: var(--sf-gray-700);
    margin: 0 0 1.5rem 0;
    position: relative;
    quotes: "\201C" "\201D";
}

.sf-story-quote::before {
    content: open-quote;
    font-size: 3rem;
    color: var(--sf-accent);
    position: absolute;
    top: -12px;
    left: -8px;
    line-height: 1;
    opacity: 0.4;
}

.sf-story-author {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

.sf-story-avatar {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    object-fit: cover;
    background: linear-gradient(135deg, var(--sf-accent), var(--sf-accent-hover, var(--sf-accent)));
    color: white;
    font-size: 1.5rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1rem;
}

.sf-story-author-name {
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--sf-black);
}

.sf-story-author-title {
    font-size: 0.82rem;
    color: var(--sf-gray-500);
}


/* ==========================================================================
   11. CONTACT SECTION
   ========================================================================== */

.sf-contact {
    padding: 64px 0;
}

.sf-contact-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
}

@media (max-width: 768px) {
    .sf-contact-grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }
}

.sf-contact-row {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 14px 0;
}

.sf-contact-row svg {
    width: 20px;
    height: 20px;
    color: var(--sf-accent);
    flex-shrink: 0;
    margin-top: 2px;
}

.sf-contact-row-label {
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--sf-gray-500);
    margin-bottom: 2px;
}

.sf-contact-row-value {
    font-size: 0.95rem;
    color: var(--sf-black);
    line-height: 1.5;
}

.sf-hours-grid {
    display: grid;
    gap: 8px;
}

.sf-hours-row {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    font-size: 0.9rem;
    border-bottom: 1px solid var(--sf-gray-100);
}

.sf-hours-day {
    font-weight: 500;
    color: var(--sf-black);
}

.sf-hours-time {
    color: var(--sf-gray-500);
}

.sf-map-placeholder {
    width: 100%;
    height: 240px;
    background: var(--sf-gray-100);
    border-radius: var(--sf-radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--sf-gray-500);
    font-size: 0.9rem;
}


/* ==========================================================================
   12. FOOTER
   ========================================================================== */

.sf-footer,
footer {
    background: var(--sf-black);
    color: rgba(255,255,255,0.5);
    padding: 2rem 0;
    margin-top: 0;
    text-align: center;
}

.sf-footer-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
}

@media (max-width: 640px) {
    .sf-footer-inner {
        flex-direction: column;
        gap: 12px;
    }
}

.sf-footer-brand {
    font-size: 0.82rem;
}

.sf-footer-brand a {
    color: rgba(255,255,255,0.7);
    transition: color var(--sf-duration);
}

.sf-footer-brand a:hover {
    color: var(--sf-white);
}

.sf-footer-social {
    display: flex;
    gap: 16px;
}

.sf-footer-social a {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(255,255,255,0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,0.5);
    transition: all var(--sf-duration);
}

.sf-footer-social a:hover {
    background: var(--sf-accent);
    color: var(--sf-white);
}

.sf-footer-social svg {
    width: 16px;
    height: 16px;
}

/* Warm footer for light themes */
.sf-type-boulangerie .sf-footer {
    background: var(--sf-cream, #FFFBF5);
    color: var(--sf-gray-700);
    border-top: 1px solid rgba(0,0,0,0.04);
}
.sf-type-boulangerie .sf-footer-social a {
    background: var(--sf-gray-100);
    color: var(--sf-gray-500);
}
.sf-type-boulangerie .sf-footer-social a:hover {
    background: var(--sf-accent);
    color: white;
}
.sf-type-boutique .sf-footer,
.sf-type-artisan .sf-footer,
.sf-type-fleuriste .sf-footer {
    background: var(--sf-page-bg, #fff);
    color: var(--sf-gray-700);
    border-top: 1px solid rgba(0,0,0,0.04);
}
.sf-type-boutique .sf-footer-social a,
.sf-type-artisan .sf-footer-social a,
.sf-type-fleuriste .sf-footer-social a {
    background: var(--sf-gray-100);
    color: var(--sf-gray-500);
}
.sf-type-boutique .sf-footer-social a:hover,
.sf-type-artisan .sf-footer-social a:hover,
.sf-type-fleuriste .sf-footer-social a:hover {
    background: var(--sf-accent);
    color: white;
}

footer p {
    margin: 4px 0;
    font-size: 0.85rem;
}

main {
    min-height: calc(100vh - 200px);
}


/* ==========================================================================
   13. PRODUCT DETAIL PAGE
   ========================================================================== */

.sf-detail-hero {
    width: 100%;
    max-height: 480px;
    overflow: hidden;
    background: var(--sf-gray-100);
    border-radius: 0 0 var(--sf-radius-xl) var(--sf-radius-xl);
}

.sf-detail-hero img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sf-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.82rem;
    color: var(--sf-gray-500);
    padding: 16px 0;
}

.sf-breadcrumb a {
    color: var(--sf-gray-500);
    transition: color var(--sf-duration);
}

.sf-breadcrumb a:hover {
    color: var(--sf-accent);
}

.sf-breadcrumb-sep {
    font-size: 0.7rem;
    opacity: 0.5;
}

.sf-detail-grid,
.product-detail-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    margin-bottom: 64px;
}

@media (max-width: 768px) {
    .sf-detail-grid,
    .product-detail-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }
}

.sf-detail-image {
    border-radius: var(--sf-radius-xl);
    overflow: hidden;
    background: var(--sf-gray-100);
    aspect-ratio: 1;
}

.sf-detail-image img,
.product-detail-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: var(--sf-radius-xl);
}

.sf-detail-info {
    display: flex;
    flex-direction: column;
}

.product-detail-info h1,
.sf-detail-name {
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--sf-black);
    margin-bottom: 12px;
    line-height: 1.15;
}

.sf-detail-price,
.product-detail-price {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--sf-accent);
    margin: 8px 0 20px 0;
}

.sf-detail-desc,
.product-detail-description {
    font-size: 1rem;
    line-height: 1.8;
    color: var(--sf-gray-700);
    margin: 0 0 24px 0;
}

/* Stock status */
.product-stock-status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    border-radius: var(--sf-radius-pill);
    font-size: 0.82rem;
    font-weight: 600;
    margin: 8px 0;
}

.stock-in-stock {
    background: rgba(52,199,89,0.1);
    color: var(--sf-success);
}

.stock-low {
    background: rgba(255,149,0,0.1);
    color: var(--sf-warning);
}

.stock-out {
    background: rgba(255,59,48,0.1);
    color: var(--sf-danger);
}

/* Quantity stepper */
.sf-qty-stepper {
    display: inline-flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 1.5rem;
}

.sf-qty-stepper button {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1.5px solid var(--sf-gray-300);
    border-radius: 50%;
    background: var(--sf-white);
    font-size: 1.1rem;
    color: var(--sf-gray-700);
    transition: all var(--sf-duration);
}

.sf-qty-stepper button:hover {
    border-color: var(--sf-accent);
    color: var(--sf-accent-hover, var(--sf-accent));
}

.sf-qty-stepper input,
.quantity-input {
    width: 32px;
    text-align: center;
    border: none;
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--sf-black);
    background: transparent;
    -moz-appearance: textfield;
}

.sf-qty-stepper input::-webkit-inner-spin-button {
    -webkit-appearance: none;
}

.add-to-cart-form {
    display: flex;
    gap: 12px;
    align-items: center;
    margin-top: 24px;
}

/* Expandable accordion sections */
.sf-accordion {
    border-top: 1px solid var(--sf-gray-100);
    margin-top: 24px;
}

.sf-accordion-item {
    border-bottom: 1px solid var(--sf-gray-100);
}

.sf-accordion-trigger {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 0;
    background: none;
    border: none;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--sf-black);
    cursor: pointer;
}

.sf-accordion-trigger svg {
    width: 16px;
    height: 16px;
    color: var(--sf-gray-500);
    transition: transform var(--sf-duration) var(--sf-ease);
}

.sf-accordion-trigger[aria-expanded="true"] svg {
    transform: rotate(180deg);
}

.sf-accordion-content {
    padding: 0 0 16px 0;
    font-size: 0.9rem;
    line-height: 1.7;
    color: var(--sf-gray-700);
}


/* ==========================================================================
   14. SIMILAR PRODUCTS
   ========================================================================== */

.sf-similar-scroll {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    padding: 8px 0 16px 0;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.sf-similar-scroll::-webkit-scrollbar {
    display: none;
}

.sf-similar-card {
    flex-shrink: 0;
    width: 180px;
    background: var(--sf-white);
    border-radius: var(--sf-radius-lg);
    border: 1px solid var(--sf-gray-100);
    overflow: hidden;
    transition: transform var(--sf-duration) var(--sf-ease),
                box-shadow var(--sf-duration) var(--sf-ease);
}

.sf-similar-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--sf-shadow-md);
}

.sf-similar-card img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
}

.sf-similar-card-info {
    padding: 10px 12px;
}

.sf-similar-card-name {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--sf-black);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sf-similar-card-price {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--sf-accent);
    margin-top: 2px;
}


/* ==========================================================================
   15. CART SLIDE-IN PANEL
   ========================================================================== */

.sf-cart-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.4);
    z-index: 999;
    opacity: 0;
    visibility: hidden;
    transition: all var(--sf-duration) var(--sf-ease);
}

.sf-cart-overlay.active {
    opacity: 1;
    visibility: visible;
}

.sf-cart-panel {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    max-width: 420px;
    background: rgba(255,255,255,0.92);
    backdrop-filter: saturate(180%) blur(20px);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    z-index: 1000;
    transform: translateX(100%);
    transition: transform var(--sf-duration) var(--sf-ease);
    display: flex;
    flex-direction: column;
    box-shadow: -8px 0 32px rgba(0,0,0,0.12);
}

.sf-cart-panel.active {
    transform: translateX(0);
}

.sf-cart-panel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px;
    border-bottom: 1px solid var(--sf-gray-100);
}

.sf-cart-panel-header h2 {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--sf-black);
    margin: 0;
}

.sf-cart-panel-close {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: var(--sf-gray-100);
    border-radius: 50%;
    color: var(--sf-gray-700);
    font-size: 1rem;
    transition: background var(--sf-duration);
}

.sf-cart-panel-close:hover {
    background: var(--sf-gray-300);
}

.sf-cart-panel-items {
    flex: 1;
    overflow-y: auto;
    padding: 16px 24px;
}

.sf-cart-panel-total {
    padding: 20px 24px;
    border-top: 1px solid var(--sf-gray-100);
}

.sf-cart-panel-total-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.sf-cart-panel-total-label {
    font-size: 0.95rem;
    color: var(--sf-gray-700);
}

.sf-cart-panel-total-amount {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--sf-black);
}

/* Cart panel form fields */
.sf-cart-panel-form .sf-input {
    margin-bottom: 10px;
}

/* Time slot pills in cart */
.sf-timeslot-pills {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin: 12px 0;
}

.sf-timeslot-pill {
    padding: 8px 16px;
    border: 1.5px solid var(--sf-gray-300);
    border-radius: var(--sf-radius-pill);
    font-size: 0.82rem;
    font-weight: 500;
    background: var(--sf-white);
    color: var(--sf-gray-700);
    cursor: pointer;
    transition: all var(--sf-duration) var(--sf-ease);
}

.sf-timeslot-pill:hover {
    border-color: var(--sf-accent);
    color: var(--sf-accent);
}

.sf-timeslot-pill.active {
    background: var(--sf-accent);
    border-color: var(--sf-accent);
    color: var(--sf-white);
}

/* Apple Pay style button */
.sf-btn-apple-pay {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 14px 24px;
    background: var(--sf-black);
    color: var(--sf-white);
    border: none;
    border-radius: var(--sf-radius-md);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: opacity var(--sf-duration);
    margin-bottom: 10px;
}

.sf-btn-apple-pay:hover {
    opacity: 0.85;
}

.sf-btn-checkout-fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 14px 24px;
    background: var(--sf-success);
    color: var(--sf-white);
    border: none;
    border-radius: var(--sf-radius-md);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--sf-duration) var(--sf-ease);
}

.sf-btn-checkout-fallback:hover {
    filter: brightness(1.05);
    transform: translateY(-1px);
}


/* ==========================================================================
   16. CART ITEMS
   ========================================================================== */

.sf-cart-item,
.cart-item {
    display: flex;
    gap: 14px;
    padding: 14px 0;
    border-bottom: 1px solid var(--sf-gray-100);
}

.sf-cart-item:last-child,
.cart-item:last-child {
    border-bottom: none;
}

.sf-cart-item-thumb,
.cart-item-image {
    width: 60px;
    height: 60px;
    border-radius: var(--sf-radius-sm);
    object-fit: cover;
    flex-shrink: 0;
    background: var(--sf-gray-100);
}

.sf-cart-item-info,
.cart-item-info {
    flex: 1;
    min-width: 0;
}

.sf-cart-item-name,
.cart-item-name {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--sf-black);
    margin-bottom: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sf-cart-item-qty {
    font-size: 0.8rem;
    color: var(--sf-gray-500);
}

.sf-cart-item-price,
.cart-item-total {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--sf-accent);
    flex-shrink: 0;
    align-self: center;
}

.cart-item-price {
    color: var(--sf-gray-500);
    font-size: 0.85rem;
    margin-bottom: 4px;
}

/* Cart summary (page version) */
.cart-summary {
    background: var(--sf-gray-100);
    padding: 24px;
    border-radius: var(--sf-radius-lg);
    position: sticky;
    top: 80px;
}

.cart-summary-line {
    display: flex;
    justify-content: space-between;
    margin-bottom: 12px;
    font-size: 0.95rem;
    color: var(--sf-gray-700);
}

.cart-summary-total {
    display: flex;
    justify-content: space-between;
    padding-top: 16px;
    border-top: 1.5px solid var(--sf-gray-300);
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--sf-black);
    margin-top: 12px;
}


/* ==========================================================================
   17. CHECKOUT PAGE
   ========================================================================== */

.sf-checkout-grid,
.checkout-grid {
    display: grid;
    grid-template-columns: 3fr 2fr;
    gap: 48px;
}

@media (max-width: 968px) {
    .sf-checkout-grid,
    .checkout-grid {
        grid-template-columns: 1fr;
    }
}

/* Delivery mode cards */
.sf-delivery-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-bottom: 24px;
}

.sf-delivery-card {
    position: relative;
    padding: 16px;
    border: 1.5px solid var(--sf-gray-300);
    border-radius: var(--sf-radius-md);
    cursor: pointer;
    transition: all var(--sf-duration) var(--sf-ease);
    text-align: center;
}

.sf-delivery-card:hover {
    border-color: var(--sf-accent);
}

.sf-delivery-card.active,
.sf-delivery-card--selected {
    border-color: var(--sf-accent);
    background: var(--sf-accent-light);
}

.sf-delivery-card input[type="radio"] {
    position: absolute;
    opacity: 0;
}

.sf-delivery-card-icon {
    font-size: 1.5rem;
    margin-bottom: 4px;
}

.sf-delivery-card-label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--sf-black);
}

.sf-delivery-card-desc {
    font-size: 0.75rem;
    color: var(--sf-gray-500);
    margin-top: 2px;
}

/* Payment mode cards */
.sf-payment-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 10px;
    margin-bottom: 24px;
}

.sf-payment-card {
    padding: 14px;
    border: 1.5px solid var(--sf-gray-300);
    border-radius: var(--sf-radius-md);
    text-align: center;
    cursor: pointer;
    transition: all var(--sf-duration) var(--sf-ease);
    font-size: 0.85rem;
    font-weight: 500;
}

.sf-payment-card:hover {
    border-color: var(--sf-accent);
}

.sf-payment-card.active {
    border-color: var(--sf-accent);
    background: var(--sf-accent-light);
    color: var(--sf-accent);
}


/* ==========================================================================
   18. ORDER SUCCESS
   ========================================================================== */

.sf-order-success {
    text-align: center;
    padding: 80px 20px;
    max-width: 560px;
    margin: 0 auto;
}

.sf-order-checkmark {
    width: 80px;
    height: 80px;
    margin: 0 auto 24px;
}

.sf-order-checkmark circle {
    fill: none;
    stroke: var(--sf-success);
    stroke-width: 2;
    stroke-dasharray: 166;
    stroke-dashoffset: 166;
    animation: sf-circle 0.6s var(--sf-ease) forwards;
}

.sf-order-checkmark path {
    fill: none;
    stroke: var(--sf-success);
    stroke-width: 3;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: 48;
    stroke-dashoffset: 48;
    animation: sf-check 0.3s var(--sf-ease) 0.4s forwards;
}

@keyframes sf-circle {
    to { stroke-dashoffset: 0; }
}

@keyframes sf-check {
    to { stroke-dashoffset: 0; }
}

.sf-order-success h1 {
    font-size: 1.75rem;
    font-weight: 700;
    margin-bottom: 8px;
    color: var(--sf-black);
}

.sf-order-number {
    font-size: 1rem;
    color: var(--sf-gray-500);
    margin-bottom: 32px;
}

.sf-order-details-card {
    background: var(--sf-gray-100);
    border-radius: var(--sf-radius-lg);
    padding: 24px;
    text-align: left;
    margin-bottom: 24px;
}

.sf-order-timeline {
    display: flex;
    flex-direction: column;
    gap: 16px;
    text-align: left;
}

.sf-order-timeline-item {
    display: flex;
    gap: 12px;
    align-items: flex-start;
}

.sf-order-timeline-dot {
    width: 10px;
    height: 10px;
    background: var(--sf-gray-300);
    border-radius: 50%;
    margin-top: 6px;
    flex-shrink: 0;
}

.sf-order-timeline-dot--done {
    background: var(--sf-success);
}

.sf-order-timeline-text {
    font-size: 0.9rem;
    color: var(--sf-gray-700);
}


/* ==========================================================================
   19. ORDER TRACKING
   ========================================================================== */

.sf-tracking {
    max-width: 560px;
    margin: 0 auto;
    padding: 48px 20px;
}

.sf-tracking-search {
    display: flex;
    gap: 10px;
    margin-bottom: 40px;
}

.sf-tracking-search input {
    flex: 1;
    padding: 12px 20px;
    border: 1.5px solid var(--sf-gray-300);
    border-radius: var(--sf-radius-pill);
    font-size: 0.95rem;
}

.sf-tracking-search input:focus {
    outline: none;
    border-color: var(--sf-accent);
    box-shadow: 0 0 0 3px var(--sf-accent-glow);
}

.sf-tracking-timeline {
    position: relative;
    padding-left: 32px;
}

.sf-tracking-timeline::before {
    content: '';
    position: absolute;
    left: 11px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--sf-gray-300);
}

.sf-tracking-step {
    position: relative;
    padding: 0 0 32px 0;
}

.sf-tracking-step:last-child {
    padding-bottom: 0;
}

.sf-tracking-dot {
    position: absolute;
    left: -32px;
    top: 2px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    border: 2px solid var(--sf-gray-300);
    background: var(--sf-white);
    display: flex;
    align-items: center;
    justify-content: center;
}

.sf-tracking-step--done .sf-tracking-dot {
    background: var(--sf-success);
    border-color: var(--sf-success);
    color: var(--sf-white);
}

.sf-tracking-step--current .sf-tracking-dot {
    border-color: var(--sf-accent);
    background: var(--sf-accent);
    animation: sf-pulse-ring 2s ease-in-out infinite;
}

.sf-tracking-step-title {
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--sf-black);
}

.sf-tracking-step--pending .sf-tracking-step-title {
    color: var(--sf-gray-500);
}

.sf-tracking-step-desc {
    font-size: 0.82rem;
    color: var(--sf-gray-500);
    margin-top: 2px;
}


/* ==========================================================================
   20. DEVIS / QUOTE PAGE
   ========================================================================== */

.sf-devis-chat {
    max-width: 640px;
    margin: 0 auto;
    padding: 24px 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.sf-devis-bubble {
    max-width: 80%;
    padding: 14px 18px;
    border-radius: var(--sf-radius-lg);
    font-size: 0.9rem;
    line-height: 1.6;
}

.sf-devis-bubble--merchant {
    align-self: flex-start;
    background: var(--sf-gray-100);
    color: var(--sf-black);
    border-bottom-left-radius: 4px;
}

.sf-devis-bubble--user {
    align-self: flex-end;
    background: var(--sf-accent);
    color: var(--sf-white);
    border-bottom-right-radius: 4px;
}

.sf-devis-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    margin-bottom: 6px;
}

.sf-devis-product-card {
    background: var(--sf-white);
    border: 1px solid var(--sf-gray-100);
    border-radius: var(--sf-radius-md);
    padding: 12px;
    display: flex;
    gap: 12px;
    align-items: center;
    margin-top: 8px;
}

.sf-devis-product-card img {
    width: 48px;
    height: 48px;
    border-radius: var(--sf-radius-sm);
    object-fit: cover;
}


/* ==========================================================================
   21. MANAGEMENT DASHBOARD
   ========================================================================== */

.sf-mgmt-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
    margin-bottom: 32px;
}

.sf-mgmt-metric-card {
    background: var(--sf-white);
    border: 1px solid var(--sf-gray-100);
    border-radius: var(--sf-radius-lg);
    padding: 20px;
}

.sf-mgmt-metric-value {
    font-size: 2rem;
    font-weight: 700;
    color: var(--sf-black);
    line-height: 1.2;
}

.sf-mgmt-metric-label {
    font-size: 0.82rem;
    color: var(--sf-gray-500);
    margin-top: 4px;
}

.sf-mgmt-metric-trend {
    font-size: 0.78rem;
    font-weight: 600;
    margin-top: 6px;
}

.sf-mgmt-metric-trend--up {
    color: var(--sf-success);
}

.sf-mgmt-metric-trend--down {
    color: var(--sf-danger);
}

.sf-mgmt-quick-actions {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 12px;
    margin-bottom: 32px;
}

.sf-mgmt-action-tile {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 20px 16px;
    background: var(--sf-white);
    border: 1px solid var(--sf-gray-100);
    border-radius: var(--sf-radius-lg);
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--sf-gray-700);
    cursor: pointer;
    transition: all var(--sf-duration) var(--sf-ease);
    gap: 8px;
    text-align: center;
    text-decoration: none;
}

.sf-mgmt-action-tile:hover {
    border-color: var(--sf-accent);
    color: var(--sf-accent);
    transform: translateY(-2px);
    box-shadow: var(--sf-shadow-md);
}

.sf-mgmt-action-tile svg {
    width: 24px;
    height: 24px;
}

.sf-mgmt-orders-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.sf-mgmt-order-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    background: var(--sf-white);
    border: 1px solid var(--sf-gray-100);
    border-radius: var(--sf-radius-md);
    font-size: 0.9rem;
}

.sf-mgmt-template-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
}

.sf-mgmt-template-card {
    border: 2px solid var(--sf-gray-100);
    border-radius: var(--sf-radius-lg);
    overflow: hidden;
    cursor: pointer;
    transition: border-color var(--sf-duration) var(--sf-ease);
}

.sf-mgmt-template-card:hover,
.sf-mgmt-template-card.active {
    border-color: var(--sf-accent);
}

.sf-mgmt-template-preview {
    aspect-ratio: 4/3;
    background: var(--sf-gray-100);
    overflow: hidden;
}

.sf-mgmt-template-label {
    padding: 10px 12px;
    font-size: 0.85rem;
    font-weight: 600;
    text-align: center;
}

.sf-mgmt-preview-frame {
    width: 100%;
    border: 1px solid var(--sf-gray-100);
    border-radius: var(--sf-radius-lg);
    overflow: hidden;
    aspect-ratio: 16/10;
}


/* ==========================================================================
   22. TOAST NOTIFICATIONS
   ========================================================================== */

.sf-toast-container {
    position: fixed;
    bottom: 1.5rem;
    right: 1.5rem;
    z-index: 10000;
    display: flex;
    flex-direction: column-reverse;
    gap: 8px;
    max-width: 380px;
    width: calc(100% - 3rem);
}

.sf-toast {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 18px;
    border-radius: var(--sf-radius-md);
    font-size: 0.875rem;
    font-weight: 500;
    box-shadow: var(--sf-shadow-lg);
    animation: sf-toast-in var(--sf-duration) var(--sf-ease);
    word-break: break-word;
    background: var(--sf-white);
    color: var(--sf-black);
    border-left: 4px solid var(--sf-gray-300);
}

.sf-toast-success {
    border-left-color: var(--sf-success);
    background: #f0fdf4;
    color: #166534;
}

.sf-toast-error {
    border-left-color: var(--sf-danger);
    background: #fef2f2;
    color: #991b1b;
}

.sf-toast-info {
    border-left-color: var(--sf-info);
    background: #eff6ff;
    color: #1e40af;
}

.sf-toast-warning {
    border-left-color: var(--sf-warning);
    background: #fffbeb;
    color: #92400e;
}

.sf-toast-close {
    background: none;
    border: none;
    font-size: 1.1rem;
    cursor: pointer;
    color: inherit;
    opacity: 0.5;
    flex-shrink: 0;
    padding: 0 2px;
    line-height: 1;
    transition: opacity var(--sf-duration);
}

.sf-toast-close:hover {
    opacity: 1;
}

.sf-toast-hide {
    animation: sf-toast-out var(--sf-duration) var(--sf-ease) forwards;
}

@keyframes sf-toast-in {
    from { transform: translateX(100%); opacity: 0; }
    to   { transform: translateX(0);    opacity: 1; }
}

@keyframes sf-toast-out {
    from { transform: translateX(0);    opacity: 1; }
    to   { transform: translateX(100%); opacity: 0; }
}

@media (max-width: 480px) {
    .sf-toast-container {
        bottom: 1rem;
        left: 1rem;
        right: 1rem;
        max-width: none;
    }
}


/* ==========================================================================
   23. SEARCH SUGGESTIONS DROPDOWN
   ========================================================================== */

.sf-search-suggestions,
.search-suggestions {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    background: var(--sf-white);
    border: 1px solid var(--sf-gray-100);
    border-radius: var(--sf-radius-md);
    box-shadow: var(--sf-shadow-lg);
    max-height: 360px;
    overflow-y: auto;
    z-index: 1000;
}

.sf-search-suggestion-item,
.search-suggestion-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    border-bottom: 1px solid var(--sf-gray-100);
    cursor: pointer;
    text-decoration: none;
    color: inherit;
    transition: background var(--sf-duration);
}

.sf-search-suggestion-item:hover,
.search-suggestion-item:hover,
.sf-search-suggestion-item:focus,
.search-suggestion-item:focus {
    background: var(--sf-gray-100);
    outline: none;
}

.sf-search-suggestion-item:last-child,
.search-suggestion-item:last-child {
    border-bottom: none;
}

.suggestion-image {
    width: 44px;
    height: 44px;
    object-fit: cover;
    border-radius: var(--sf-radius-sm);
    flex-shrink: 0;
}

.suggestion-info {
    flex: 1;
    min-width: 0;
}

.suggestion-name {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--sf-black);
    margin-bottom: 1px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.suggestion-category {
    font-size: 0.78rem;
    color: var(--sf-gray-500);
}

.suggestion-price {
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--sf-accent);
    flex-shrink: 0;
}

@media (max-width: 768px) {
    .search-suggestions { max-height: 280px; }
    .suggestion-image { width: 36px; height: 36px; }
}


/* ==========================================================================
   24. BADGES
   ========================================================================== */

.sf-badge,
.badge {
    position: absolute;
    top: 12px;
    right: 12px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: var(--sf-radius-pill);
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    z-index: 1;
}

.sf-badge--new,
.badge-new {
    background: var(--sf-success);
    color: var(--sf-white);
}

.sf-badge--promo,
.badge-promo {
    background: linear-gradient(135deg, #ff6b6b, #ee5a24);
    color: var(--sf-white);
}

.sf-badge--warning,
.badge-warning {
    background: var(--sf-warning);
    color: var(--sf-black);
}

.sf-badge--sold-out,
.badge-sold-out {
    background: var(--sf-gray-500);
    color: var(--sf-white);
}

.sf-badge--stock {
    position: static;
    font-size: 0.72rem;
}

/* Product badges container */
.sf-product-badges {
    position: absolute;
    top: 10px;
    left: 10px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    z-index: 2;
}

.sf-badge-promo {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 700;
    background: linear-gradient(135deg, #ff6b6b, #ee5a24);
    color: white;
}

.sf-badge-popular {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 6px;
    font-size: 0.7rem;
    font-weight: 600;
    background: rgba(0,0,0,0.65);
    color: white;
    backdrop-filter: blur(4px);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

/* Stock indicator */
.sf-product-stock {
    position: absolute;
    bottom: 10px;
    left: 10px;
    padding: 3px 8px;
    border-radius: 6px;
    font-size: 0.7rem;
    font-weight: 600;
    backdrop-filter: blur(4px);
    z-index: 2;
}
.sf-stock-ok { background: rgba(22, 163, 74, 0.12); color: #16a34a; }
.sf-stock-low { background: rgba(245, 158, 11, 0.12); color: #d97706; }
.sf-stock-out { background: rgba(239, 68, 68, 0.12); color: #dc2626; }

/* Devis button on product card */
.sf-product-devis-btn {
    position: absolute;
    bottom: 10px;
    right: 10px;
    padding: 6px 14px;
    border-radius: 8px;
    font-size: 0.75rem;
    font-weight: 600;
    background: var(--sf-accent);
    color: white;
    text-decoration: none;
    opacity: 0;
    transform: translateY(4px);
    transition: all var(--sf-duration) var(--sf-ease);
    z-index: 2;
}
.sf-product-card:hover .sf-product-devis-btn {
    opacity: 1;
    transform: translateY(0);
}


/* ==========================================================================
   25. BUTTONS
   ========================================================================== */

.sf-btn,
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 24px;
    font-size: 0.9rem;
    font-weight: 600;
    text-decoration: none;
    border: none;
    border-radius: var(--sf-radius-pill);
    cursor: pointer;
    transition: all var(--sf-duration) var(--sf-ease);
    text-align: center;
    white-space: nowrap;
    letter-spacing: -0.01em;
}

.sf-btn-primary,
.btn-primary {
    background: var(--sf-accent);
    color: var(--sf-white);
}

.sf-btn-primary:hover,
.btn-primary:hover {
    background: var(--sf-accent-hover);
    transform: scale(1.02);
    box-shadow: var(--sf-shadow-md);
}

.sf-btn-outline,
.btn-outline {
    background: transparent;
    color: var(--sf-accent);
    border: 1.5px solid var(--sf-accent);
}

.sf-btn-outline:hover,
.btn-outline:hover {
    background: var(--sf-accent);
    color: var(--sf-white);
}

.sf-btn-outline-light {
    background: rgba(255,255,255,0.2);
    color: white;
    border: 1.5px solid rgba(255,255,255,0.4);
    backdrop-filter: blur(8px);
}

.sf-btn-outline-light:hover {
    background: rgba(255,255,255,0.3);
}

.sf-btn-ghost {
    background: transparent;
    color: var(--sf-gray-700);
    border: none;
}

.sf-btn-ghost:hover {
    background: var(--sf-gray-100);
}

.btn-secondary {
    background: var(--sf-gray-100);
    color: var(--sf-gray-700);
}

.btn-secondary:hover {
    background: var(--sf-gray-300);
}

.btn-large,
.sf-btn--lg {
    padding: 14px 32px;
    font-size: 1rem;
}

.btn-block,
.sf-btn--block {
    width: 100%;
}

.sf-btn--white {
    background: var(--sf-white);
    color: var(--sf-black);
}

.sf-btn--white:hover {
    background: rgba(255,255,255,0.85);
}

/* Hero button variant (glass) */
.sf-btn--glass {
    background: rgba(255,255,255,0.18);
    color: var(--sf-white);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,0.25);
}

.sf-btn--glass:hover {
    background: rgba(255,255,255,0.28);
}


/* ==========================================================================
   26. FORMS
   ========================================================================== */

.sf-label,
.form-label {
    display: block;
    margin-bottom: 6px;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--sf-gray-700);
}

.form-label-required::after {
    content: ' *';
    color: var(--sf-danger);
}

.sf-input,
.form-input,
.form-textarea {
    width: 100%;
    padding: 10px 14px;
    font-size: 0.95rem;
    border: 1.5px solid var(--sf-gray-300);
    border-radius: var(--sf-radius-md);
    background: var(--sf-white);
    color: var(--sf-black);
    transition: border-color var(--sf-duration) var(--sf-ease),
                box-shadow var(--sf-duration) var(--sf-ease);
}

.sf-input:focus,
.form-input:focus,
.form-textarea:focus {
    outline: none;
    border-color: var(--sf-accent);
    box-shadow: 0 0 0 3px var(--sf-accent-glow);
}

.sf-input::placeholder {
    color: var(--sf-gray-500);
}

.form-group {
    margin-bottom: 20px;
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

@media (max-width: 480px) {
    .form-row { grid-template-columns: 1fr; }
}

.sf-input--error {
    border-color: var(--sf-danger);
}

.sf-input-help {
    font-size: 0.75rem;
    color: var(--sf-gray-500);
    margin-top: 4px;
}

.sf-input-error-msg {
    font-size: 0.75rem;
    color: var(--sf-danger);
    margin-top: 4px;
}


/* ==========================================================================
   27. RESPONSIVE
   ========================================================================== */

/* Mobile-first: base styles are mobile */

@media (min-width: 768px) {
    .sf-hero,
    .hero {
        min-height: 65vh;
    }

    .sf-hero-title,
    .hero-title {
        letter-spacing: -0.04em;
    }

    .sf-product-grid,
    .products-grid {
        grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    }
}

@media (min-width: 1024px) {
    .sf-hero-content,
    .hero-content {
        max-width: 720px;
    }
}

/* Mobile nav override */
@media (max-width: 640px) {
    .sf-header-inner,
    .header-content {
        height: 48px;
    }

    .sf-logo h1,
    .logo h1 {
        font-size: 1rem;
    }

    nav ul,
    .sf-nav ul {
        gap: 0.75rem;
    }

    nav a,
    .sf-nav a {
        font-size: 0.8rem;
    }

    .sf-hero,
    .hero {
        min-height: 55vh;
    }

    .sf-detail-grid,
    .product-detail-grid {
        gap: 20px;
    }

    .sf-contact-grid {
        grid-template-columns: 1fr;
    }

    .sf-delivery-cards {
        grid-template-columns: 1fr;
    }
}


/* ==========================================================================
   28. SCROLL REVEAL ANIMATIONS
   ========================================================================== */

.sf-reveal {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.8s var(--sf-ease),
                transform 0.8s var(--sf-ease);
}

.sf-reveal.sf-visible {
    opacity: 1;
    transform: translateY(0);
}

.sf-reveal-delay-1 { transition-delay: 0.1s; }
.sf-reveal-delay-2 { transition-delay: 0.2s; }
.sf-reveal-delay-3 { transition-delay: 0.3s; }
.sf-reveal-delay-4 { transition-delay: 0.4s; }
.sf-reveal-delay-5 { transition-delay: 0.5s; }
.sf-reveal-delay-6 { transition-delay: 0.6s; }
.sf-reveal-delay-7 { transition-delay: 0.7s; }
.sf-reveal-delay-8 { transition-delay: 0.8s; }

@keyframes sf-pulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.5; }
}

@keyframes sf-pulse-ring {
    0%   { box-shadow: 0 0 0 0 var(--sf-accent-glow); }
    70%  { box-shadow: 0 0 0 8px transparent; }
    100% { box-shadow: 0 0 0 0 transparent; }
}


/* ==========================================================================
   29. PAGE-SPECIFIC BACKGROUNDS
   ========================================================================== */

[data-sf-page="warm"] {
    --sf-page-bg: #faf8f5;
}

[data-sf-page="cool"] {
    --sf-page-bg: #f5f7fa;
}

[data-sf-page="neutral"] {
    --sf-page-bg: var(--sf-gray-100);
}


/* ==========================================================================
   30. DARK MODE
   ========================================================================== */

[data-sf-theme="dark"] {
    --sf-page-bg: #000000;
    --sf-black: #f5f5f7;
    --sf-gray-900: #e8e8ed;
    --sf-gray-700: #d2d2d7;
    --sf-gray-500: #86868b;
    --sf-gray-300: #424245;
    --sf-gray-100: #1d1d1f;
    --sf-white: #0d0d0d;
    --sf-shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
    --sf-shadow-md: 0 4px 12px rgba(0,0,0,0.4);
    --sf-shadow-lg: 0 8px 32px rgba(0,0,0,0.5);
    --sf-shadow-xl: 0 16px 48px rgba(0,0,0,0.6);
}

[data-sf-theme="dark"] .sf-header,
[data-sf-theme="dark"] body > header {
    background: rgba(13,13,13,0.72);
    border-bottom-color: rgba(255,255,255,0.06);
}

[data-sf-theme="dark"] body > header .search-input,
[data-sf-theme="dark"] .sf-header .search-input {
    background: var(--sf-gray-100);
    border-color: var(--sf-gray-300);
    color: var(--sf-black);
}

[data-sf-theme="dark"] .sf-product-card,
[data-sf-theme="dark"] .product-card {
    background: #1d1d1f;
    border-color: #2d2d2f;
}

[data-sf-theme="dark"] .sf-cart-panel {
    background: rgba(13,13,13,0.92);
}

[data-sf-theme="dark"] .sf-story {
    background: linear-gradient(180deg, #1d1d1f 0%, #141414 100%);
}

[data-sf-theme="dark"] .sf-toast {
    background: #1d1d1f;
    color: #f5f5f7;
}

[data-sf-theme="dark"] .sf-toast-success { background: #0a2e1a; color: #86efac; }
[data-sf-theme="dark"] .sf-toast-error   { background: #2e0a0a; color: #fca5a5; }
[data-sf-theme="dark"] .sf-toast-info    { background: #0a1e2e; color: #93c5fd; }
[data-sf-theme="dark"] .sf-toast-warning { background: #2e1f0a; color: #fcd34d; }

[data-sf-theme="dark"] .sf-footer,
[data-sf-theme="dark"] footer {
    background: #0d0d0d;
}

[data-sf-theme="dark"] .cart-summary {
    background: #1d1d1f;
}

[data-sf-theme="dark"] .sf-delivery-card,
[data-sf-theme="dark"] .sf-payment-card {
    border-color: #2d2d2f;
}

[data-sf-theme="dark"] .sf-input,
[data-sf-theme="dark"] .form-input,
[data-sf-theme="dark"] .form-textarea {
    background: #1d1d1f;
    border-color: #2d2d2f;
    color: #f5f5f7;
}

[data-sf-theme="dark"] .sf-search-suggestions,
[data-sf-theme="dark"] .search-suggestions {
    background: #1d1d1f;
    border-color: #2d2d2f;
}


/* ==========================================================================
   31. PRINT STYLES (Order confirmation)
   ========================================================================== */

@media print {
    .sf-header, body > header,
    .sf-footer, footer,
    .sf-cart-overlay,
    .sf-cart-panel,
    .sf-toast-container,
    nav,
    .sf-hero-actions,
    .sf-btn,
    .btn,
    .search-form {
        display: none !important;
    }

    body {
        background: white !important;
        color: black !important;
        font-size: 12pt;
    }

    .sf-container, .container {
        max-width: 100%;
        padding: 0;
    }

    .sf-order-success {
        padding: 20px 0;
    }

    .sf-order-checkmark {
        width: 40px;
        height: 40px;
    }

    .sf-order-details-card {
        background: none !important;
        border: 1px solid #ccc;
        page-break-inside: avoid;
    }

    .sf-product-card,
    .product-card {
        box-shadow: none !important;
        border: 1px solid #ddd;
        break-inside: avoid;
    }

    a[href]::after {
        content: none;
    }
}


/* ==========================================================================
   32. UTILITIES
   ========================================================================== */

.text-center { text-align: center; }
.text-muted  { color: var(--sf-gray-500); }

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border-width: 0;
}

.mt-0 { margin-top: 0; }
.mt-1 { margin-top: 8px; }
.mt-2 { margin-top: 16px; }
.mt-3 { margin-top: 24px; }
.mt-4 { margin-top: 32px; }

.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: 8px; }
.mb-2 { margin-bottom: 16px; }
.mb-3 { margin-bottom: 24px; }
.mb-4 { margin-bottom: 32px; }

/* Search bar (legacy compatibility) */
.search-bar {
    display: flex;
    gap: 12px;
    margin-bottom: 24px;
    max-width: 500px;
}

.search-input-wrapper {
    position: relative;
    flex: 1;
    display: flex;
    align-items: center;
}

.search-icon {
    position: absolute;
    left: 14px;
    width: 18px;
    height: 18px;
    color: var(--sf-gray-500);
    pointer-events: none;
}

.search-input {
    width: 100%;
    padding: 10px 40px 10px 40px;
    font-size: 0.95rem;
    border: 1.5px solid var(--sf-gray-300);
    border-radius: var(--sf-radius-pill);
    transition: border-color var(--sf-duration) var(--sf-ease),
                box-shadow var(--sf-duration) var(--sf-ease);
}

.search-input:focus {
    outline: none;
    border-color: var(--sf-accent);
    box-shadow: 0 0 0 3px var(--sf-accent-glow);
}

.search-clear {
    position: absolute;
    right: 12px;
    background: none;
    border: none;
    padding: 4px;
    cursor: pointer;
    color: var(--sf-gray-500);
    transition: color var(--sf-duration);
}

.search-clear:hover {
    color: var(--sf-black);
}

.search-clear svg {
    width: 16px;
    height: 16px;
}

/* Empty state */
.empty-state {
    text-align: center;
    padding: 64px 24px;
    max-width: 400px;
    margin: 0 auto;
}

.empty-state-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 20px;
    color: var(--sf-gray-300);
}

.empty-state-title {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 8px;
    color: var(--sf-black);
}

.empty-state-text {
    color: var(--sf-gray-500);
    margin-bottom: 20px;
    line-height: 1.6;
    font-size: 0.9rem;
}

/* Pagination */
.pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 12px;
    margin-top: 32px;
}

.pagination-info {
    color: var(--sf-gray-500);
    font-size: 0.85rem;
}


/* ==========================================================================
   NOTRE HISTOIRE SECTION
   ========================================================================== */

.sf-histoire {
    padding: 4rem 0;
}

.sf-histoire-card {
    max-width: 640px;
    margin: 0 auto;
    padding: 2.5rem;
    background: var(--sf-white);
    border-radius: var(--sf-radius-xl);
    box-shadow: var(--sf-shadow-md);
    border: 1px solid rgba(0,0,0,0.04);
}

.sf-histoire-title {
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--sf-black);
    margin-bottom: 1.25rem;
}

.sf-histoire-text {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--sf-gray-700);
    border: none;
    padding: 0;
    margin: 0 0 1.5rem;
    font-style: italic;
}

.sf-histoire-author {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--sf-gray-100);
}

.sf-histoire-author-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--sf-accent);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1rem;
    text-transform: uppercase;
    flex-shrink: 0;
}

.sf-histoire-author-info {
    display: flex;
    flex-direction: column;
}

.sf-histoire-author-info strong {
    font-size: 0.9375rem;
    color: var(--sf-black);
}

.sf-histoire-author-info span {
    font-size: 0.8125rem;
    color: var(--sf-gray-500);
}

/* Dark mode */
html.dark-mode .sf-histoire-card {
    background: #161b22;
    border-color: #21262d;
}
html.dark-mode .sf-histoire-text { color: #8b949e; }
html.dark-mode .sf-histoire-author { border-top-color: #21262d; }


/* ==========================================================================
   DELIVERY INFO BANNER
   ========================================================================== */

.sf-delivery-banner {
    padding: 2rem 0 3rem;
}

.sf-delivery-cards {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}

.sf-delivery-card {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem 1.5rem;
    background: var(--sf-white);
    border: 1px solid rgba(0,0,0,0.06);
    border-radius: var(--sf-radius-md);
    box-shadow: var(--sf-shadow-sm);
    min-width: 200px;
}

.sf-delivery-card svg {
    color: var(--sf-accent);
    flex-shrink: 0;
}

.sf-delivery-card div {
    display: flex;
    flex-direction: column;
}

.sf-delivery-card strong {
    font-size: 0.8125rem;
    color: var(--sf-black);
    letter-spacing: -0.01em;
}

.sf-delivery-card span {
    font-size: 0.8125rem;
    color: var(--sf-gray-500);
}

html.dark-mode .sf-delivery-card {
    background: #161b22;
    border-color: #21262d;
}

@media (max-width: 640px) {
    .sf-delivery-cards {
        flex-direction: column;
    }
    .sf-delivery-card {
        min-width: 0;
    }
}


/* ==========================================================================
   SECTOR-SPECIFIC THEMES
   Each storefront type gets a unique visual identity via body.sf-type-{type}.
   These override base tokens and component styles to create distinct ambiances.
   ========================================================================== */


/* ==========================================================================
   RESTAURANT — Dark, moody, menu-driven
   ========================================================================== */

.sf-type-restaurant {
    --sf-page-bg: #1a1a1a;
    --sf-black: #f5f5f7;
    --sf-white: #1a1a1a;
    --sf-gray-100: #242424;
    --sf-gray-300: #3a3a3a;
    --sf-gray-500: #999;
    --sf-gray-700: #ccc;
    --sf-gray-900: #eee;
    --sf-accent: #d4a04a;
    --sf-accent-hover: #c0902e;
    --sf-accent-light: rgba(212, 160, 74, 0.1);
    --sf-accent-glow: rgba(212, 160, 74, 0.08);
    --sf-shadow-sm: 0 1px 3px rgba(0,0,0,0.2);
    --sf-shadow-md: 0 4px 12px rgba(0,0,0,0.3);
    --sf-shadow-lg: 0 8px 32px rgba(0,0,0,0.4);
    background-color: #1a1a1a;
    color: #f5f5f7;
}

.sf-type-restaurant .sf-hero,
.sf-type-restaurant .sf-section {
    background: #1a1a1a;
}

/* Menu-style product grid: single column list */
.sf-type-restaurant .sf-product-grid,
.sf-type-restaurant .products-grid {
    grid-template-columns: 1fr;
    gap: 0;
    max-width: 720px;
    margin: 0 auto;
}

/* Menu item card: horizontal layout */
.sf-type-restaurant .sf-product-card,
.sf-type-restaurant .product-card {
    flex-direction: row;
    border-radius: 0;
    border: none;
    border-bottom: 1px solid #2a2a2a;
    background: transparent;
    padding: 20px 0;
}

.sf-type-restaurant .sf-product-card:hover,
.sf-type-restaurant .product-card:hover {
    transform: none;
    box-shadow: none;
    background: rgba(255,255,255,0.03);
}

/* Smaller image for menu layout */
.sf-type-restaurant .sf-product-card-image,
.sf-type-restaurant .product-image-wrapper {
    width: 80px;
    height: 80px;
    min-width: 80px;
    aspect-ratio: 1;
    border-radius: var(--sf-radius-md);
    order: 2;
    margin-left: auto;
}

/* Serif-ish typography for dish names */
.sf-type-restaurant .sf-product-card-name,
.sf-type-restaurant .product-card .product-name {
    font-family: 'Georgia', 'Times New Roman', 'Playfair Display', serif;
    font-size: 1.1rem;
    font-weight: 600;
    letter-spacing: -0.01em;
    color: #f5f5f7;
}

.sf-type-restaurant .sf-product-card-desc,
.sf-type-restaurant .product-card .product-desc {
    color: #888;
    font-size: 0.85rem;
    font-style: italic;
    margin-top: 4px;
}

/* Warm gold price */
.sf-type-restaurant .sf-product-card-price,
.sf-type-restaurant .product-card .product-price {
    color: #d4a04a;
    font-weight: 700;
    font-size: 1rem;
    margin-top: 8px;
}

/* Category pills as menu section tabs */
.sf-type-restaurant .sf-category-pill {
    border: none;
    border-radius: 0;
    border-bottom: 2px solid transparent;
    background: transparent;
    color: #888;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.1em;
    padding: 12px 16px;
}

.sf-type-restaurant .sf-category-pill:hover {
    color: #d4a04a;
    border-bottom-color: #d4a04a;
}

.sf-type-restaurant .sf-category-pill.active,
.sf-type-restaurant .sf-category-pill--active {
    background: transparent;
    color: #d4a04a;
    border-bottom-color: #d4a04a;
}

/* Hide add overlay, use subtle text link instead */
.sf-type-restaurant .sf-product-add-overlay {
    position: static;
    width: auto;
    height: auto;
    border-radius: var(--sf-radius-pill);
    background: rgba(212, 160, 74, 0.12);
    color: #d4a04a;
    font-size: 0.8rem;
    font-weight: 600;
    padding: 6px 14px;
    opacity: 1;
    margin-top: 10px;
}

/* Header & navbar dark treatment */
.sf-type-restaurant .sf-header,
.sf-type-restaurant .sf-navbar {
    background: #111;
    border-bottom: 1px solid #2a2a2a;
}

.sf-type-restaurant .sf-store-name {
    font-family: 'Georgia', 'Times New Roman', serif;
    letter-spacing: 0.05em;
}

/* Footer */
.sf-type-restaurant .sf-footer {
    background: #111;
    border-top: 1px solid #2a2a2a;
}


/* ==========================================================================
   BOUTIQUE — Masonry, beige luxury, fashion-forward
   ========================================================================== */

.sf-type-boutique {
    --sf-page-bg: #faf8f5;
    --sf-gray-100: #f3f0eb;
    --sf-gray-300: #ddd8d0;
    --sf-shadow-sm: 0 1px 4px rgba(120,100,70,0.06);
    --sf-shadow-md: 0 4px 16px rgba(120,100,70,0.08);
    --sf-shadow-lg: 0 8px 32px rgba(120,100,70,0.1);
    background-color: #faf8f5;
}

/* Masonry layout via CSS columns */
.sf-type-boutique .sf-product-grid,
.sf-type-boutique .products-grid {
    display: block;
    columns: 3;
    column-gap: 20px;
}

@media (max-width: 768px) {
    .sf-type-boutique .sf-product-grid,
    .sf-type-boutique .products-grid {
        columns: 2;
        column-gap: 12px;
    }
}

/* Masonry card: break-inside-avoid */
.sf-type-boutique .sf-product-card,
.sf-type-boutique .product-card {
    break-inside: avoid;
    margin-bottom: 20px;
    display: inline-block;
    width: 100%;
    border: none;
    border-radius: var(--sf-radius-lg);
    background: var(--sf-white);
    overflow: hidden;
    box-shadow: var(--sf-shadow-sm);
}

@media (max-width: 768px) {
    .sf-type-boutique .sf-product-card,
    .sf-type-boutique .product-card {
        margin-bottom: 12px;
    }
}

/* Larger images, varied aspect ratios for masonry feel */
.sf-type-boutique .sf-product-card-image,
.sf-type-boutique .product-image-wrapper {
    aspect-ratio: auto;
    overflow: hidden;
}

.sf-type-boutique .sf-product-card-image img,
.sf-type-boutique .product-image {
    position: relative;
    width: 100%;
    height: auto;
    object-fit: cover;
    transition: transform 0.6s var(--sf-ease);
}

/* Gentle zoom on hover */
.sf-type-boutique .sf-product-card:hover .sf-product-card-image img,
.sf-type-boutique .product-card:hover .product-image {
    transform: scale(1.04);
}

.sf-type-boutique .sf-product-card:hover,
.sf-type-boutique .product-card:hover {
    transform: none;
    box-shadow: var(--sf-shadow-md);
}

/* Minimal text overlay */
.sf-type-boutique .sf-product-card-info,
.sf-type-boutique .product-card .product-info {
    padding: 14px 16px 18px;
}

.sf-type-boutique .sf-product-card-name {
    font-size: 0.9rem;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.sf-type-boutique .sf-product-card-desc {
    display: none;
}

.sf-type-boutique .sf-product-card-price {
    font-size: 0.85rem;
    color: var(--sf-gray-700);
    font-weight: 500;
}

/* "Reserver" button style */
.sf-type-boutique .sf-product-add-overlay {
    width: auto;
    height: auto;
    border-radius: var(--sf-radius-pill);
    background: var(--sf-black);
    color: var(--sf-white);
    font-size: 0.75rem;
    font-weight: 600;
    padding: 8px 16px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    bottom: 14px;
    right: 14px;
}

.sf-type-boutique .sf-product-add-overlay::before {
    content: "Reserver";
}

.sf-type-boutique .sf-product-add-overlay svg {
    display: none;
}

/* Category pills: refined underline style */
.sf-type-boutique .sf-category-pill {
    border: none;
    border-radius: 0;
    padding: 10px 18px;
    font-weight: 500;
    font-size: 0.8rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--sf-gray-500);
    background: transparent;
    border-bottom: 2px solid transparent;
    transition: all var(--sf-duration) var(--sf-ease);
}

.sf-type-boutique .sf-category-pill:hover {
    color: var(--sf-black);
    border-bottom-color: var(--sf-black);
}

.sf-type-boutique .sf-category-pill.active,
.sf-type-boutique .sf-category-pill--active {
    background: transparent;
    color: var(--sf-black);
    border-bottom-color: var(--sf-black);
}

/* Warm header */
.sf-type-boutique .sf-header,
.sf-type-boutique .sf-navbar {
    background: #faf8f5;
    border-bottom: 1px solid #e8e4de;
}

.sf-type-boutique .sf-store-name {
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-size: 0.95rem;
}


/* ==========================================================================
   ARTISAN — Portfolio gallery, earthy craft tones
   ========================================================================== */

.sf-type-artisan {
    --sf-page-bg: #f7f4f0;
    --sf-gray-100: #eeebe5;
    --sf-gray-300: #d6d0c8;
    --sf-shadow-sm: 0 1px 4px rgba(80,60,30,0.06);
    --sf-shadow-md: 0 6px 20px rgba(80,60,30,0.1);
    --sf-shadow-lg: 0 12px 40px rgba(80,60,30,0.14);
    background-color: #f7f4f0;
}

/* Portfolio gallery: 2-column large tiles */
.sf-type-artisan .sf-product-grid,
.sf-type-artisan .products-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
}

@media (max-width: 640px) {
    .sf-type-artisan .sf-product-grid,
    .sf-type-artisan .products-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }
}

/* Portfolio card: overlay text on image */
.sf-type-artisan .sf-product-card,
.sf-type-artisan .product-card {
    border: none;
    border-radius: var(--sf-radius-lg);
    overflow: hidden;
    position: relative;
    background: transparent;
}

.sf-type-artisan .sf-product-card-image,
.sf-type-artisan .product-image-wrapper {
    aspect-ratio: 4 / 3;
}

.sf-type-artisan .sf-product-card:hover,
.sf-type-artisan .product-card:hover {
    transform: none;
    box-shadow: var(--sf-shadow-lg);
}

/* Overlay info on image */
.sf-type-artisan .sf-product-card-info,
.sf-type-artisan .product-card .product-info {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 24px 20px 20px;
    background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0) 100%);
    z-index: 2;
}

.sf-type-artisan .sf-product-card-name {
    color: #fff;
    font-size: 1.1rem;
    font-weight: 700;
    text-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

.sf-type-artisan .sf-product-card-desc {
    color: rgba(255,255,255,0.8);
    font-size: 0.82rem;
    margin-top: 4px;
}

.sf-type-artisan .sf-product-card-price {
    color: #fff;
    font-weight: 600;
    font-size: 0.95rem;
    margin-top: 6px;
}

/* Badge-style category pills (craft specialties) */
.sf-type-artisan .sf-category-pill {
    border-radius: var(--sf-radius-sm);
    background: #e8e2d8;
    border: none;
    color: #6b5d4a;
    font-weight: 600;
    font-size: 0.8rem;
    padding: 8px 16px;
}

.sf-type-artisan .sf-category-pill:hover {
    background: #ddd5c8;
    color: #4a3d2e;
}

.sf-type-artisan .sf-category-pill.active,
.sf-type-artisan .sf-category-pill--active {
    background: #6b5d4a;
    color: #fff;
    border-color: #6b5d4a;
}

/* Certification badge */
.sf-type-artisan .sf-certification-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: #f0ebe3;
    border: 1px solid #d6cfc5;
    border-radius: var(--sf-radius-pill);
    font-size: 0.75rem;
    font-weight: 600;
    color: #6b5d4a;
}

.sf-type-artisan .sf-certification-badge::before {
    content: "\2713";
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #6b5d4a;
    color: #fff;
    font-size: 0.65rem;
}

/* Artisan header */
.sf-type-artisan .sf-header,
.sf-type-artisan .sf-navbar {
    background: #f7f4f0;
    border-bottom: 1px solid #e0dbd3;
}

.sf-type-artisan .sf-store-name {
    font-weight: 800;
    letter-spacing: -0.01em;
}


/* ==========================================================================
   FLEURISTE — Soft, floral, pastel organic shapes
   ========================================================================== */

.sf-type-fleuriste {
    --sf-page-bg: #fff5f5;
    --sf-gray-100: #fef0f0;
    --sf-gray-300: #f0d5d5;
    --sf-accent: #e8788a;
    --sf-accent-hover: #d4636f;
    --sf-accent-light: rgba(232, 120, 138, 0.08);
    --sf-shadow-sm: 0 1px 4px rgba(180,100,100,0.06);
    --sf-shadow-md: 0 4px 16px rgba(180,100,100,0.1);
    --sf-shadow-lg: 0 8px 32px rgba(180,100,100,0.14);
    background-color: #fff5f5;
}

/* Rounded organic grid */
.sf-type-fleuriste .sf-product-grid,
.sf-type-fleuriste .products-grid {
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 24px;
}

/* Organic rounded cards */
.sf-type-fleuriste .sf-product-card,
.sf-type-fleuriste .product-card {
    border: none;
    border-radius: 24px;
    overflow: hidden;
    background: var(--mary-bg-primary, #fff);
    box-shadow: var(--sf-shadow-sm);
    transition: transform var(--sf-duration) var(--sf-ease),
                box-shadow var(--sf-duration) var(--sf-ease);
}

.sf-type-fleuriste .sf-product-card:hover,
.sf-type-fleuriste .product-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--sf-shadow-lg);
}

.sf-type-fleuriste .sf-product-card-image,
.sf-type-fleuriste .product-image-wrapper {
    aspect-ratio: 3 / 4;
    background: #fef0f0;
}

.sf-type-fleuriste .sf-product-card-info {
    padding: 16px 18px 20px;
    text-align: center;
}

.sf-type-fleuriste .sf-product-card-name {
    font-weight: 600;
    font-size: 0.95rem;
    color: #4a2c3a;
}

.sf-type-fleuriste .sf-product-card-price {
    color: #e8788a;
    font-weight: 700;
    font-size: 1rem;
    margin-top: 6px;
}

/* Tag badges: Bestseller, Nouveau, Premium */
.sf-type-fleuriste .sf-product-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 3;
    padding: 5px 12px;
    border-radius: 20px;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.sf-type-fleuriste .sf-product-badge--bestseller {
    background: #e8788a;
    color: #fff;
}

.sf-type-fleuriste .sf-product-badge--nouveau {
    background: #7ec8a0;
    color: #fff;
}

.sf-type-fleuriste .sf-product-badge--premium {
    background: linear-gradient(135deg, #d4a04a, #e8c068);
    color: #fff;
}

/* Occasion-based filter pills with icons */
.sf-type-fleuriste .sf-category-pill {
    border-radius: 20px;
    background: var(--mary-bg-primary, #fff);
    border: 1.5px solid #f0d5d5;
    color: #8a5a6a;
    font-weight: 500;
    font-size: 0.82rem;
    padding: 8px 18px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.sf-type-fleuriste .sf-category-pill::before {
    font-size: 0.9rem;
    line-height: 1;
}

.sf-type-fleuriste .sf-category-pill:hover {
    border-color: #e8788a;
    color: #e8788a;
    background: rgba(232, 120, 138, 0.04);
}

.sf-type-fleuriste .sf-category-pill.active,
.sf-type-fleuriste .sf-category-pill--active {
    background: #e8788a;
    border-color: #e8788a;
    color: #fff;
}

/* Floral CTA button */
.sf-type-fleuriste .sf-product-add-overlay {
    background: #e8788a;
    border-radius: 50%;
    width: 42px;
    height: 42px;
}

.sf-type-fleuriste .sf-product-add-overlay:hover {
    background: #d4636f;
}

/* Header */
.sf-type-fleuriste .sf-header,
.sf-type-fleuriste .sf-navbar {
    background: #fff5f5;
    border-bottom: 1px solid #f0e0e0;
}

.sf-type-fleuriste .sf-store-name {
    font-weight: 700;
    color: #4a2c3a;
}


/* ==========================================================================
   BOULANGERIE — Warm bakery tones, rustic-modern
   ========================================================================== */

.sf-type-boulangerie {
    --sf-page-bg: #fdf8f0;
    --sf-gray-100: #f5ede2;
    --sf-gray-300: #e0d5c5;
    --sf-accent: #c87830;
    --sf-accent-hover: #b06820;
    --sf-accent-light: rgba(200, 120, 48, 0.08);
    --sf-shadow-sm: 0 1px 4px rgba(120,80,30,0.06);
    --sf-shadow-md: 0 4px 16px rgba(120,80,30,0.1);
    --sf-shadow-lg: 0 8px 32px rgba(120,80,30,0.14);
    background-color: #fdf8f0;
}

/* Grid: emphasize food photography with larger cards */
.sf-type-boulangerie .sf-product-grid,
.sf-type-boulangerie .products-grid {
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 24px;
}

@media (max-width: 480px) {
    .sf-type-boulangerie .sf-product-grid,
    .sf-type-boulangerie .products-grid {
        grid-template-columns: 1fr 1fr;
        gap: 12px;
    }
}

/* Cards: warm, rounded, food-first */
.sf-type-boulangerie .sf-product-card,
.sf-type-boulangerie .product-card {
    border: none;
    border-radius: var(--sf-radius-xl);
    background: var(--mary-bg-primary, #fff);
    overflow: hidden;
    box-shadow: var(--sf-shadow-sm);
}

.sf-type-boulangerie .sf-product-card:hover,
.sf-type-boulangerie .product-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--sf-shadow-md);
}

/* Taller image: food photography hero */
.sf-type-boulangerie .sf-product-card-image,
.sf-type-boulangerie .product-image-wrapper {
    aspect-ratio: 4 / 3;
    background: #f5ede2;
}

.sf-type-boulangerie .sf-product-card-info {
    padding: 14px 16px 18px;
}

.sf-type-boulangerie .sf-product-card-name {
    font-weight: 700;
    font-size: 1rem;
    color: #3a2810;
}

.sf-type-boulangerie .sf-product-card-desc {
    color: #8a7560;
    font-size: 0.82rem;
    margin-top: 4px;
}

.sf-type-boulangerie .sf-product-card-price {
    color: #c87830;
    font-weight: 700;
    font-size: 1rem;
    margin-top: 8px;
}

/* Category pills: warm badge style */
.sf-type-boulangerie .sf-category-pill {
    border-radius: var(--sf-radius-pill);
    background: #f5ede2;
    border: none;
    color: #8a6840;
    font-weight: 600;
    font-size: 0.82rem;
    padding: 8px 18px;
}

.sf-type-boulangerie .sf-category-pill:hover {
    background: #ece0d0;
    color: #6a4e28;
}

.sf-type-boulangerie .sf-category-pill.active,
.sf-type-boulangerie .sf-category-pill--active {
    background: #c87830;
    color: #fff;
    border-color: #c87830;
}

/* Warm CTA button */
.sf-type-boulangerie .sf-product-add-overlay {
    background: #c87830;
}

.sf-type-boulangerie .sf-product-add-overlay:hover {
    background: #b06820;
}

/* Header */
.sf-type-boulangerie .sf-header,
.sf-type-boulangerie .sf-navbar {
    background: #fdf8f0;
    border-bottom: 1px solid #e8ddd0;
}

.sf-type-boulangerie .sf-store-name {
    font-weight: 800;
    color: #3a2810;
}


/* ==========================================================================
   "POWERED BY MARY" BADGE
   Floating bottom-right badge with expand-on-hover CTA.
   ========================================================================== */

.sf-powered-badge {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 9000;
    display: flex;
    align-items: center;
    gap: 0;
    background: rgba(29, 29, 31, 0.9);
    -webkit-backdrop-filter: blur(20px);
    backdrop-filter: blur(20px);
    border-radius: var(--sf-radius-pill);
    padding: 8px 14px;
    color: #fff;
    font-size: 0.75rem;
    font-weight: 500;
    text-decoration: none;
    box-shadow: 0 4px 20px rgba(0,0,0,0.15);
    transition: all 0.4s var(--sf-ease);
    cursor: pointer;
    overflow: hidden;
    white-space: nowrap;
    max-width: 200px;
}

.sf-powered-badge-logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    min-width: 22px;
    border-radius: 50%;
    background: var(--couleur-primaire, #10b981);
    color: #fff;
    font-weight: 800;
    font-size: 0.7rem;
    margin-right: 8px;
    transition: margin 0.4s var(--sf-ease);
}

.sf-powered-badge-text {
    display: inline;
    opacity: 1;
    transition: opacity 0.3s var(--sf-ease);
}

.sf-powered-expanded {
    display: inline;
    max-width: 0;
    opacity: 0;
    overflow: hidden;
    transition: max-width 0.4s var(--sf-ease),
                opacity 0.3s var(--sf-ease) 0.1s;
    white-space: nowrap;
}

.sf-powered-badge:hover {
    max-width: 420px;
    background: rgba(29, 29, 31, 0.95);
    box-shadow: 0 6px 28px rgba(0,0,0,0.22);
    padding-right: 18px;
}

.sf-powered-badge:hover .sf-powered-expanded {
    max-width: 300px;
    opacity: 1;
}

.sf-powered-expanded-link {
    display: inline;
    color: var(--couleur-primaire, #10b981);
    font-weight: 600;
    text-decoration: none;
    margin-left: 6px;
    white-space: nowrap;
}

.sf-powered-expanded-link:hover {
    
}

/* Restaurant dark-mode override for badge */
.sf-type-restaurant .sf-powered-badge {
    background: rgba(255,255,255,0.1);
    -webkit-backdrop-filter: blur(20px);
    backdrop-filter: blur(20px);
}

.sf-type-restaurant .sf-powered-badge:hover {
    background: rgba(255,255,255,0.15);
}

/* Hide badge on mobile to save space, show mini version */
@media (max-width: 480px) {
    .sf-powered-badge {
        bottom: 80px; /* Above mobile sticky nav */
        right: 12px;
        padding: 6px 10px;
        font-size: 0.65rem;
        max-width: 160px;
    }

    .sf-powered-badge-logo {
        width: 18px;
        height: 18px;
        min-width: 18px;
        font-size: 0.6rem;
        margin-right: 6px;
    }

    .sf-powered-badge:hover {
        max-width: 320px;
    }
}


/* ==========================================================================
   MOBILE-FIRST IMPROVEMENTS
   Better touch targets, mobile grids, sticky nav, checkout spacing.
   ========================================================================== */

/* Touch targets: minimum 44px per Apple HIG */
@media (max-width: 768px) {
    .sf-category-pill {
        min-height: 44px;
        display: inline-flex;
        align-items: center;
        padding: 10px 20px;
    }

    .sf-product-add-overlay {
        width: 44px;
        height: 44px;
    }

    .sf-cart-btn {
        min-width: 44px;
        min-height: 44px;
    }

    .sf-btn,
    .sf-btn-primary,
    .sf-btn-checkout-fallback,
    .sf-btn-apple-pay {
        min-height: 48px;
        font-size: 1rem;
        padding: 14px 24px;
    }

    /* Input fields: larger for mobile */
    .sf-input,
    .sf-cart-panel-form .sf-input {
        min-height: 48px;
        font-size: 1rem;
        padding: 12px 16px;
    }
}

/* Mobile product grid: 2 cols for boutique */
@media (max-width: 480px) {
    .sf-type-boutique .sf-product-grid,
    .sf-type-boutique .products-grid {
        columns: 2;
        column-gap: 10px;
    }

    .sf-type-boutique .sf-product-card,
    .sf-type-boutique .product-card {
        margin-bottom: 10px;
    }
}

/* Mobile sticky bottom nav bar */
.sf-mobile-nav {
    display: none;
}

@media (max-width: 768px) {
    .sf-mobile-nav {
        display: flex;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        z-index: 8500;
        background: rgba(255,255,255,0.95);
        -webkit-backdrop-filter: blur(20px);
        backdrop-filter: blur(20px);
        border-top: 1px solid var(--sf-gray-100);
        padding: 8px 0;
        padding-bottom: calc(8px + env(safe-area-inset-bottom));
        justify-content: space-around;
        align-items: center;
    }

    .sf-mobile-nav-item {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 2px;
        padding: 6px 12px;
        min-width: 64px;
        min-height: 44px;
        justify-content: center;
        color: var(--sf-gray-500);
        text-decoration: none;
        font-size: 0.65rem;
        font-weight: 500;
        transition: color 0.2s ease;
        -webkit-tap-highlight-color: transparent;
    }

    .sf-mobile-nav-item:active,
    .sf-mobile-nav-item.active {
        color: var(--sf-accent);
    }

    .sf-mobile-nav-item svg {
        width: 22px;
        height: 22px;
    }

    .sf-mobile-nav-cart-count {
        position: absolute;
        top: 2px;
        right: 8px;
        min-width: 16px;
        height: 16px;
        border-radius: 8px;
        background: var(--sf-accent);
        color: #fff;
        font-size: 0.6rem;
        font-weight: 700;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0 4px;
    }

    /* Dark treatment for restaurant mobile nav */
    .sf-type-restaurant .sf-mobile-nav {
        background: rgba(26, 26, 26, 0.95);
        border-top: 1px solid #2a2a2a;
    }

    .sf-type-restaurant .sf-mobile-nav-item {
        color: #888;
    }

    .sf-type-restaurant .sf-mobile-nav-item:active,
    .sf-type-restaurant .sf-mobile-nav-item.active {
        color: #d4a04a;
    }

    /* Offset main content for bottom nav */
    .sf-storefront {
        padding-bottom: 72px;
    }
}

/* Mobile checkout flow spacing */
@media (max-width: 768px) {
    .sf-cart-panel {
        width: 100%;
        max-width: 100%;
        border-radius: var(--sf-radius-xl) var(--sf-radius-xl) 0 0;
    }

    .sf-cart-panel-header {
        padding: 20px 20px 16px;
    }

    .sf-cart-panel-items {
        padding: 0 20px;
    }

    .sf-cart-panel-total {
        padding: 16px 20px;
    }

    /* Cart item touch targets */
    .sf-cart-item {
        min-height: 64px;
        padding: 12px 0;
    }

    .sf-cart-item-qty button {
        min-width: 36px;
        min-height: 36px;
        border-radius: 50%;
    }

    /* Checkout button: full width, prominent */
    .sf-cart-panel-form {
        padding: 0 20px 20px;
    }

    .sf-cart-panel-form .sf-btn,
    .sf-cart-panel-form .sf-btn-primary,
    .sf-cart-panel-form .sf-btn-checkout-fallback,
    .sf-cart-panel-form .sf-btn-apple-pay {
        width: 100%;
        justify-content: center;
        border-radius: var(--sf-radius-md);
    }

    /* Safe area at bottom for checkout */
    .sf-cart-panel-form::after {
        content: "";
        display: block;
        height: env(safe-area-inset-bottom);
    }
}

/* Mobile search improvements */
@media (max-width: 768px) {
    .sf-search-input,
    .sf-search input {
        min-height: 48px;
        font-size: 1rem;
        border-radius: var(--sf-radius-md);
    }
}

/* Fleuriste mobile: 2 columns */
@media (max-width: 480px) {
    .sf-type-fleuriste .sf-product-grid,
    .sf-type-fleuriste .products-grid {
        grid-template-columns: 1fr 1fr;
        gap: 12px;
    }

    .sf-type-fleuriste .sf-product-card-image,
    .sf-type-fleuriste .product-image-wrapper {
        aspect-ratio: 3 / 4;
    }
}

/* Restaurant mobile: keep single column */
@media (max-width: 480px) {
    .sf-type-restaurant .sf-product-grid,
    .sf-type-restaurant .products-grid {
        grid-template-columns: 1fr;
    }

    .sf-type-restaurant .sf-product-card-image,
    .sf-type-restaurant .product-image-wrapper {
        width: 64px;
        height: 64px;
        min-width: 64px;
    }
}

/* Artisan mobile: single column portfolio */
@media (max-width: 480px) {
    .sf-type-artisan .sf-product-card-image,
    .sf-type-artisan .product-image-wrapper {
        aspect-ratio: 16 / 10;
    }
}


/* ==========================================================================
   MOCKUP UPGRADE — Inter Font Import
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Segoe UI', Roboto, sans-serif;
}


/* ==========================================================================
   MOCKUP UPGRADE — Hero Open/Close Status
   ========================================================================== */

.sf-hero-meta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 2rem;
    padding: 8px 18px;
    background: rgba(255,255,255,0.12);
    backdrop-filter: blur(10px);
    border-radius: var(--sf-radius-pill);
    font-size: 0.85rem;
    color: rgba(255,255,255,0.88);
}

.sf-hero-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
}

.sf-hero-status-dot.open {
    background: #4ade80;
    box-shadow: 0 0 8px rgba(74,222,128,0.5);
    animation: sf-pulse 2s ease-in-out infinite;
}

.sf-hero-status-dot.closed {
    background: #ef4444;
    box-shadow: 0 0 8px rgba(239,68,68,0.3);
}

@keyframes sf-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}


/* ==========================================================================
   MOCKUP UPGRADE — Hours Grid (Contact Section)
   ========================================================================== */

.sf-hours-grid {
    margin-top: 1rem;
}

.sf-hours-row {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    font-size: 0.85rem;
    color: var(--sf-gray-500);
    border-bottom: 1px solid var(--sf-gray-100);
}

.sf-hours-row:last-child {
    border-bottom: none;
}

.sf-hours-row .day {
    font-weight: 600;
    color: var(--sf-gray-700);
}

.sf-hours-row.today {
    color: var(--sf-accent);
    font-weight: 600;
}

.sf-hours-row.today .day {
    color: var(--sf-accent);
}

.sf-map-placeholder {
    border-radius: var(--sf-radius-lg);
    background: linear-gradient(135deg, var(--sf-gray-100), rgba(0,0,0,0.04));
    min-height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--sf-gray-300);
    font-size: 0.9rem;
    flex-direction: column;
    gap: 8px;
}

.sf-map-placeholder svg {
    width: 32px;
    height: 32px;
    opacity: 0.5;
}


/* ==========================================================================
   MOCKUP UPGRADE — Expandable Sections (Product Detail)
   ========================================================================== */

.sf-expandable {
    border-top: 1px solid var(--sf-gray-100);
    padding: 16px 0;
}

.sf-expandable-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--sf-gray-700);
    user-select: none;
}

.sf-expandable-header:hover {
    color: var(--sf-black);
}

.sf-expandable-icon {
    transition: transform 0.25s var(--sf-ease);
    flex-shrink: 0;
}

.sf-expandable.sf-open .sf-expandable-icon {
    transform: rotate(180deg);
}

.sf-expandable-body {
    display: none;
    padding-top: 12px;
    font-size: 0.9rem;
    color: var(--sf-gray-500);
    line-height: 1.7;
}

.sf-expandable.sf-open .sf-expandable-body {
    display: block;
}

.sf-expandable-body strong {
    color: var(--sf-gray-700);
    font-weight: 600;
}

.sf-info-row {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    font-size: 0.85rem;
    border-bottom: 1px solid var(--sf-gray-100);
}

.sf-info-row:last-child {
    border-bottom: none;
}


/* ==========================================================================
   MOCKUP UPGRADE — Apple Pay / Google Pay Buttons
   ========================================================================== */

.sf-wallet-section {
    margin-bottom: 1.5rem;
}

.sf-btn-wallet {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 14px;
    border-radius: var(--sf-radius-pill);
    border: none;
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.2s;
}

.sf-btn-apple-pay {
    background: #1d1d1f;
    color: white;
    margin-bottom: 10px;
    font-size: 1.05rem;
    letter-spacing: 0.3px;
}

.sf-btn-apple-pay:hover {
    background: #000;
    transform: translateY(-1px);
    box-shadow: 0 4px 16px rgba(0,0,0,0.3);
}

.sf-btn-google-pay {
    background: white;
    color: var(--sf-gray-700);
    border: 1.5px solid var(--sf-gray-300);
    margin-bottom: 10px;
}

.sf-btn-google-pay:hover {
    border-color: var(--sf-gray-500);
}

.sf-wallet-divider {
    text-align: center;
    font-size: 0.85rem;
    color: var(--sf-gray-300);
    padding: 6px 0;
    position: relative;
}

.sf-wallet-divider::before,
.sf-wallet-divider::after {
    content: '';
    position: absolute;
    top: 50%;
    width: calc(50% - 30px);
    height: 1px;
    background: var(--sf-gray-100);
}

.sf-wallet-divider::before { left: 0; }
.sf-wallet-divider::after { right: 0; }


/* ==========================================================================
   MOCKUP UPGRADE — Confetti Animation (Order Success)
   ========================================================================== */

.sf-confetti-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 9999;
    overflow: hidden;
}

.sf-confetti {
    position: absolute;
    width: 10px;
    height: 10px;
    opacity: 0;
    animation: sfConfettiFall 3s ease-in-out forwards;
}

.sf-confetti.circle { border-radius: 50%; }
.sf-confetti.square { border-radius: 2px; }
.sf-confetti.strip { width: 4px; height: 14px; border-radius: 2px; }

@keyframes sfConfettiFall {
    0% {
        transform: translateY(-20px) rotate(0deg) scale(1);
        opacity: 1;
    }
    80% {
        opacity: 0.8;
    }
    100% {
        transform: translateY(100vh) rotate(720deg) scale(0.5);
        opacity: 0;
    }
}


/* ==========================================================================
   MOCKUP UPGRADE — Dashboard Metrics Sparklines
   ========================================================================== */

.sf-metric-card {
    position: relative;
    overflow: hidden;
}

.sf-metric-sparkline {
    margin-top: 10px;
}

.sf-metric-sparkline svg {
    width: 100%;
    height: 32px;
    display: block;
}

.sf-metric-trend {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.75rem;
    font-weight: 700;
    margin-top: 6px;
    padding: 3px 8px;
    border-radius: 6px;
}

.sf-metric-trend.up {
    background: #dcfce8;
    color: #15803d;
}

.sf-metric-trend.down {
    background: #fef2f2;
    color: #991b1b;
}


/* ==========================================================================
   MOCKUP UPGRADE — Dashboard Quick Actions
   ========================================================================== */

.sf-dash-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.sf-dash-card {
    background: white;
    border-radius: var(--sf-radius-xl, 1rem);
    padding: 1.5rem;
    box-shadow: 0 1px 2px rgba(0,0,0,0.05);
    border: 1px solid #e5e7eb;
}

.sf-dash-card h3 {
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    margin-bottom: 1rem;
    color: #111827;
}

.sf-dash-action {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    border-radius: 12px;
    cursor: pointer;
    transition: all 0.15s;
    margin-bottom: 8px;
    text-decoration: none;
    color: inherit;
}

.sf-dash-action:last-child { margin-bottom: 0; }

.sf-dash-action:hover {
    background: #f9fafb;
    transform: translateX(4px);
}

.sf-dash-action-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 1.1rem;
}

.sf-dash-action-icon.amber { background: #fffbeb; color: #d97706; }
.sf-dash-action-icon.blue { background: #eff6ff; color: #2563eb; }
.sf-dash-action-icon.purple { background: #f5f3ff; color: #7c3aed; }
.sf-dash-action-icon.green { background: #f0fdf4; color: #16a34a; }

.sf-dash-action h4 {
    font-size: 0.875rem;
    font-weight: 600;
    color: #111827;
    margin: 0 0 2px;
}

.sf-dash-action p {
    font-size: 0.8125rem;
    color: #6b7280;
    margin: 0;
}

.sf-badge-pulse {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: #ef4444;
    color: white;
    font-size: 0.6875rem;
    font-weight: 700;
    margin-left: auto;
    flex-shrink: 0;
    animation: sf-pulse 2s ease-in-out infinite;
}


/* ==========================================================================
   MOCKUP UPGRADE — Dashboard Recent Orders
   ========================================================================== */

.sf-dash-order {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 10px 0;
    border-bottom: 1px solid #f3f4f6;
    font-size: 0.8125rem;
}

.sf-dash-order:last-child { border-bottom: none; }

.sf-dash-order-num {
    font-weight: 700;
    color: #111827;
    min-width: 45px;
}

.sf-dash-order-name {
    font-weight: 600;
    color: #374151;
    min-width: 80px;
}

.sf-dash-order-detail {
    color: #6b7280;
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.sf-dash-order-time {
    color: #9ca3af;
    font-size: 0.75rem;
    white-space: nowrap;
}

.sf-dash-order-status {
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 0.6875rem;
    font-weight: 600;
    white-space: nowrap;
}

.sf-dash-order-status.new { background: #dbeafe; color: #1e40af; }
.sf-dash-order-status.prep { background: #fef3c7; color: #92400e; }
.sf-dash-order-status.ready { background: #dcfce8; color: #166534; }
.sf-dash-order-status.retrieved { background: #f3f4f6; color: #6b7280; }

.sf-dash-order-amount {
    font-weight: 700;
    color: #111827;
    white-space: nowrap;
    min-width: 55px;
    text-align: right;
}


/* ==========================================================================
   MOCKUP UPGRADE — Dashboard Live Preview
   ========================================================================== */

.sf-dash-live-frame {
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    overflow: hidden;
    background: #faf6f1;
}

.sf-dash-live-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: #f3f4f6;
    border-bottom: 1px solid #e5e7eb;
}

.sf-dash-live-bar .mini-dots {
    display: flex;
    gap: 4px;
}

.sf-dash-live-bar .mini-dots span {
    width: 7px;
    height: 7px;
    border-radius: 50%;
}

.sf-dash-live-bar .mini-dots span:nth-child(1) { background: #ff5f57; }
.sf-dash-live-bar .mini-dots span:nth-child(2) { background: #febc2e; }
.sf-dash-live-bar .mini-dots span:nth-child(3) { background: #28c840; }

.sf-dash-live-bar .mini-url {
    flex: 1;
    text-align: center;
    font-size: 0.6875rem;
    color: #6b7280;
    background: white;
    padding: 3px 8px;
    border-radius: 4px;
}

.sf-dash-live-content {
    padding: 16px;
}

.sf-dash-mini-hero {
    background: linear-gradient(135deg, var(--sf-accent, #10b981), color-mix(in srgb, var(--sf-accent, #10b981), black 25%));
    border-radius: 8px;
    padding: 20px 16px;
    text-align: center;
    margin-bottom: 12px;
    color: white;
}

.sf-dash-mini-hero .mini-type {
    font-size: 0.5rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    opacity: 0.7;
    margin-bottom: 4px;
}

.sf-dash-mini-hero .mini-name {
    font-size: 0.9rem;
    font-weight: 800;
}

.sf-dash-mini-hero .mini-tagline {
    font-size: 0.6rem;
    opacity: 0.8;
    font-style: italic;
}

.sf-dash-mini-products {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 8px;
}

.sf-dash-mini-prod {
    text-align: center;
}

.sf-dash-mini-prod-img {
    width: 100%;
    aspect-ratio: 1;
    border-radius: 8px;
    background: #e8d5be;
    margin-bottom: 4px;
}

.sf-dash-mini-prod-img.v { background: #f3e0c4; }
.sf-dash-mini-prod-img.p { background: #f5d0d0; }
.sf-dash-mini-prod-img.s { background: #d4e8d0; }

.sf-dash-mini-prod .bar {
    height: 4px;
    border-radius: 2px;
    background: #d2d2d7;
    margin-bottom: 3px;
}

.sf-dash-mini-prod .bar.short {
    width: 60%;
    background: #e5e7eb;
}


/* ==========================================================================
   MOCKUP UPGRADE — Dashboard Template Selector
   ========================================================================== */

.sf-dash-templates {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
}

.sf-dash-template {
    position: relative;
    border: 2px solid #e5e7eb;
    border-radius: 12px;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.2s;
}

.sf-dash-template:hover {
    border-color: var(--sf-accent, #10b981);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

.sf-dash-template.selected {
    border-color: var(--sf-accent, #10b981);
    box-shadow: 0 0 0 3px rgba(16,185,129,0.15);
}

.sf-dash-template-preview {
    height: 80px;
    position: relative;
}

.sf-dash-template-preview.bakery { background: linear-gradient(135deg, #f3e8d8, #d4a574); }
.sf-dash-template-preview.restaurant { background: linear-gradient(135deg, #1d1d1f, #424245); }
.sf-dash-template-preview.boutique { background: linear-gradient(135deg, #f5f5f7, #e8e8ed); }
.sf-dash-template-preview.artisan { background: linear-gradient(135deg, #d4c4a8, #8b7355); }

.sf-dash-template-info {
    padding: 8px 10px;
    text-align: center;
}

.sf-dash-template-info h4 {
    font-size: 0.75rem;
    font-weight: 700;
    color: #111827;
    margin: 0;
}

.sf-dash-template-info p {
    font-size: 0.625rem;
    color: #6b7280;
    margin: 2px 0 0;
}

.sf-dash-template .check-badge {
    position: absolute;
    top: 6px;
    right: 6px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--sf-accent, #10b981);
    color: white;
    display: none;
    align-items: center;
    justify-content: center;
    font-size: 0.625rem;
    font-weight: 700;
    z-index: 1;
}

.sf-dash-template.selected .check-badge {
    display: flex;
}

@media (max-width: 768px) {
    .sf-dash-grid { grid-template-columns: 1fr; }
    .sf-dash-templates { grid-template-columns: repeat(2, 1fr); }
    .sf-dash-order-detail { display: none; }
}


/* ==========================================================================
   MOCKUP UPGRADE — Product Card Hover Add Button Enhancement
   ========================================================================== */

.sf-product-add-btn {
    position: absolute;
    bottom: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: white;
    border: none;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--sf-accent);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(0,0,0,0.12);
    opacity: 0;
    transform: scale(0.8);
    transition: all 0.25s var(--sf-ease);
    z-index: 2;
}

.sf-product-card:hover .sf-product-add-btn {
    opacity: 1;
    transform: scale(1);
}

.sf-product-add-btn:hover {
    background: var(--sf-accent);
    color: white;
    transform: scale(1.1) !important;
}

/* ===========================================================================
   Galerie multi-images produit (storefront public)
   Apparaît sous le hero quand le produit a des images secondaires
   =========================================================================== */
.sf-detail-gallery {
    display: flex;
    gap: 8px;
    padding: 12px 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    background: var(--sf-bg, #fff);
}
.sf-detail-gallery::-webkit-scrollbar { height: 4px; }
.sf-detail-gallery::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.15); border-radius: 2px; }

.sf-detail-gallery__thumb {
    flex-shrink: 0;
    width: 72px;
    height: 72px;
    padding: 0;
    border: 2px solid transparent;
    border-radius: 8px;
    overflow: hidden;
    background: #f3f4f6;
    cursor: pointer;
    transition: border-color 0.15s, transform 0.15s;
    scroll-snap-align: start;
}
.sf-detail-gallery__thumb:hover,
.sf-detail-gallery__thumb:focus-visible {
    border-color: var(--sf-primary, #10b981);
    transform: translateY(-1px);
    outline: none;
}
.sf-detail-gallery__thumb--active {
    border-color: var(--sf-primary, #10b981);
    box-shadow: 0 2px 6px rgba(16,185,129,0.25);
}
.sf-detail-gallery__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Desktop : plus grand + fond neutre */
@media (min-width: 768px) {
    .sf-detail-gallery {
        justify-content: center;
        padding: 16px 24px;
    }
    .sf-detail-gallery__thumb {
        width: 88px;
        height: 88px;
    }
}

/* ===========================================================================
   Lightbox — overlay plein écran pour zoomer l'image produit
   =========================================================================== */
.sf-detail-hero-img[data-action="sf-lightbox-open"] {
    cursor: zoom-in;
}

.sf-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.92);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    padding: 24px;
    opacity: 0;
    transition: opacity 0.2s ease;
}
.sf-lightbox--open {
    display: flex;
    opacity: 1;
}

.sf-lightbox__img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
    border-radius: 4px;
    cursor: zoom-out;
    user-select: none;
    -webkit-user-drag: none;
}

.sf-lightbox__close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 44px;
    height: 44px;
    background: rgba(255, 255, 255, 0.12);
    border: none;
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s;
    z-index: 10;
}
.sf-lightbox__close:hover { background: rgba(255, 255, 255, 0.25); }

.sf-lightbox__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 52px;
    height: 52px;
    background: rgba(255, 255, 255, 0.1);
    border: none;
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s;
    z-index: 10;
}
.sf-lightbox__nav:hover { background: rgba(255, 255, 255, 0.22); }
.sf-lightbox__nav--prev { left: 16px; }
.sf-lightbox__nav--next { right: 16px; }

.sf-lightbox__counter {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    padding: 6px 14px;
    background: rgba(255, 255, 255, 0.15);
    color: #fff;
    font-size: 0.8125rem;
    font-weight: 500;
    border-radius: 999px;
    letter-spacing: 0.03em;
    z-index: 10;
}

@media (max-width: 640px) {
    .sf-lightbox { padding: 12px; }
    .sf-lightbox__close { top: 10px; right: 10px; width: 40px; height: 40px; }
    .sf-lightbox__nav {
        /* Sur mobile, navs plus petits + repositionnés (plus de place pour l'image) */
        width: 40px; height: 40px;
        top: auto; bottom: 16px; transform: none;
    }
    .sf-lightbox__nav--prev { left: 16px; }
    .sf-lightbox__nav--next { right: 16px; left: auto; }
    .sf-lightbox__counter { bottom: 70px; }
}

/* ===========================================================================
   Variant picker sur produit_detail (.sf-variant-picker-*)
   Dropdowns tailles / couleurs / formats — sélection progressive avec
   disabled states pour les combinaisons non disponibles
   =========================================================================== */

.sf-variant-picker {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 16px 0;
    margin-bottom: 16px;
    border-top: 1px solid var(--sf-border, #e5e7eb);
    border-bottom: 1px solid var(--sf-border, #e5e7eb);
}

.sf-variant-picker__group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.sf-variant-picker__label {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--sf-text-muted, #6b7280);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.sf-variant-picker__options {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.sf-variant-picker__option {
    padding: 8px 14px;
    min-width: 44px;
    background: #fff;
    border: 1px solid var(--sf-border, #e5e7eb);
    border-radius: 6px;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--sf-text, #111827);
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s, color 0.15s;
    font-family: inherit;
    line-height: 1;
}

.sf-variant-picker__option:hover:not(:disabled) {
    border-color: var(--sf-primary, #10b981);
}

.sf-variant-picker__option--active {
    background: var(--sf-primary, #10b981);
    border-color: var(--sf-primary, #10b981);
    color: #fff;
}

.sf-variant-picker__option--unavailable,
.sf-variant-picker__option:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    text-decoration: line-through;
    text-decoration-color: rgba(0, 0, 0, 0.3);
}

.sf-variant-picker__status {
    font-size: 0.8125rem;
    color: var(--sf-text-muted, #6b7280);
    padding: 6px 0;
    font-style: italic;
    min-height: 1.4em;
}
