/* =============================================================================
   GiftKorner — consolidated storefront + admin styles
   Generated sources: merge_blade_css.py — edit Blade/CSS workflow, then re-run.
   ============================================================================= */



/* ----- partials/typography-system.blade.php block 1 ----- */

:root {
        --font-sans: 'Inter', sans-serif;
        --font-display: 'Poppins', sans-serif;
        --font-weight-regular: 400;
        --font-weight-medium: 500;
        --font-weight-semibold: 600;
        --font-weight-bold: 700;
        --font-weight-extrabold: 800;
        --line-height-body: 1.5;
        --line-height-heading: 1.2;
        --line-height-compact: 1.4;
        --text-xs: 0.75rem;
        --text-sm: 0.875rem;
        --text-base: 1rem;
        --text-lg: 1.125rem;
        --text-xl: 1.25rem;
        --text-2xl: 1.5rem;
        --tracking-tight: -0.03em;
        --tracking-wide: 0.08em;
        --bs-body-font-family: var(--font-sans);
        --bs-font-sans-serif: var(--font-sans);
        --bs-body-line-height: var(--line-height-body);
    }

    html {
        font-family: var(--font-sans);
    }

    body {
        font-family: var(--font-sans);
        font-size: var(--text-base);
        line-height: var(--line-height-body);
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }

    h1,
    h2,
    h3,
    h4,
    h5,
    h6,
    .font-display {
        font-family: var(--font-display);
        line-height: var(--line-height-heading);
        letter-spacing: var(--tracking-tight);
    }

    button,
    input,
    optgroup,
    select,
    textarea,
    .btn,
    .dropdown-item,
    .dropdown-header,
    .form-control,
    .form-select,
    .form-label,
    .table,
    .page-link,
    .modal-title,
    .nav-link,
    .badge,
    .alert,
    .card,
    .list-group-item {
        font-family: inherit;
    }

    .ui-kicker {
        font-size: var(--text-xs);
        font-weight: var(--font-weight-bold);
        line-height: var(--line-height-compact);
        letter-spacing: var(--tracking-wide);
        text-transform: uppercase;
    }

    .ui-meta {
        font-size: 0.8125rem;
        font-weight: var(--font-weight-semibold);
        line-height: var(--line-height-compact);
    }

    .ui-code {
        font-family: var(--font-sans);
        font-size: 0.8125rem;
        font-weight: var(--font-weight-semibold);
        line-height: var(--line-height-compact);
        letter-spacing: 0.04em;
    }


/* ----- frontend/layouts/partials/theme-styles.blade.php block 1 ----- */

:root {
        /* Essential Palette - Structured and readable */
        --primary: #000000;
        --primary-dark: #121212;
        --secondary: #1f1f1f;
        --accent: #2563eb; /* Stable blue */
        --accent-strong: #000000;
        
        --text: #171717;
        --text-muted: #525252;
        --text-soft: #737373;
        
        --border: #e5e5e5;
        --border-strong: #d4d4d4;
        
        --bg-light: #ffffff;
        --bg-soft: #ffffff;
        --surface: #ffffff;
        --surface-strong: #f5f5f5;
        
        /* Spacing Scale - Clean Grid */
        --sp-1: 8px;
        --sp-2: 16px;
        --sp-3: 24px;
        --sp-4: 32px;
        --sp-5: 48px;
        --sp-6: 64px;
        --sp-8: 80px;

        /* Stable Radii & Shadows */
        --radius-sm: 6px;
        --radius-md: 8px;
        --radius-lg: 12px;
        --radius-full: 9999px;
        
        --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
        --shadow-md: 0 4px 6px -1px rgba(0,0,0,0.08), 0 2px 4px -1px rgba(0,0,0,0.04);
        --shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -2px rgba(0,0,0,0.05);
        
        --container-max: 1320px;
    }

    * { 
        box-sizing: border-box; 
        -webkit-tap-highlight-color: transparent; 
    }
    html, body {
        overflow-x: hidden !important;
        width: 100% !important;
        position: relative !important;
        max-width: 100vw !important;
    }
    /* Do not set overflow-x on .site-wrapper — paired with body overflow it can clip sticky header dropdowns.
       Horizontal overflow is already constrained on html/body. */
    .site-wrapper {
        width: 100% !important;
        position: relative !important;
        min-width: 0;
    }
    body {
        margin: 0;
        min-height: 100vh;
        font-family: var(--font-sans);
        color: var(--text);
        background: var(--bg-light); /* More intentional background contrast */
        line-height: var(--line-height-body);
        padding-bottom: env(safe-area-inset-bottom);
    }
    
    
    body.body-locked { overflow: hidden; }
    img { max-width: 100%; display: block; }
    a { color: inherit; }
    .container, .container-lg, .container-xl, .container-xxl { max-width: var(--container-max); }

    h1, h2, h3, h4, h5, h6 {
        font-family: var(--font-display);
        color: var(--text);
        letter-spacing: var(--tracking-tight);
    }

    .announcement-bar {
        background: #000000;
        color: #FFFFFF;
        font-size: 0.84rem;
        font-weight: 600;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        border-bottom: 1px solid rgba(255,255,255,0.1);
    }
    .announcement-bar-inner {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 1rem;
        padding: 0.72rem 0;
        flex-wrap: wrap;
    }
    .announcement-bar strong { color: #fff; font-weight: 800; }
    .announcement-link {
        display: inline-flex;
        align-items: center;
        gap: 0.4rem;
        color: #fff;
        text-decoration: none;
        border-bottom: 1px solid rgba(255, 255, 255, 0.35);
    }

    .site-header {
        position: sticky;
        top: 0;
        z-index: 1040;
        background: #ffffff;
        border-bottom: 1px solid var(--border);
        transition: all 0.2s ease;
    }
    .site-header-inner {
        display: grid;
        grid-template-columns: auto 1fr auto;
        align-items: center;
        gap: 1.5rem;
        min-height: 72px;
    }
    
    
    .header-brand-wrap, .checkout-header-meta {
        display: flex;
        align-items: center;
        gap: 0.85rem;
    }
    .header-actions {
        display: flex;
        align-items: center;
    }
    .header-icon-btn, .mobile-nav-toggle, .search-trigger, .search-close {
        width: 44px;
        height: 44px;
        border-radius: var(--radius-sm);
        border: 0;
        background: transparent;
        color: var(--text);
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 0;
        appearance: none;
        -webkit-appearance: none;
        transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    }
    .header-icon-btn:hover,
    .mobile-nav-toggle:hover,
    .search-trigger:hover,
    .search-close:hover {
        background: var(--surface-strong);
        color: var(--primary);
    }
    /* nav-icon-list — exact Vinfur reference style */
    .nav-icon-list {
        display: flex;
        align-items: center;
        justify-content: flex-end;
        gap: 12px;
        list-style: none;
        margin: 0;
        padding: 0;
    }
    .nav-icon-list li {
        display: flex;
        position: relative;
    }
    .nav-icon-item {
        display: flex;
        align-items: center;
        justify-content: center;
        color: var(--text);
        text-decoration: none;
        transition: color 0.3s ease;
        line-height: 1;
        background: transparent;
        border: 0;
        padding: 0;
        cursor: pointer;
    }
    .nav-icon-item svg {
        width: 24px;
        height: 24px;
        display: block;
        fill: currentColor;
    }
    .nav-icon-item:hover {
        color: var(--primary);
    }
    
    .brand-name { font-family: var(--font-display); font-size: 1.4rem; font-weight: 800; color: #000000; letter-spacing: -0.02em; line-height: 1; }
    .brand-tagline { color: #525252; font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; }

    .header-nav {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 0.5rem;
    }
    .nav-item { position: relative; }
    /* Invisible hit-area between trigger and panel so :hover is not lost while moving the pointer */
    .nav-item.mega-item::before {
        content: '';
        position: absolute;
        left: 0;
        right: 0;
        top: 100%;
        height: 14px;
        z-index: 103;
    }
    .nav-link-item, .nav-link-button {
        display: inline-flex;
        align-items: center;
        padding: 0 1rem;
        min-height: 44px;
        color: #000000 !important;
        font-size: 0.95rem;
        font-weight: 600;
        text-decoration: none;
        transition: all 0.2s ease;
        background: transparent;
        border: 0;
        position: relative;
    }
    .nav-link-item::after, .nav-link-button::after {
        content: '';
        position: absolute;
        bottom: 6px;
        left: 1rem;
        right: 1rem;
        height: 2px;
        background: #000000;
        transform: scaleX(0);
        transform-origin: right;
        transition: transform 0.3s ease;
    }
    .nav-link-item:hover, .nav-link-item.active, .nav-link-button:hover {
        background: transparent;
        color: #000000 !important;
    }
    .nav-link-item:hover::after, .nav-link-item.active::after, .nav-link-button:hover::after {
        transform: scaleX(1);
        transform-origin: left;
    }

    .mega-panel {
        position: absolute;
        left: 50%;
        top: calc(100% + 0px);
        width: min(1000px, calc(100vw - 2rem));
        max-width: 100vw;
        transform: translateX(-50%) translateY(8px);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        background: #ffffff;
        border: 1px solid var(--border);
        border-radius: var(--radius-md);
        box-shadow: var(--shadow-lg);
        z-index: 105;
        transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
    }
    .nav-item:hover .mega-panel {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: translateX(-50%) translateY(0);
    }
    .nav-item.mega-item:hover .mega-panel {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: translateX(-50%) translateY(0);
    }
    .mega-panel-inner {
        display: grid;
        grid-template-columns: minmax(0, 1fr) 280px;
        gap: 1.2rem;
    }
    .mega-grid {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.9rem;
    }
    .mega-group {
        padding: 1rem;
        border-radius: 4px;
        background: #FFFFFF;
        border: 1px solid var(--border);
    }
    .mega-group-title {
        display: inline-flex;
        align-items: center;
        gap: 0.45rem;
        font-family: var(--font-display);
        font-size: 1rem;
        font-weight: 700;
        text-decoration: none;
        margin-bottom: 0.65rem;
    }
    .mega-group-count {
        font-size: 0.76rem;
        color: var(--text-soft);
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        margin-bottom: 0.75rem;
    }
    .mega-links { display: grid; gap: 0.45rem; }
    .mega-links a {
        display: inline-flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        padding: 0.58rem 0.75rem;
        border-radius: 14px;
        text-decoration: none;
        color: var(--text-muted);
        font-weight: 700;
        transition: background 0.2s ease, color 0.2s ease;
    }
    .mega-links a:hover { background: rgba(31, 93, 80, 0.08); color: var(--primary); }
    .mega-feature {
        border-radius: var(--radius-md);
        padding: 2.5rem;
        background: var(--primary);
        color: #fff;
        min-height: 100%;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    .mega-feature-label {
        font-size: 0.78rem;
        font-weight: 800;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        color: rgba(255, 255, 255, 0.62);
    }
    .mega-feature-title { font-size: 1.45rem; font-weight: 700; color: #fff; margin: 0.6rem 0; }
    .mega-feature p { margin: 0; font-size: 0.92rem; line-height: 1.7; }
    .mega-feature a { display: inline-flex; align-items: center; gap: 0.5rem; color: #fff; text-decoration: none; font-weight: 700; margin-top: 1.2rem; }

    .header-icon-btn,
    .mobile-nav-toggle,
    .search-trigger,
    .search-close {
        position: relative;
        text-decoration: none;
        flex-shrink: 0;
    }
    .header-icon-btn i,
    .mobile-nav-toggle i,
    .search-trigger i,
    .search-close i {
        font-size: 1.15rem;
        line-height: 1;
    }
    /* action-count — exact Vinfur reference badge style */
    .action-count {
        width: 16px;
        height: 16px;
        border-radius: 50%;
        background: #111111;
        position: absolute;
        top: -5px;
        right: -7px;
        font-weight: 500;
        font-size: 11px;
        line-height: 16px;
        color: #ffffff;
        display: flex;
        align-items: center;
        justify-content: center;
        pointer-events: none;
        letter-spacing: 0;
    }

    .checkout-header {
        min-height: 84px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1.5rem;
    }

    .hero-meta-chip, .eyebrow-pill, .status-pill, .section-eyebrow {
        display: inline-flex;
        align-items: center;
        gap: 0.45rem;
        padding: 0.55rem 0.95rem;
        border-radius: 4px;
        font-size: 0.78rem;
        font-weight: 800;
        letter-spacing: 0.06em;
        text-transform: uppercase;
    }
    .eyebrow-pill, .status-pill, .section-eyebrow {
        background: rgba(0, 0, 0, 0.05);
        color: var(--primary);
    }
    .hero-meta-chip {
        background: rgba(255, 255, 255, 0.85);
        border: 1px solid var(--border);
        color: var(--text-muted);
        text-transform: none;
        letter-spacing: 0;
        font-size: 0.82rem;
        font-weight: 700;
    }

    .drawer-backdrop, .overlay-backdrop, .cart-overlay {
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.48);
        backdrop-filter: blur(10px);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        z-index: 1060;
        transition: all 0.3s ease;
    }
    .drawer-backdrop.is-open, .overlay-backdrop.is-open, .cart-overlay.is-open {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }

    .search-overlay {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        background: #ffffff;
        z-index: 2000;
        transform: translateY(-100%);
        transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.4s ease;
        opacity: 0;
        visibility: hidden;
        border-bottom: 1px solid var(--border);
        max-height: 100vh;
        overflow-y: auto;
    }
    .search-overlay.is-open {
        transform: translateY(0);
        opacity: 1;
        visibility: visible;
    }
    .search-overlay-container {
        max-width: var(--container-max);
        margin: 0 auto;
        padding: 0 var(--sp-2);
    }
    .search-overlay-header {
        padding: var(--sp-4) 0;
        border-bottom: 1px solid #eeeeee;
    }
    .search-input-row {
        display: flex;
        align-items: center;
        gap: 1.5rem;
        position: relative;
    }
    .search-input-icons {
        font-size: 1.5rem;
        color: var(--text);
        display: flex;
        align-items: center;
    }
    .search-overlay-form {
        flex: 1;
    }
    .search-overlay-form input {
        width: 100%;
        border: 0;
        outline: 0;
        font-family: var(--font-display);
        font-size: 1.5rem;
        font-weight: 500;
        color: var(--text);
        background: transparent;
        padding: 0.5rem 0;
    }
    .search-overlay-form input::placeholder {
        color: #999999;
    }
    .search-overlay-close {
        background: transparent;
        border: 0;
        font-size: 1.2rem;
        color: var(--text);
        cursor: pointer;
        padding: 0.5rem;
        transition: color 0.2s ease;
    }
    .search-overlay-close:hover {
        color: var(--primary);
    }
    .search-overlay-body {
        padding: var(--sp-5) 0 var(--sp-6);
    }
    .search-section-title {
        font-family: var(--font-display);
        font-size: 1.15rem;
        font-weight: 700;
        margin-bottom: 1.8rem;
        color: #000000;
        text-transform: capitalize;
    }
    .search-quick-links {
        list-style: none;
        padding: 0;
        margin: 0;
    }
    .search-quick-links li {
        margin-bottom: 1rem;
    }
    .search-quick-links a {
        font-size: 1rem;
        font-weight: 500;
        color: var(--text-muted);
        text-decoration: none;
        transition: color 0.2s ease;
    }
    .search-quick-links a:hover {
        color: var(--primary);
    }
    .search-suggestions-grid {
        display: grid;
        gap: 1.25rem;
    }
    .search-suggestion-item {
        display: flex;
        align-items: center;
        text-decoration: none;
        color: inherit;
        transition: transform 0.2s ease;
    }
    .search-suggestion-item:hover {
        transform: translateX(4px);
    }
    .suggestion-thumb {
        width: 80px;
        height: 80px;
        flex-shrink: 0;
        border-radius: 4px;
        overflow: hidden;
        background: var(--surface-strong);
        margin-right: 1.25rem;
    }
    .suggestion-thumb img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .thumb-placeholder {
        width: 100%;
        height: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        color: var(--text-soft);
        font-size: 1.5rem;
    }
    .suggestion-info {
        min-width: 0;
    }
    .suggestion-name {
        font-size: 1rem;
        font-weight: 600;
        margin: 0 0 0.35rem;
        color: var(--text);
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .suggestion-price {
        display: flex;
        align-items: center;
        gap: 0.75rem;
    }
    .price-current {
        font-weight: 700;
        color: var(--primary);
    }
    .price-old {
        font-size: 0.9rem;
        color: var(--text-soft);
        text-decoration: line-through;
    }

    

    .drawer-backdrop { 
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.48);
        backdrop-filter: blur(10px);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        z-index: 1060;
        transition: all 0.3s ease;
    }
    .drawer-backdrop.is-open {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }

    .mobile-drawer {
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        width: 320px;
        max-width: 85vw;
        background: #ffffff;
        z-index: 2000;
        transform: translateX(-100%);
        transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
        display: flex;
        flex-direction: column;
        box-shadow: 20px 0 50px rgba(0,0,0,0.15);
        border-right: 0;
    }
    .mobile-drawer.is-open { transform: translateX(0); }
    
    .mobile-drawer-header { 
        padding: 1.25rem 1.5rem; 
        border-bottom: 1.5px solid var(--border); 
        display: flex; 
        align-items: center; 
        justify-content: space-between;
        min-height: 72px;
    }
    
    .mobile-drawer-body {
        flex: 1;
        overflow-y: auto;
        padding-bottom: 40px;
    }

    .mobile-drawer-section {
        padding: 1.5rem;
        border-bottom: 1px solid var(--border);
    }
    .mobile-drawer-section:last-child { border-bottom: 0; }

    .mobile-nav-links {
        display: grid;
        gap: 4px;
    }
    .mobile-nav-links a {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 0.85rem 1rem;
        border-radius: var(--radius-md);
        text-decoration: none;
        color: var(--text);
        font-size: 1.05rem;
        font-weight: 700;
        transition: all 0.2s ease;
    }
    .mobile-nav-links a:hover, .mobile-nav-links a.active {
        background: var(--surface-strong);
        transform: translateX(4px);
    }
    .mobile-nav-links a i {
        font-size: 0.8rem;
        color: var(--text-soft);
        opacity: 0.5;
    }

    .mobile-action-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 0.75rem;
        margin-top: 1rem;
    }
    .mobile-action-btn {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 0.85rem 1rem;
        border-radius: var(--radius-md);
        background: var(--surface-strong);
        text-decoration: none;
        font-weight: 700;
        color: var(--text);
        font-size: 0.9rem;
        border: 1.5px solid transparent;
        transition: all 0.2s ease;
    }
    .mobile-action-btn:hover { border-color: var(--border-strong); }
    .mobile-action-btn span { display: flex; align-items: center; gap: 0.6rem; }
    .mobile-action-count {
        width: 18px;
        height: 18px;
        border-radius: 50%;
        background: var(--primary);
        color: #fff;
        font-size: 10px;
        font-weight: 700;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
    }

    .mobile-drawer-section-title {
        font-size: 0.72rem;
        font-weight: 800;
        text-transform: uppercase;
        letter-spacing: 0.12em;
        color: var(--text-soft);
        margin-bottom: 1.25rem;
        display: block;
    }

    .mobile-category-list {
        display: grid;
        gap: 2px;
    }
    .mobile-category-item {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 0.75rem 0.75rem;
        text-decoration: none;
        color: var(--text);
        font-weight: 600;
        font-size: 0.95rem;
        border-bottom: 1px solid rgba(0,0,0,0.03);
    }
    .mobile-category-item:last-child { border-bottom: 0; }
    .mobile-category-item .count {
        color: var(--text-soft);
        font-size: 0.78rem;
        font-weight: 700;
        background: var(--surface-strong);
        padding: 2px 8px;
        border-radius: 6px;
    }

    .flash-stack { padding-top: 0; }
    .flash-banner {
        display: flex;
        align-items: center;
        gap: 0.8rem;
        padding: 1rem 1.15rem;
        margin-top: 1.5rem;
        border-radius: var(--radius-md);
        border: 1.2px solid var(--border-strong);
        background: rgba(255, 255, 255, 0.96);
        box-shadow: var(--shadow-md);
        margin-bottom: 0.85rem;
    }
    .flash-banner.is-success { border-color: var(--border-strong); color: #000; }
    .flash-banner.is-danger { border-color: var(--border-strong); color: #000; }
    .flash-banner .btn-close { margin-left: auto; }

    .page-hero {
        padding: clamp(1.5rem, 3vw, 2.5rem) 0;
        background: transparent;
    }
    .page-hero-shell {
        background: #fff;
        border: 1px solid var(--border);
        border-radius: var(--radius-lg);
        padding: var(--sp-6) var(--sp-4);
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        box-shadow: var(--shadow-md);
    }
    .page-hero-inner {
        display: grid;
        gap: 1.25rem;
        justify-items: center;
    }
    .page-hero-title {
        margin: 0.55rem 0 0;
        font-size: clamp(2rem, 5vw, 3.2rem);
        line-height: 1.1;
        max-width: 20ch;
        color: var(--text);
    }
    .page-hero-subtitle {
        max-width: 60ch;
        margin: 0.9rem 0 0;
        font-size: 1.05rem;
        color: var(--text-muted);
    }
    .section-heading {
        display: flex;
        align-items: flex-end;
        justify-content: space-between;
        gap: 1.5rem;
        margin-bottom: 2rem;
    }
    .section-heading.is-centered { justify-content: center; text-align: center; }
    .section-heading.is-centered .section-link { display: none; }
    .section-title {
        margin: 0.75rem 0 0;
        font-size: clamp(1.9rem, 4vw, 3rem);
        line-height: 1.05;
    }
    .section-subtitle {
        margin: 0.7rem 0 0;
        color: var(--text-muted);
        max-width: 60ch;
        font-size: 0.98rem;
    }
    .section-link {
        background: #fff;
        border: 1px solid var(--border);
        color: var(--text);
        box-shadow: var(--shadow-sm);
        white-space: nowrap;
    }

    .surface-card, .card {
        background: #ffffff;
        border: 1px solid var(--border);
        border-radius: 4px;
        box-shadow: var(--shadow-sm);
    }
    .surface-muted {
        background: var(--bg-soft);
        border: 1px solid var(--border);
        border-radius: 4px;
    }

    .btn {
        border-radius: var(--radius-sm);
        font-weight: 600;
        padding: 0.9rem 2.2rem;
        font-size: 0.92rem;
        border-width: 1.5px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 0.5rem;
        transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
        cursor: pointer;
    }
    .btn:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
    .btn:active { transform: translateY(0); }
    .btn-primary {
        background: var(--primary);
        border-color: var(--primary);
        color: #fff;
    }
    .btn-primary:hover { background: var(--primary-dark); border-color: var(--primary-dark); }
    .btn-outline-primary {
        color: var(--primary);
        border-color: var(--primary);
        background: transparent;
    }
    .btn-outline-primary:hover { background: var(--surface-strong); color: var(--primary); }
    .btn-light {
        background: #fff;
        border-color: #fff;
        color: var(--primary);
        box-shadow: var(--shadow-sm);
    }
    .btn-light:hover { background: var(--surface-strong); border-color: var(--surface-strong); }

    .form-control, .form-select, textarea.form-control {
        min-height: 52px;
        border-radius: var(--radius-sm);
        border: 1.5px solid var(--border-strong);
        background: #fff;
        padding: 0.75rem 1.25rem;
        color: var(--text);
        font-weight: 500;
        font-size: 0.95rem;
        transition: all 0.2s ease;
    }
    .form-control:focus, .form-select:focus {
        border-color: var(--primary);
        box-shadow: 0 0 0 4px rgba(0, 0, 0, 0.04);
        outline: none;
    }

    /* ── Input Group Fix — Seamless Unity (Nuclear Fix) ──────── */
    .input-group {
        border: 1.5px solid var(--border-strong) !important;
        border-radius: var(--radius-sm) !important;
        background: #fff !important;
        overflow: hidden !important;
        display: flex !important;
        align-items: stretch !important;
        gap: 0 !important;
        transition: all 0.2s ease !important;
    }
    .input-group > * {
        border: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        border-radius: 0 !important;
        margin: 0 !important;
        outline: none !important;
        min-height: 52px !important;
    }
    .input-group .input-group-text {
        padding-left: 1.15rem;
        padding-right: 0.65rem;
        color: var(--text-soft);
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .input-group .form-control {
        padding-left: 0.5rem;
    }
    .input-group:focus-within {
        border-color: #000000 !important;
        box-shadow: 0 0 0 4px rgba(0, 0, 0, 0.04) !important;
    }
    /* Client-side validation: inner .form-control/.form-select gets .is-invalid; border lives on .input-group */
    .input-group:has(.form-control.is-invalid),
    .input-group:has(.form-select.is-invalid) {
        border-color: #dc3545 !important;
        box-shadow: none !important;
    }
    /* Handle eye icons and other buttons inside groups */
    .input-group .btn-group-text, .input-group button {
        padding-right: 1.15rem;
        padding-left: 0.65rem;
    }
    .form-label {
        font-size: 0.82rem;
        font-weight: 700;
        color: var(--text);
        margin-bottom: 0.6rem;
        display: block;
    }
    .form-check-input { width: 20px; height: 20px; border-radius: 6px; border: 2px solid var(--border-strong); cursor: pointer; }
    .form-check-input:checked { background-color: var(--primary); border-color: var(--primary); }

    .alert { border-radius: 18px; border-color: transparent; }
    /* ── Unified Store Breadcrumb — VinFur style ─────────────── */
    .store-breadcrumb {
        background: #f7f6f5;
        border-bottom: 1px solid #ebebeb;
        padding: 2.5rem 0;
        text-align: center;
    }
    .store-breadcrumb-inner {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 0.625rem;
    }
    .store-breadcrumb-title {
        font-family: var(--font-display);
        font-size: clamp(1.5rem, 3vw, 2.125rem);
        font-weight: 700;
        color: var(--text);
        margin: 0;
        letter-spacing: -0.02em;
        line-height: 1.2;
    }
    .store-breadcrumb-nav { display: block; }
    .store-breadcrumb-list {
        display: inline-flex;
        align-items: center;
        flex-wrap: wrap;
        justify-content: center;
        list-style: none;
        margin: 0;
        padding: 0;
        gap: 0;
    }
    .store-breadcrumb-item {
        display: inline-flex;
        align-items: center;
        font-size: 0.8125rem;
        font-weight: 400;
        color: #999;
        line-height: 1;
    }
    .store-breadcrumb-item a {
        color: #999;
        text-decoration: none;
        transition: color 0.18s ease;
    }
    .store-breadcrumb-item a:hover { color: var(--text); }
    .store-breadcrumb-sep {
        font-size: 0.75rem;
        color: #ccc;
        margin: 0 0.5rem;
        font-weight: 300;
    }
    .store-breadcrumb-item.active {
        color: #555;
        font-weight: 500;
    }
    
    /* Legacy breadcrumb kept for account sidebar only */
    .breadcrumb-nav { margin-bottom: 2rem; }
    .breadcrumb {
        display: inline-flex;
        align-items: center;
        flex-wrap: wrap;
        margin: 0;
        padding: 0.5rem 1rem;
        background: transparent;
        border: 0;
        list-style: none;
    }
    .breadcrumb-item {
        display: flex;
        align-items: center;
        font-size: 0.82rem;
        font-weight: 500;
        color: var(--text-soft);
    }
    .breadcrumb-item a {
        color: var(--text-soft);
        text-decoration: none;
        transition: color 0.2s ease;
    }
    .breadcrumb-item a:hover { color: var(--primary); }
    .breadcrumb-item.active { color: var(--text); font-weight: 600; }
    .breadcrumb-item + .breadcrumb-item::before {
        content: '›';
        font-size: 0.9rem;
        color: #bbb;
        margin: 0 0.4rem;
    }
    .table { --bs-table-bg: transparent; --bs-table-border-color: var(--border); }
    .page-link {
        border-radius: var(--radius-sm) !important;
        border-color: var(--border);
        color: var(--text);
        font-weight: 600;
        padding: 0.8rem 1.2rem;
        margin: 0 0.25rem;
        transition: all 0.2s ease;
    }
    .page-link:hover { background: var(--surface-strong); border-color: var(--border-strong); }
    .active > .page-link, .page-link.active { background: var(--primary); border-color: var(--primary); color: #fff; }

    .toast-container {
        position: fixed;
        right: 1.25rem;
        bottom: 1.25rem;
        z-index: 1100;
        display: grid;
        gap: 0.7rem;
    }
    .toast-card {
        display: flex;
        align-items: center;
        gap: 0.8rem;
        min-width: 280px;
        max-width: 400px;
        padding: 1.25rem;
        border-radius: var(--radius-md);
        background: var(--primary);
        color: #fff;
        box-shadow: var(--shadow-lg);
        font-weight: 600;
    }

    .product-card {
        height: 100%;
        display: flex;
        flex-direction: column;
        border-radius: var(--radius-lg);
        overflow: hidden;
        background: #fff;
        border: 1px solid var(--border);
        transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
        cursor: pointer;
    }
    .product-card:hover {
        transform: translateY(-4px);
        box-shadow: var(--shadow-md);
        border-color: var(--border-strong);
    }
    .product-card-media {
        position: relative;
        isolation: isolate;
        aspect-ratio: 0.88;
        overflow: hidden;
        background: #f8f9fa;
        border-bottom: 1px solid var(--border);
    }
    .product-card-media img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 0.45s ease;
    }
    .product-card:hover .product-card-media img { transform: scale(1.06); }
    .product-card-top,
    .product-card-hover {
        position: absolute;
        left: 0;
        right: 0;
        padding: 1rem;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.6rem;
        z-index: 2;
    }
    .product-card-top { top: 0; }
    .product-card-hover {
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.04);
        display: flex;
        align-items: center;
        justify-content: center;
        opacity: 0;
        transition: all 0.3s ease;
        z-index: 2;
    }
    .product-card:hover .product-card-hover {
        opacity: 1;
    }
    .product-card-badge {
        display: inline-flex;
        align-items: center;
        gap: 0.35rem;
        padding: 0.5rem 0.85rem;
        border-radius: 999px;
        font-size: 0.74rem;
        font-weight: 800;
        letter-spacing: 0.05em;
        text-transform: uppercase;
        background: #111111;
        color: #ffffff;
        box-shadow: 0 4px 10px rgba(0,0,0,0.1);
        border: none;
    }
    .product-card-badge.is-sale { background: #ef4444; color: #ffffff; }
    .product-card-badge.is-new { background: #3b82f6; color: #ffffff; }
    .product-card-badge.is-hot { background: #f59e0b; color: #ffffff; }
    .product-card-icon {
        width: 42px;
        height: 42px;
        border-radius: 50%;
        border: 1px solid rgba(255, 255, 255, 0.5);
        background: rgba(255, 255, 255, 0.92);
        color: var(--text);
        display: inline-flex;
        align-items: center;
        justify-content: center;
        text-decoration: none;
        box-shadow: var(--shadow-sm);
    }
    .product-card-actions {
        display: flex;
        gap: 0.55rem;
        margin-left: auto;
    }
    .product-card-body {
        padding: 1.15rem 1.15rem 1.2rem;
        display: flex;
        flex-direction: column;
        gap: 0.8rem;
        flex: 1;
    }
    .product-card-meta {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.8rem;
        color: var(--text-soft);
        font-size: 0.76rem;
        font-weight: 800;
        letter-spacing: 0.08em;
        text-transform: uppercase;
    }
    .product-card-title {
        margin: 0;
        font-size: 1rem;
        font-weight: 700;
        line-height: 1.4;
    }
    .product-card-title a {
        color: var(--text);
        text-decoration: none;
    }
    /* ── Mobile Product Card — App-like compact style ──────── */
    
    .product-card-title a:hover { color: var(--primary); }
    .product-card-rating {
        display: flex;
        align-items: center;
        gap: 0.45rem;
        color: var(--text-soft);
        font-size: 0.84rem;
        font-weight: 700;
    }
    .product-card-stars {
        color: #000000;
        display: inline-flex;
        gap: 0.12rem;
    }
    .product-card-price {
        display: flex;
        align-items: baseline;
        gap: 0.55rem;
        flex-wrap: wrap;
    }
    .product-card-price-current,
    .product-card-price-sale {
        font-size: 1.15rem;
        font-weight: 800;
        letter-spacing: -0.03em;
    }
    .product-card-price-sale { color: #000000; }
    .product-card-price-old {
        color: var(--text-soft);
        text-decoration: line-through;
        font-size: 0.92rem;
        font-weight: 700;
    }
    .product-card-footer {
        display: grid;
        grid-template-columns: minmax(0, 1fr);
        gap: 0.6rem;
        margin-top: auto;
    }
    .product-card-footer.has-secondary {
        grid-template-columns: minmax(0, 1fr) 48px;
    }
    .product-card-cta {
        min-height: 40px;
        border: 0;
        border-radius: 4px;
        background: var(--primary);
        color: #fff;
        font-weight: 700;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 0.45rem;
        width: 100%;
        padding: 0 1rem;
        box-shadow: 0 1px 2px 0 rgba(0,0,0,0.1);
    }
    .product-card-cta:disabled {
        opacity: 0.55;
        cursor: not-allowed;
        box-shadow: none;
    }
    .product-card-secondary {
        min-height: 48px;
        border-radius: 50%;
        border: 1px solid var(--border);
        background: var(--bg-light);
        color: var(--text);
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .cart-overlay { z-index: 1070; }
    .mini-cart {
        position: fixed;
        top: 0;
        right: 0;
        width: min(430px, 100vw);
        height: 100vh;
        z-index: 1075;
        background: #ffffff;
        transform: translateX(100%);
        box-shadow: var(--shadow-lg);
        display: flex;
        flex-direction: column;
    }
    .mini-cart.is-open { transform: translateX(0); }
    .mini-cart-header, .mini-cart-footer { padding: 1.25rem; border-color: var(--border); }
    .mini-cart-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        border-bottom: 1px solid var(--border);
    }
    .mini-cart-title {
        margin: 0;
        display: flex;
        align-items: center;
        gap: 0.7rem;
        font-size: 1.1rem;
        font-weight: 700;
    }
    .mini-cart-items {
        flex: 1;
        overflow-y: auto;
        padding: 1rem 1.25rem;
        display: grid;
        align-content: start;
        gap: 0.9rem;
    }
    .mini-cart-item {
        display: grid;
        grid-template-columns: 84px minmax(0, 1fr) auto;
        gap: 0.95rem;
        align-items: center;
        padding: 0.9rem;
        border: 1px solid var(--border);
        border-radius: var(--radius-md);
        background: var(--bg-soft);
    }
    .mini-cart-item-name { font-size: 0.95rem; font-weight: 800; }
    .mini-cart-item-variant, .mini-cart-item-meta { font-size: 0.8rem; color: var(--text-soft); }
    .mini-cart-item-price { color: var(--primary); font-weight: 800; font-size: 0.95rem; }
    .mini-cart-remove {
        width: 40px;
        height: 40px;
        border-radius: 50%;
        border: 1px solid var(--border);
        background: #fff;
        color: var(--text-soft);
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }
    .mini-cart-total {
        display: flex;
        justify-content: space-between;
        align-items: center;
        font-weight: 800;
        margin-bottom: 1rem;
    }

    .site-footer { margin-top: var(--sp-8); padding: var(--sp-4) 0; }
    .footer-shell {
        background: var(--primary);
        padding: var(--sp-6);
        color: rgba(255, 255, 255, 0.7);
        border-radius: var(--radius-lg);
    }
    .footer-newsletter {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        gap: 2.5rem;
        padding: var(--sp-4);
        border-radius: var(--radius-md);
        background: rgba(255, 255, 255, 0.04);
        border: 1px solid rgba(255, 255, 255, 0.06);
        margin-bottom: var(--sp-5);
    }
    .footer-newsletter h3 { color: #fff; margin: 0.4rem 0; font-size: clamp(1.5rem, 3vw, 2.3rem); }
    .footer-newsletter p { margin: 0; max-width: 54ch; }
    .footer-newsletter-form {
        display: grid;
        grid-template-columns: 1fr auto;
        gap: 0.75rem;
        align-items: stretch;
    }
    .footer-newsletter-form input {
        height: 58px;
        border-radius: var(--radius-md);
        border: 1.2px solid rgba(255, 255, 255, 0.15);
        background: rgba(255, 255, 255, 0.08);
        color: #fff;
        padding: 0 1rem;
        font-weight: 700;
    }
    .footer-newsletter-form input::placeholder { color: rgba(255, 255, 255, 0.6); }
    .footer-newsletter-form button {
        height: 58px;
        border-radius: var(--radius-md);
        border: 0;
        padding: 0 1.25rem;
        background: #FFFFFF;
        color: #000000;
        font-weight: 700;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        white-space: nowrap;
        transition: all 0.2s ease;
    }
    .footer-newsletter-form button:hover { opacity: 0.9; transform: translateY(-1px); }
    .footer-grid {
        display: grid;
        grid-template-columns: 1.2fr repeat(4, minmax(0, 1fr));
        gap: 1.25rem;
    }
    .footer-grid > div { padding-bottom: 0.85rem; }
    .footer-brand-title { color: #fff; font-size: 1.35rem; font-weight: 700; margin: 0.85rem 0 0.6rem; }
    .footer-brand-copy { color: rgba(255, 255, 255, 0.7); margin: 0; max-width: 34ch; }
    .footer-social {
        display: flex;
        flex-wrap: wrap;
        gap: 0.65rem;
        margin-top: 1rem;
    }
    .footer-social a {
        width: 42px;
        height: 42px;
        border-radius: var(--radius-sm);
        background: rgba(255, 255, 255, 0.08);
        color: #fff;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        text-decoration: none;
    }
    .footer-title {
        color: #fff;
        font-size: 0.86rem;
        font-weight: 800;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        margin-bottom: 1rem;
    }
    .footer-links { padding: 0; margin: 0; list-style: none; }
    .footer-links li { margin-bottom: 0.45rem; }
    .footer-links li:last-child { margin-bottom: 0; }
    .footer-links a { text-decoration: none; color: rgba(255, 255, 255, 0.72); font-weight: 700; }
    .footer-bottom {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        flex-wrap: wrap;
        margin-top: 1.5rem;
        padding-top: 1.25rem;
        border-top: 1px solid rgba(255, 255, 255, 0.1);
        font-size: 0.84rem;
        color: rgba(255, 255, 255, 0.62);
    }

    .checkout-footer {
        padding: 1.5rem 0 2rem;
        color: var(--text-soft);
        text-align: center;
        font-size: 0.82rem;
    }
    .reveal-on-scroll {
        opacity: 0;
        transform: translateY(28px);
        transition: opacity 0.55s ease, transform 0.55s ease;
    }
    .reveal-on-scroll.is-visible {
        opacity: 1;
        transform: translateY(0);
    }

    
    
    
    
    /* Select2 Monochrome Override */
    .select2-container--default .select2-selection--single {
        border: 0 !important;
        background: transparent !important;
        height: 52px !important;
        padding: 12px 0 0 4px !important;
        font-weight: 800 !important;
        font-size: 0.95rem !important;
        box-shadow: none !important;
    }
    .select2-container--default .select2-selection--single .select2-selection__arrow {
        top: 13px !important;
        right: 4px !important;
    }
    .select2-container--default .select2-selection--single .select2-selection__rendered {
        color: #000 !important;
        padding-left: 12px !important;
    }
    .select2-dropdown {
        border: 1.5px solid #000000 !important;
        border-radius: 4px !important;
        box-shadow: 0 10px 30px rgba(0,0,0,0.1) !important;
        overflow: hidden;
        z-index: 9999 !important;
    }
    .select2-results__option {
        padding: 10px 15px !important;
        font-size: 0.88rem !important;
    }
    .select2-results__option--highlighted[aria-selected] {
        background-color: #000000 !important;
        color: #FFFFFF !important;
    }
    .select2-search--dropdown {
        padding: 10px !important;
    }
    .select2-search--dropdown .select2-search__field {
        border: 1.5px solid #EEEEEE !important;
        border-radius: 4px !important;
        padding: 8px 12px !important;
        outline: none !important;
    }

    /*
     * Tailwind v4 + @source on Blade: any `class="… collapse …"` triggers the `collapse`
     * utility (`visibility: collapse`), which hides Bootstrap Collapse / accordion bodies
     * even when `.show` is present. Restore visibility for Bootstrap’s open / animating states.
     */
    .collapse.show,
    .collapse.collapsing {
        visibility: visible !important;
    }


/* ----- frontend/shop.blade.php block 1 ----- */

/* ============================================================
   SHOP PAGE — VinFur-style premium filter layout
   ============================================================ */

/* ── Sidebar filter form ─────────────────────────────────── */
.sf-form {
    font-family: 'Inter', sans-serif;
    max-width: 100%;
    -webkit-font-smoothing: antialiased;
}

/* Applied meta bar */
.sf-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 1.125rem;
    border-bottom: 1px solid #ebebeb;
    margin-bottom: 0;
}
.sf-meta-count {
    font-size: 0.875rem;
    color: #777;
    font-weight: 500;
}
.sf-remove-all {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--text);
    text-decoration: none;
    transition: color 0.18s;
}
.sf-remove-all:hover { color: var(--accent); }

/* Filter group */
.sf-group {
    border-bottom: 1px solid #ebebeb;
}
.sf-group--last { border-bottom: none; }

.sf-group-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
    padding: 1rem 0;
    cursor: pointer;
    user-select: none;
    text-decoration: none;
    color: inherit;
}
.sf-group-title span:first-child {
    flex: 1;
    min-width: 0;
    font-size: 0.8125rem;
    font-weight: 800;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--text);
    line-height: 1.35;
}
.sf-chevron {
    color: var(--text);
    transition: transform 0.22s ease;
    flex-shrink: 0;
}
.sf-group-title.collapsed .sf-chevron {
    transform: rotate(-90deg);
}

/* Filter list */
.sf-list {
    list-style: none;
    padding: 0 0 1.25rem;
    margin: 0;
}
.sf-item {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    margin-bottom: 0.8125rem;
}
.sf-item:last-child { margin-bottom: 0; }

/* Custom checkbox / radio */
.sf-check {
    appearance: none;
    -webkit-appearance: none;
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    border: 1.5px solid #c8c8c8;
    border-radius: 3px;
    background: #fff;
    cursor: pointer;
    display: inline-grid;
    place-content: center;
    transition: background 0.18s ease, border-color 0.18s ease;
}
.sf-check[type="radio"] { border-radius: 50%; }
.sf-check::before {
    content: "";
    width: 10px;
    height: 10px;
    transform: scale(0);
    transition: transform 120ms ease-in-out;
}
.sf-check[type="checkbox"]::before {
    box-shadow: inset 1em 1em #fff;
    clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
}
.sf-check[type="radio"]::before {
    border-radius: 50%;
    box-shadow: inset 1em 1em #fff;
    width: 8px;
    height: 8px;
}
.sf-check:checked {
    background: var(--text);
    border-color: var(--text);
}
.sf-check:checked::before { transform: scale(1); }

/* Filter label */
.sf-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    cursor: pointer;
    gap: 0.5rem;
    margin: 0;
}
.sf-label-text {
    font-size: 0.9375rem;
    color: #404040;
    line-height: 1.5;
    display: flex;
    align-items: center;
    gap: 0.2rem;
    min-width: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
}
.sf-badge {
    color: #777;
    font-size: 0.875rem;
    white-space: nowrap;
}

/* Stars */
.sf-stars {
    display: inline-flex;
    align-items: center;
    gap: 1px;
}
.sf-stars svg { flex-shrink: 0; }

/* Price filter */
.sf-price-body { padding-bottom: 1.25rem; }
.sf-price-row {
    display: flex;
    align-items: flex-end;
    gap: 0.625rem;
}
.sf-price-dash {
    flex-shrink: 0;
    padding-bottom: 0.625rem;
    color: #888;
    font-size: 0.85rem;
}
.sf-price-field {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}
.sf-price-label {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #888;
    margin: 0;
}
.sf-price-input {
    width: 100%;
    height: 42px;
    padding: 0 0.75rem;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
    background: #fff;
    transition: border-color 0.18s;
}
.sf-price-input:focus {
    border-color: var(--text);
    outline: none;
    box-shadow: 0 0 0 3px rgba(0,0,0,0.08);
}
.sf-price-apply {
    display: block;
    width: 100%;
    margin-top: 0.75rem;
    height: 44px;
    background: var(--text);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background 0.2s;
}
.sf-price-apply:hover { background: var(--accent); }

/* ============================================================
   SHOP LAYOUT
   ============================================================ */
.shop-page { padding-bottom: 5rem; }

.shop-row {
    --bs-gutter-x: 3.5rem;
    margin-top: 2rem;
}

/* Sidebar column — wider than default 25% so filters stay readable */

.shop-sidebar-sticky {
    position: sticky;
    top: 108px;
    background: #fff;
    padding: 0 1.25rem 1.25rem 1rem;
    border-right: 1px solid #ebebeb;
    max-width: 100%;
}

/* ============================================================
   SHOP TOOLBAR
   ============================================================ */
.shop-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding-bottom: 1.375rem;
    border-bottom: 1px solid #ebebeb;
    margin-bottom: 1.5rem;
}

/* Left: filter toggle + count */
.shop-toolbar-left {
    display: flex;
    align-items: center;
    gap: 1.25rem;
}
.shop-filter-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: none;
    border: none;
    padding: 0;
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text);
    cursor: pointer;
    transition: color 0.18s;
}
.shop-filter-toggle:hover { color: var(--accent); }
.shop-filter-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--text);
    color: #fff;
    font-size: 0.65rem;
    font-weight: 800;
}
.shop-product-count {
    font-size: 0.82rem;
    color: #777;
    font-weight: 500;
}

/* Center: grid layout switches */
.shop-grid-switches {
    display: flex;
    align-items: center;
    gap: 1.25rem;
}
.shop-grid-switch {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.15rem;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    color: #d0d0d0;
    font-family: 'Playfair Display', serif;
    font-weight: 700;
    font-style: italic;
    font-size: 1.25rem;
    line-height: 1;
    transition: all 0.25s ease;
}
.shop-grid-switch:hover {
    color: #000;
}
.shop-grid-switch.active {
    color: #000;
}
.shop-grid-switch .sw-mark {
    width: 12px;
    height: 1.5px;
    background: #000;
    opacity: 0;
    transform: scaleX(0);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.shop-grid-switch.active .sw-mark {
    opacity: 1;
    transform: scaleX(1);
}

/* Right: sort dropdown */
.shop-sort-wrap {
    display: flex;
    align-items: center;
    gap: 0.625rem;
}
.shop-sort-label {
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.15em;
    color: #999;
    white-space: nowrap;
    text-transform: uppercase;
}
.shop-sort-select {
    display: none !important;
}
/* Nice Select Premium Overhaul */
.shop-sort-wrap .nice-select {
    border: none !important;
    background: transparent !important;
    height: 40px !important;
    line-height: 40px !important;
    padding-left: 0 !important;
    padding-right: 1.5rem !important;
    font-size: 0.8125rem !important;
    font-weight: 800 !important;
    color: #000 !important;
    float: none !important;
    display: inline-flex !important;
    align-items: center !important;
    transition: all 0.3s ease !important;
    border-radius: 0 !important;
}
.shop-sort-wrap .nice-select:after {
    border-bottom: 1.5px solid #000 !important;
    border-right: 1.5px solid #000 !important;
    height: 7px !important;
    width: 7px !important;
    margin-top: -5px !important;
    right: 0 !important;
    transform-origin: center !important;
    transition: all 0.3s ease !important;
}
.shop-sort-wrap .nice-select.open:after {
    transform: rotate(-135deg) !important;
    margin-top: -1px !important;
}
.shop-sort-wrap .nice-select .list {
    border-radius: 16px !important;
    box-shadow: 0 15px 45px rgba(0,0,0,0.12) !important;
    border: 1px solid rgba(0,0,0,0.04) !important;
    margin-top: 12px !important;
    width: auto !important;
    min-width: 200px !important;
    right: 0 !important;
    left: auto !important;
    padding: 8px !important;
    transform: translateY(15px) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    display: block !important;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
    background: #fff !important;
}
.shop-sort-wrap .nice-select.open .list {
    transform: translateY(0) !important;
    opacity: 1 !important;
    visibility: visible !important;
}
.shop-sort-wrap .nice-select .option {
    padding: 10px 16px !important;
    font-size: 0.8125rem !important;
    font-weight: 500 !important;
    border-radius: 10px !important;
    line-height: 1.4 !important;
    color: #555 !important;
    transition: all 0.2s ease !important;
}
.shop-sort-wrap .nice-select .option:hover,
.shop-sort-wrap .nice-select .option.focus,
.shop-sort-wrap .nice-select .option.selected.focus {
    background-color: #f8f8f8 !important;
    color: #000 !important;
    padding-left: 20px !important;
}
.shop-sort-wrap .nice-select .option.selected {
    font-weight: 800 !important;
    color: #000 !important;
    background: transparent !important;
}

/* ── Active filter chips ─────────────────────────────────── */
.shop-active-chips {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
}
.shop-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.42rem 0.85rem;
    border-radius: 999px;
    background: #fff;
    border: 1px solid #ddd;
    color: var(--text);
    font-size: 0.8rem;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.18s;
    white-space: nowrap;
}
.shop-chip:hover {
    background: var(--text);
    border-color: var(--text);
    color: #fff;
}
.shop-chip svg { flex-shrink: 0; }

/* ── Product grid ────────────────────────────────────────── */
.shop-products-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.375rem;
    /* override Bootstrap row/col */
    margin-left: 0 !important;
    margin-right: 0 !important;
}
.shop-products-grid.layout-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.shop-products-grid.layout-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.shop-products-grid.layout-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
/* Collapse Bootstrap col behaviour for grid children */
.shop-products-grid > * {
    padding-left: 0 !important;
    padding-right: 0 !important;
    width: 100% !important;
    max-width: none !important;
    flex: none !important;
}

/* ── Empty state ─────────────────────────────────────────── */
.shop-empty {
    padding: 4.5rem 2rem;
    text-align: center;
    border: 1px solid #eee;
    border-radius: 16px;
    background: #fafafa;
}
.shop-empty i {
    font-size: 3rem;
    color: #bbb;
    display: block;
    margin-bottom: 1rem;
}
.shop-empty h3 {
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
}
.shop-empty p {
    color: #777;
    max-width: 48ch;
    margin: 0 auto 1.5rem;
    font-size: 0.9375rem;
}

/* ── Pagination ──────────────────────────────────────────── */
.shop-pagination {
    margin-top: 3.5rem;
    margin-bottom: 2rem;
}
.shop-pagination > nav {
    width: 100%;
}

/* 1. Hide the ugly mobile-only text block ("Previous" "Next") entirely */
.shop-pagination nav > div.d-sm-none {
    display: none !important;
}

/* 2. Force the desktop numbered pagination block to show on all screens and center it */
.shop-pagination nav > div.d-none.flex-sm-fill {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100%;
}

/* 3. Hide the 'Showing x to y of z results' text to keep it ultra-clean */
.shop-pagination p.text-muted,
.shop-pagination .small.text-muted {
    display: none !important; 
}

/* 4. Style the pagination numbers as minimalist square buttons */
.shop-pagination .pagination {
    margin: 0;
    gap: 0.5rem;
}
.shop-pagination .page-item .page-link,
.shop-pagination .page-item span.page-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    border: 1px solid #ebebeb;
    border-radius: 6px !important; /* Soft corners instead of full circles */
    color: #000;
    font-weight: 700;
    font-size: 0.95rem;
    font-family: 'Inter', sans-serif;
    background: transparent;
    transition: all 0.25s ease;
    box-shadow: none !important;
}
.shop-pagination .page-item.active .page-link,
.shop-pagination .page-item.active span.page-link {
    background: #000;
    color: #fff;
    border-color: #000;
}
.shop-pagination .page-item:not(.active):not(.disabled) .page-link:hover {
    border-color: #000;
    color: #000;
    background: #fafafa;
}
.shop-pagination .page-item.disabled .page-link {
    color: #ccc;
    background: transparent;
    border-color: #f0f0f0;
}
.shop-pagination .page-item:first-child .page-link,
.shop-pagination .page-item:last-child .page-link {
    border-radius: 6px !important; /* Ensure prev/next stay soft square */
}


/* ── Offcanvas overrides ─────────────────────────────────── */
#shopFiltersOffcanvas { max-width: 340px; }
#shopFiltersOffcanvas .offcanvas-header {
    border-bottom: 1px solid #ebebeb;
    padding: 1.25rem 1.5rem;
}
#shopFiltersOffcanvas .offcanvas-title {
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
#shopFiltersOffcanvas .offcanvas-body {
    padding: 0 1.5rem 1.5rem;
    overflow-y: auto;
}
#shopFiltersOffcanvas .sf-meta { padding-top: 1.25rem; }
#shopFiltersOffcanvas .shop-offcanvas-footer {
    padding: 1rem 1.5rem;
    border-top: 1px solid #ebebeb;
}
#shopFiltersOffcanvas .shop-offcanvas-reset {
    display: block;
    width: 100%;
    height: 48px;
    background: var(--text);
    color: #fff;
    border: none;
    border-radius: 10px;
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none;
    text-align: center;
    line-height: 48px;
    cursor: pointer;
    transition: background 0.2s;
}
#shopFiltersOffcanvas .shop-offcanvas-reset:hover { background: var(--accent); }

/* ── Responsive ──────────────────────────────────────────── */


/* ----- frontend/home.blade.php block 1 ----- */

.hero-stage {
        padding: var(--sp-4) 0 var(--sp-2);
    }
    .hero-shell {
        position: relative;
        overflow: hidden;
        border-radius: var(--radius-lg);
        padding: var(--sp-5) var(--sp-4);
        background: var(--primary);
        color: #fff;
    }
    .hero-grid {
        display: grid;
        grid-template-columns: minmax(0, 1.05fr) minmax(300px, 0.95fr);
        gap: 2rem;
        align-items: center;
    }
    .hero-copy {
        position: relative;
        z-index: 1;
        max-width: 640px;
    }
    .hero-title {
        color: #fff;
        font-size: clamp(2.8rem, 6vw, 5.1rem);
        line-height: 0.96;
        margin: 1rem 0 1rem;
        max-width: 10ch;
    }
    .hero-subtitle {
        margin: 0;
        max-width: 56ch;
        font-size: 1.04rem;
        color: rgba(255, 255, 255, 0.74);
    }
    .hero-actions {
        display: flex;
        flex-wrap: wrap;
        gap: 0.85rem;
        margin-top: 1.6rem;
    }
    .hero-stats {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.85rem;
        margin-top: 1.8rem;
    }
    .hero-stat {
        padding: var(--sp-2);
        border-radius: var(--radius-md);
        background: rgba(255, 255, 255, 0.1);
        border: 1px solid rgba(255, 255, 255, 0.1);
    }
    .hero-stat strong {
        display: block;
        color: #fff;
        font-family: 'Poppins', sans-serif;
        font-size: 1.08rem;
        margin-bottom: 0.2rem;
    }
    .hero-stat span {
        color: rgba(255, 255, 255, 0.68);
        font-size: 0.84rem;
        font-weight: 700;
    }
    .hero-visual {
        position: relative;
        z-index: 1;
        min-height: 100%;
    }
    .hero-visual-card {
        position: relative;
        padding: var(--sp-2);
        border-radius: var(--radius-lg);
        background: rgba(255, 255, 255, 0.05);
        border: 1px solid rgba(255, 255, 255, 0.1);
    }
    .hero-visual-media {
        aspect-ratio: 0.92;
        border-radius: var(--radius-md);
        overflow: hidden;
        background: rgba(255, 255, 255, 0.06);
    }
    .hero-visual-media img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .hero-floating-card {
        position: absolute;
        left: calc(var(--sp-4) * -1);
        bottom: var(--sp-4);
        width: min(300px, 100%);
        padding: var(--sp-2);
        border-radius: var(--radius-md);
        background: rgba(255, 255, 255, 0.98);
        color: var(--text);
        box-shadow: var(--shadow-lg);
    }
    .hero-floating-card p {
        margin: 0.35rem 0 0;
        color: var(--text-muted);
        font-size: 0.88rem;
    }
    .hero-floating-card strong {
        display: block;
        font-size: 1.1rem;
        font-family: 'Poppins', sans-serif;
    }
    .hero-carousel .carousel-indicators {
        position: static;
        margin: 1.3rem 0 0;
        justify-content: flex-start;
    }
    .hero-carousel .carousel-indicators [data-bs-target] {
        width: 10px;
        height: 10px;
        border-radius: 50%;
        border: 0;
    }
    .hero-trust-strip {
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 1rem;
        margin-top: 1.4rem;
    }
    .hero-trust-item {
        padding: var(--sp-2) var(--sp-3);
        border-radius: var(--radius-md);
        background: #ffffff;
        border: 1px solid var(--border);
        color: var(--text);
        box-shadow: var(--shadow-sm);
        transition: all 0.3s ease;
    }
    .hero-trust-item:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
    .hero-trust-item strong {
        display: block;
        font-size: 0.95rem;
        margin-bottom: 0.18rem;
    }
    .hero-trust-item span {
        color: var(--text-muted);
        font-size: 0.82rem;
        font-weight: 700;
    }
    .category-mosaic {
        display: grid;
        grid-template-columns: repeat(12, minmax(0, 1fr));
        gap: 1rem;
    }
    .category-tile {
        position: relative;
        min-height: 280px;
        border-radius: var(--radius-lg);
        overflow: hidden;
        text-decoration: none;
        box-shadow: var(--shadow-md);
        transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    }
    .category-tile:hover { transform: scale(1.02); box-shadow: var(--shadow-lg); }
    .category-tile--large { grid-column: span 5; }
    .category-tile--small { grid-column: span 3; }
    .category-tile::after {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(180deg, transparent 40%, rgba(0, 0, 0, 0.4) 100%);
    }
    .category-tile img,
    .category-tile-fallback {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .category-tile-fallback {
        background: #f5f5f5;
    }
    .category-tile-content {
        position: absolute;
        inset: auto 1.2rem 1.2rem;
        z-index: 1;
        color: #fff;
    }
    .category-tile-content h3 {
        color: #fff;
        margin: 0;
        font-size: 1.3rem;
    }
    .category-tile-content p {
        margin: 0.3rem 0 0;
        color: rgba(255, 255, 255, 0.72);
        font-size: 0.88rem;
        font-weight: 700;
    }
    .editorial-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1rem;
    }
    .editorial-card {
        position: relative;
        min-height: 320px;
        border-radius: var(--radius-lg);
        overflow: hidden;
        text-decoration: none;
        box-shadow: var(--shadow-md);
        transition: all 0.4s ease;
    }
    .editorial-card img,
    .editorial-fallback {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .editorial-fallback {
        background: #f5f5f5;
    }
    .editorial-overlay {
        position: absolute;
        inset: 0;
        display: flex;
        align-items: flex-end;
        padding: 1.5rem;
        background: linear-gradient(180deg, transparent 40%, rgba(0, 0, 0, 0.5) 100%);
        color: #fff;
    }
    .editorial-overlay h3 {
        color: #fff;
        margin: 0 0 0.35rem;
        font-size: 1.65rem;
    }
    .editorial-overlay p {
        margin: 0;
        color: rgba(255, 255, 255, 0.72);
        max-width: 32ch;
    }
    .collection-shell {
        padding: var(--sp-4);
        border-radius: var(--radius-lg);
        background: #ffffff;
        border: 1px solid var(--border);
        box-shadow: var(--shadow-sm);
    }

    /* SEO FAQ accordion — neutral GiftKorner look (override Bootstrap default blue tint) */
    .seo-faq-accordion {
        --bs-accordion-color: var(--text);
        --bs-accordion-bg: #fff;
        --bs-accordion-border-color: var(--border);
        --bs-accordion-border-radius: 0;
        --bs-accordion-inner-border-radius: 0;
        --bs-accordion-btn-padding-x: 1.15rem;
        --bs-accordion-btn-padding-y: 0.95rem;
        --bs-accordion-btn-color: var(--text);
        --bs-accordion-btn-bg: #fff;
        --bs-accordion-btn-icon-width: 0.85rem;
        --bs-accordion-active-color: var(--text);
        --bs-accordion-active-bg: #f7f7f7;
        --bs-accordion-body-padding-y: 0.85rem;
        --bs-accordion-body-padding-x: var(--bs-accordion-btn-padding-x);
        --bs-accordion-btn-focus-border-color: transparent;
        --bs-accordion-btn-focus-box-shadow: none;
        border: 0;
        border-radius: 0;
        overflow: hidden;
        background: transparent;
    }
    .seo-faq-accordion__item {
        border: 0;
        border-bottom: 1px solid var(--border);
        background: transparent;
    }
    .seo-faq-accordion__item:last-child {
        border-bottom: 0;
    }
    .seo-faq-accordion__header {
        margin: 0;
    }
    .seo-faq-accordion .accordion-button {
        font-size: 0.95rem;
        font-weight: 600;
        line-height: 1.45;
        text-align: left;
        box-shadow: none !important;
    }
    .seo-faq-accordion .accordion-button:not(.collapsed) {
        color: var(--text);
        background-color: #f7f7f7;
        box-shadow: none;
    }
    .seo-faq-accordion .accordion-button::after {
        flex-shrink: 0;
        background-size: 0.85rem;
        filter: brightness(0);
        opacity: 0.55;
    }
    .seo-faq-accordion .accordion-button:not(.collapsed)::after {
        opacity: 0.85;
    }
    .seo-faq-accordion .accordion-body {
        margin: 0;
        padding-top: var(--bs-accordion-body-padding-y);
        padding-bottom: calc(var(--bs-accordion-body-padding-y) + 0.15rem);
        padding-left: var(--bs-accordion-body-padding-x);
        padding-right: var(--bs-accordion-body-padding-x);
        font-size: 0.94rem;
        line-height: 1.65;
        color: var(--text-muted);
        border-top: 1px solid var(--border);
        background: #fff;
    }
    .seo-faq-accordion .accordion-button.collapsed {
        background-color: #fff;
    }

    .collection-tabs .nav {
        display: inline-flex;
        gap: 0.5rem;
        padding: 0.3rem;
        border-radius: 999px;
        background: rgba(23, 20, 17, 0.05);
        margin-bottom: 1.6rem;
    }
    .collection-tabs .nav-link {
        border: 0;
        border-radius: 999px;
        color: var(--text-muted);
        font-weight: 800;
        padding: 0.8rem 1.1rem;
        background: transparent;
    }
    .collection-tabs .nav-link.active {
        background: #fff;
        color: var(--text);
        box-shadow: var(--shadow-sm);
    }
    .brand-grid {
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: 1rem;
    }
    .brand-card {
        min-height: 120px;
        display: grid;
        place-items: center;
        padding: var(--sp-2);
        border-radius: var(--radius-md);
        background: #ffffff;
        border: 1px solid var(--border);
        transition: all 0.2s ease;
    }
    .brand-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--border-strong); }
    .brand-card span {
        font-family: 'Poppins', sans-serif;
        font-size: 1.15rem;
        font-weight: 700;
        color: var(--text-soft);
    }
    .testimonial-grid {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 1rem;
    }
    .testimonial-card {
        padding: var(--sp-3);
        border-radius: var(--radius-lg);
        background: #ffffff;
        border: 1px solid var(--border);
        box-shadow: var(--shadow-sm);
        transition: all 0.3s ease;
    }
    .testimonial-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
    .testimonial-card p {
        margin: 1rem 0 1.1rem;
        color: var(--text-muted);
    }
    .testimonial-author {
        display: flex;
        align-items: center;
        gap: 0.8rem;
    }
    .testimonial-avatar {
        width: 46px;
        height: 46px;
        border-radius: 50%;
        display: grid;
        place-items: center;
        background: #000000;
        color: #fff;
        font-weight: 800;
    }


/* ----- frontend/product.blade.php block 1 ----- */

:root {
        --vinfur-accent: var(--primary);
        --vinfur-dark: var(--text);
        --vinfur-text: var(--text);
        --vinfur-muted: var(--text-muted);
        --font-sora: 'Sora', sans-serif;
    }
    .product-shell {
        padding: 40px 0 80px;
    }
    .product-breadcrumb {
        padding: 1.25rem 0 0;
    }
    .product-layout {
        display: grid;
        grid-template-columns: minmax(0, 1.05fr) minmax(340px, 0.95fr);
        gap: 2rem;
        align-items: start;
    }
    .product-gallery-wrap {
        display: grid;
        gap: 1rem;
    }
    .product-gallery-card {
        padding: var(--sp-2);
        border-radius: var(--radius-lg);
        background: #ffffff;
        border: 1px solid var(--border);
        box-shadow: var(--shadow-md);
    }
    .gallery-main {
        position: relative;
        aspect-ratio: 1;
        border-radius: var(--radius-md);
        overflow: hidden;
        background: #f8f9fa;
        border: 1px solid var(--border);
    }
    .gallery-main img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 0.45s ease;
    }
    .gallery-main:hover img { transform: scale(1.04); }
    .gallery-thumbs {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(82px, 1fr));
        gap: 0.8rem;
    }
    .gallery-thumb {
        aspect-ratio: 1;
        border-radius: var(--radius-sm);
        overflow: hidden;
        border: 1.5px solid transparent;
        background: var(--bg-light);
        cursor: pointer;
        transition: all 0.2s ease;
    }
    .gallery-thumb:hover { border-color: var(--border-strong); }
    .gallery-thumb.active { border-color: var(--primary); }
    .gallery-thumb img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .product-summary {
        position: sticky;
        top: 112px;
        padding: 0;
        background: transparent;
        border: 0;
        box-shadow: none;
    }
    .product-summary-top {
        display: flex;
        align-items: center;
        gap: 0.75rem;
        margin-bottom: 1.5rem;
    }
    .product-vendor {
        font-size: 14px;
        font-weight: 500;
        color: var(--vinfur-muted);
        text-transform: uppercase;
        letter-spacing: 1px;
    }
    .product-title {
        font-family: var(--font-sora);
        font-size: 32px;
        font-weight: 500;
        line-height: 1.2;
        color: var(--vinfur-dark);
        margin: 0 0 1.5rem;
    }
    .product-rating {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        margin-bottom: 1.5rem;
        color: var(--vinfur-muted);
        font-size: 14px;
    }
    .product-rating-stars {
        display: inline-flex;
        gap: 2px;
        color: var(--vinfur-accent);
    }
    .product-price-row {
        display: flex;
        align-items: center;
        gap: 12px;
        margin-bottom: 1.5rem;
    }
    .product-price-main {
        font-family: var(--font-sora);
        font-size: 24px;
        font-weight: 600;
        color: var(--vinfur-accent);
    }
    .product-price-old {
        font-size: 18px;
        color: var(--vinfur-muted);
        text-decoration: line-through;
    }
    .product-save-pill {
        padding: 4px 12px;
        border-radius: 30px;
        background: var(--vinfur-accent);
        color: #ffffff;
        font-size: 12px;
        font-weight: 600;
    }
    .product-intro {
        color: var(--text-muted);
        font-size: 0.96rem;
        margin-bottom: 1.2rem;
    }
    .product-status-bar {
        margin-bottom: 2rem;
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
    }
    .product-status-item {
        display: flex;
        align-items: center;
        gap: 8px;
        font-size: 14px;
        color: var(--vinfur-dark);
    }
    .product-status-item i {
        font-size: 16px;
    }
    .product-status-item.in-stock i { color: #1a1a1a; }
    .product-status-item.sales-info i { color: #555555; }
    .product-option-group {
        margin-bottom: 1.8rem;
    }
    .product-option-group label {
        display: block;
        font-size: 14px;
        font-weight: 700;
        color: var(--vinfur-dark);
        margin-bottom: 1rem;
    }
    .variant-label-val {
        font-weight: 400;
        color: var(--vinfur-muted);
    }
    .variant-options {
        display: flex;
        flex-wrap: wrap;
        gap: 12px;
    }
    .variant-swatch {
        width: 32px;
        height: 32px;
        border-radius: 50%;
        border: 1px solid var(--border);
        padding: 2px;
        cursor: pointer;
        transition: all 0.2s ease;
        position: relative;
    }
    .variant-swatch-inner {
        width: 100%;
        height: 100%;
        border-radius: 50%;
    }
    .variant-swatch.active {
        border-color: var(--vinfur-accent);
        border-width: 2px;
    }
    .variant-btn {
        padding: 10px 18px;
        border-radius: 0;
        border: 1px solid var(--border);
        background: #fff;
        font-weight: 500;
        font-size: 14px;
        transition: all 0.2s ease;
    }
    .variant-btn.selected {
        border-color: var(--vinfur-accent);
        background: var(--vinfur-accent);
        color: #ffffff;
    }
    .variant-btn:disabled {
        opacity: 0.45;
        cursor: not-allowed;
        text-decoration: line-through;
    }
    .qty-buy-wrap {
        display: flex;
        gap: 12px;
        margin-bottom: 1rem;
    }
    .qty-control {
        display: flex;
        border: 1px solid var(--border);
        height: 52px;
        background: #fff;
    }
    .qty-btn {
        width: 48px;
        border: 0;
        background: transparent;
        font-size: 18px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .qty-input {
        width: 50px;
        border: 0;
        text-align: center;
        font-size: 16px;
        font-weight: 500;
    }
    .btn-add-to-cart {
        flex: 1;
        height: 52px;
        background: var(--vinfur-accent);
        color: #ffffff;
        border: 0;
        border-radius: 0;
        font-family: var(--font-sora);
        font-size: 14px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 1px;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 1rem;
    }
    .btn-add-to-cart:hover {
        background: var(--vinfur-dark);
        color: #ffffff;
        transform: none;
        box-shadow: none;
    }
    .secondary-actions {
        display: flex;
        gap: 20px;
        margin-bottom: 1.5rem;
    }
    .secondary-action-link {
        display: flex;
        align-items: center;
        gap: 8px;
        font-size: 14px;
        color: var(--vinfur-dark);
        text-decoration: none;
        transition: color 0.2s ease;
    }
    .secondary-action-link:hover {
        color: var(--vinfur-accent);
    }
    .btn-buy-now {
        width: 100%;
        height: 52px;
        background: var(--vinfur-accent);
        color: #ffffff;
        border: 1px solid var(--vinfur-accent);
        border-radius: 0;
        font-family: var(--font-sora);
        font-size: 14px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 1px;
        display: flex;
        align-items: center;
        justify-content: center;
        margin-bottom: 2rem;
    }
    .btn-buy-now:hover {
        background: transparent;
        color: var(--vinfur-accent);
    }
    .extra-info-block {
        border-top: 1px solid #e5e5e5;
        padding-top: 1.8rem;
        display: grid;
        gap: 1.25rem;
    }
    .pickup-info {
        font-size: 14px;
        color: var(--vinfur-muted);
        line-height: 1.6;
    }
    .pickup-info b { color: var(--vinfur-dark); }
    .pickup-info a { color: var(--vinfur-dark); text-decoration: underline; }
    .utility-links {
        display: flex;
        gap: 25px;
    }
    .utility-link {
        display: flex;
        align-items: center;
        gap: 8px;
        font-size: 14px;
        color: var(--vinfur-dark);
        text-decoration: none;
    }
    .metadata-list {
        display: grid;
        gap: 0.5rem;
        font-size: 14px;
        color: var(--vinfur-muted);
    }
    .metadata-list span { color: var(--vinfur-dark); }
    .safe-checkout-block {
        background: #f9f9f9;
        padding: 1.5rem;
        text-align: center;
        border-radius: 0;
    }
    .safe-checkout-title {
        font-size: 14px;
        font-weight: 600;
        margin-bottom: 1rem;
        color: var(--vinfur-dark);
    }
    .payment-icons {
        display: flex;
        justify-content: center;
        gap: 12px;
        flex-wrap: wrap;
    }
    .payment-icons i {
        font-size: 24px;
        color: #555555;
    }
    .product-highlights {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 1rem;
        margin-top: 2rem;
    }
    .highlight-card {
        padding: 1.15rem;
        border-radius: var(--radius-md);
        background: #ffffff;
        border: 1px solid var(--border);
        box-shadow: var(--shadow-sm);
    }
    .highlight-card strong {
        display: block;
        margin: 0.7rem 0 0.2rem;
        font-size: 1rem;
    }
    .detail-tabs-shell {
        margin-top: 3.5rem;
        padding-top: 1rem;
    }
    .detail-tabs-shell .nav {
        display: flex;
        gap: 2.5rem;
        padding: 0;
        margin-bottom: 2rem;
        border-bottom: 2px solid #f2f2f2;
    }
    .detail-tabs-shell .nav-link {
        border: 0;
        border-radius: 0;
        color: var(--vinfur-muted);
        font-weight: 700;
        padding: 0 0 0.85rem;
        background: transparent;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        font-size: 0.82rem;
        position: relative;
        transition: all 0.2s ease;
    }
    .detail-tabs-shell .nav-link.active {
        color: var(--vinfur-dark);
        background: transparent;
        box-shadow: none;
    }
    .detail-tabs-shell .nav-link::after {
        content: '';
        position: absolute;
        bottom: -2px;
        left: 0;
        width: 0;
        height: 2px;
        background: var(--vinfur-accent);
        transition: width 0.2s ease;
    }
    .detail-tabs-shell .nav-link.active::after {
        width: 100%;
    }
    
    .spec-grid {
        display: grid;
        gap: 0.85rem;
        max-width: 720px;
    }
    .product-description-content {
        max-width: 820px;
        color: var(--text-muted);
        font-size: 0.96rem;
        line-height: 1.9;
    }
    .product-description-content > :last-child {
        margin-bottom: 0;
    }
    .product-description-content h1,
    .product-description-content h2,
    .product-description-content h3,
    .product-description-content h4,
    .product-description-content h5,
    .product-description-content h6 {
        color: var(--text);
        margin: 1.2rem 0 0.7rem;
    }
    .product-description-content p,
    .product-description-content ul,
    .product-description-content ol {
        margin-bottom: 0.95rem;
    }
    .product-description-content ul,
    .product-description-content ol {
        padding-left: 1.25rem;
    }
    .product-description-content a {
        color: var(--primary);
    }
    .product-description-content img {
        max-width: 100%;
        height: auto;
        border-radius: var(--radius-sm);
    }
    .product-description-content table {
        width: 100%;
        margin: 1rem 0;
        border-collapse: collapse;
        border: 1px solid var(--border);
    }
    .product-description-content th,
    .product-description-content td {
        padding: 0.75rem 0.9rem;
        border: 1px solid var(--border);
        vertical-align: top;
    }
    .product-description-content blockquote {
        margin: 1rem 0;
        padding: 0.8rem 1rem;
        border-left: 3px solid var(--primary);
        background: var(--bg-light);
    }
    .product-description-content pre,
    .product-description-content code {
        font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    }
    .product-description-content pre {
        padding: 1rem;
        overflow: auto;
        border-radius: var(--radius-sm);
        background: #f8f9fa;
    }
    .spec-row {
        display: grid;
        grid-template-columns: 220px minmax(0, 1fr);
        gap: 1rem;
        padding: 0.9rem 1rem;
        border-radius: 4px;
        background: #FFFFFF;
        border: 1px solid var(--border);
    }
    .review-form-card,
    .review-card {
        padding: 1.2rem;
        border-radius: 4px;
        background: #FFFFFF;
        border: 1px solid var(--border);
        box-shadow: var(--shadow-sm);
        margin-bottom: 1rem;
    }
    .review-header {
        display: flex;
        align-items: center;
        gap: 0.8rem;
        margin-bottom: 0.75rem;
    }
    .review-avatar {
        width: 46px;
        height: 46px;
        border-radius: 50%;
        display: grid;
        place-items: center;
        background: #000000;
        color: #fff;
        font-weight: 800;
    }
    .review-rating-input {
        display: flex;
        gap: 0.45rem;
        margin-top: 0.5rem;
    }
    .review-rating-input label {
        cursor: pointer;
        color: var(--secondary);
        font-size: 1.25rem;
    }
    .review-rating-input input {
        display: none;
    }
    .product-rail {
        margin-top: 2.5rem;
    }

    
    
    
    /* ── Share Dropdown ── */
    .share-dropdown-item {
        display: flex;
        align-items: center;
        gap: 0.6rem;
        padding: 0.55rem 1rem;
        text-decoration: none;
        color: #333;
        font-size: 0.85rem;
        transition: background 0.15s ease;
    }
    .share-dropdown-item:hover {
        background: #f5f0eb;
        color: #111;
    }
    .share-dropdown-item i {
        font-size: 1rem;
        width: 18px;
        text-align: center;
    }


/* ----- frontend/cart.blade.php block 1 ----- */

/* ── Cart Page Shell ─────────────────────────────────────── */
    .cart-page { padding: var(--sp-4) 0 var(--sp-6); }

    .cart-layout {
        display: grid;
        grid-template-columns: minmax(0, 1fr) 380px;
        gap: 2.5rem;
        align-items: start;
    }

    /* ── Section header row ────────────────────────────────── */
    .cart-section-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding-bottom: 1rem;
        border-bottom: 2px solid #111;
        margin-bottom: 0;
    }
    .cart-section-head h2 {
        font-size: 1rem;
        font-weight: 700;
        color: #111;
        margin: 0;
        text-transform: uppercase;
        letter-spacing: 0.06em;
    }
    .cart-count-badge {
        color: #888;
        font-size: 0.82rem;
        font-weight: 500;
    }

    /* ── Cart Table ──────────────────────────────────────────── */
    .cart-table {
        width: 100%;
        border-collapse: collapse;
    }

    /* Column headers */
    .cart-table-head th {
        padding: 0.75rem 0.5rem;
        font-size: 0.72rem;
        font-weight: 700;
        color: #888;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        border-bottom: 1px solid #e8e8e8;
        white-space: nowrap;
    }
    .cart-table-head th:first-child { padding-left: 0; }
    .cart-table-head th:last-child  { padding-right: 0; text-align: right; }
    .cart-table-head th.col-price,
    .cart-table-head th.col-qty,
    .cart-table-head th.col-subtotal { text-align: center; }
    .cart-table-head th.col-subtotal { text-align: right; }

    /* Table rows */
    .cart-item-row td {
        padding: 1.4rem 0.5rem;
        border-bottom: 1px solid #f0f0f0;
        vertical-align: middle;
    }
    .cart-item-row td:first-child { padding-left: 0; }
    .cart-item-row td:last-child  { padding-right: 0; }
    .cart-item-row:last-child td  { border-bottom: 1px solid #e8e8e8; }

    /* ── Product Column ──────────────────────────────────────── */
    .cart-product-cell {
        display: flex;
        align-items: flex-start;
        gap: 1rem;
        min-width: 0;
    }

    .cart-item-img {
        width: 80px;
        height: 80px;
        object-fit: cover;
        background: #f5f5f5;
        flex-shrink: 0;
        border: 1px solid #ebebeb;
    }
    .cart-item-img-placeholder {
        width: 80px;
        height: 80px;
        background: #f5f5f5;
        border: 1px solid #ebebeb;
        display: flex;
        align-items: center;
        justify-content: center;
        color: #ccc;
        flex-shrink: 0;
    }

    .cart-item-info {
        display: flex;
        flex-direction: column;
        gap: 0.2rem;
        padding-top: 0.1rem;
        min-width: 0;
    }

    .cart-item-name {
        margin: 0;
        font-size: 0.92rem;
        font-weight: 600;
        color: #111;
        line-height: 1.3;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .cart-item-name a {
        text-decoration: none;
        color: inherit;
    }
    .cart-item-name a:hover { color: #555; }

    .cart-item-variant {
        font-size: 0.78rem;
        color: #999;
        font-weight: 400;
    }

    .cart-item-remove {
        margin-top: 0.5rem;
        border: 0;
        background: transparent;
        color: #aaa;
        font-size: 0.75rem;
        font-weight: 500;
        cursor: pointer;
        padding: 0;
        text-align: left;
        text-decoration: underline;
        text-underline-offset: 2px;
        transition: color 0.15s;
        display: inline-block;
    }
    .cart-item-remove:hover { color: #111; }

    /* ── Price column ────────────────────────────────────────── */
    .cart-col-price {
        text-align: center;
        font-size: 0.9rem;
        color: #333;
        font-weight: 500;
        white-space: nowrap;
    }

    /* ── Qty Stepper ─────────────────────────────────────────── */
    .cart-col-qty { text-align: center; }

    .cart-qty-wrap {
        display: inline-flex;
        align-items: stretch;
        height: 36px;
        border: 1px solid #d8d8d8;
        background: #fff;
    }
    .cart-qty-btn {
        width: 34px;
        border: 0;
        background: transparent;
        color: #333;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        transition: background 0.12s;
        font-size: 1rem;
        line-height: 1;
    }
    .cart-qty-btn:hover  { background: #f5f5f5; }
    .cart-qty-btn:active { background: #ececec; }
    .cart-qty-input {
        width: 40px;
        border: 0;
        border-left: 1px solid #e8e8e8;
        border-right: 1px solid #e8e8e8;
        text-align: center;
        font-size: 0.88rem;
        font-weight: 600;
        color: #111;
        background: #fff;
        outline: none;
        -moz-appearance: textfield;
    }
    .cart-qty-input::-webkit-inner-spin-button,
    .cart-qty-input::-webkit-outer-spin-button { -webkit-appearance: none; }

    /* ── Subtotal column ─────────────────────────────────────── */
    .cart-col-subtotal {
        text-align: right;
        font-size: 0.95rem;
        font-weight: 700;
        color: #111;
        white-space: nowrap;
    }

    /* ── Bottom Action Row ───────────────────────────────────── */
    .cart-actions-row {
        display: flex;
        align-items: center;
        justify-content: space-between;
        flex-wrap: wrap;
        gap: 0.75rem;
        padding-top: 1.25rem;
        margin-top: 0.1rem;
    }
    .cart-btn-secondary {
        display: inline-flex;
        align-items: center;
        gap: 0.4rem;
        padding: 0.5rem 0;
        border: 0;
        background: transparent;
        color: #555;
        font-size: 0.82rem;
        font-weight: 500;
        text-decoration: none;
        letter-spacing: 0.02em;
        transition: color 0.15s;
    }
    .cart-btn-secondary:hover { color: #000; }
    .cart-btn-secondary i { font-size: 0.8rem; }

    .cart-btn-danger {
        display: inline-flex;
        align-items: center;
        gap: 0.4rem;
        padding: 0.5rem 0;
        border: 0;
        background: transparent;
        color: #aaa;
        font-size: 0.82rem;
        font-weight: 500;
        cursor: pointer;
        letter-spacing: 0.02em;
        transition: color 0.15s;
        text-decoration: underline;
        text-underline-offset: 2px;
    }
    .cart-btn-danger:hover { color: #111; }

    /* ── Summary Sidebar ─────────────────────────────────────── */
    .cart-summary {
        position: sticky;
        top: 100px;
        background: #fff;
        border: 1px solid #e8e8e8;
        border-radius: 2px;
        overflow: hidden;
    }

    .cart-summary-head {
        padding: 1.1rem 1.25rem;
        border-bottom: 1px solid #f0f0f0;
        font-size: 0.82rem;
        font-weight: 700;
        color: #111;
        text-transform: uppercase;
        letter-spacing: 0.08em;
    }

    .cart-summary-body { padding: 1.1rem 1.25rem; }

    /* Coupon */
    .coupon-shell {
        background: #f8f9fa;
        border: 1px dashed #d0d0d0;
        border-radius: 4px;
        padding: 0.9rem 1rem;
        margin-bottom: 1.1rem;
    }
    .coupon-label {
        font-size: 0.75rem;
        font-weight: 600;
        color: #666;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        margin-bottom: 0.6rem;
        display: flex;
        align-items: center;
        gap: 0.4rem;
    }
    .coupon-form {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 0.5rem;
    }
    .coupon-form .form-control {
        font-size: 0.85rem;
        border-radius: 2px;
        border-color: #ddd;
    }
    .coupon-form .btn {
        font-size: 0.82rem;
        padding: 0 0.9rem;
        border-radius: 2px;
        white-space: nowrap;
    }
    .coupon-applied {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
    }
    .coupon-applied-info strong {
        font-size: 0.9rem;
        color: #000;
        font-weight: 700;
        display: block;
    }
    .coupon-applied-info span {
        font-size: 0.78rem;
        color: #878787;
    }

    /* Summary rows */
    .summary-rows { margin-bottom: 0.25rem; }
    .summary-row {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        padding: 0.6rem 0;
        font-size: 0.87rem;
        color: #666;
        font-weight: 400;
        border-bottom: 1px solid #f5f5f5;
    }
    .summary-row:last-child { border-bottom: 0; }
    .summary-row strong { font-weight: 600; color: #111; }

    .summary-total-row {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        padding: 1rem 1.25rem;
        background: #f8f9fa;
        border-top: 1px solid #e8e8e8;
        border-bottom: 1px solid #e8e8e8;
        font-size: 0.9rem;
        font-weight: 600;
        color: #111;
        text-transform: uppercase;
        letter-spacing: 0.04em;
    }
     .announcement-bar {
        background: #000000;
        color: #FFFFFF;
        font-size: 0.84rem;
        font-weight: 600;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        border-bottom: 1px solid rgba(255,255,255,0.1);
        width: 100% !important;
        max-width: 100vw !important;
        overflow: hidden !important;
    }
    .announcement-bar-inner {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 1rem;
        padding: 0.72rem 0;
        flex-wrap: nowrap;
        width: 100%;
        overflow-x: auto;
    }
    .announcement-bar strong { color: #fff; font-weight: 800; }
    .announcement-link {
        display: inline-flex;
        align-items: center;
        gap: 0.4rem;
        color: #fff;
        text-decoration: none;
        border-bottom: 1px solid rgba(255, 255, 255, 0.35);
        white-space: nowrap;
    }

    .site-header {
        position: sticky;
        top: 0;
        z-index: 1040;
        background: #ffffff;
        border-bottom: 1px solid var(--border);
        transition: all 0.2s ease;
        width: 100% !important;
        max-width: 100vw !important;
        /* must stay visible or mega-menu / dropdowns are clipped */
        overflow: visible;
    }


    .btn-checkout {
        display: block;
        width: 100%;
        padding: 0.85rem;
        background: #111;
        color: #fff;
        border: 0;
        border-radius: 2px;
        font-size: 0.85rem;
        font-weight: 700;
        text-align: center;
        text-decoration: none;
        cursor: pointer;
        transition: background 0.2s ease;
        letter-spacing: 0.08em;
        text-transform: uppercase;
    }
    .btn-checkout:hover { background: #333; color: #fff; }

    .summary-secure-note {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0.35rem;
        margin-top: 0.75rem;
        font-size: 0.74rem;
        color: #aaa;
        font-weight: 400;
    }

    .summary-note {
        margin-top: 0.75rem;
        padding: 0.6rem 0.85rem;
        border-radius: 2px;
        background: #f8f9fa;
        color: #555;
        font-size: 0.78rem;
        font-weight: 500;
        display: flex;
        align-items: center;
        gap: 0.4rem;
        border: 1px solid #ebebeb;
    }

    /* ── Empty Cart ──────────────────────────────────────────── */
    .cart-empty {
        text-align: center;
        padding: 4rem 2rem;
        background: #fff;
        border: 1px solid #e8e8e8;
        border-radius: 4px;
    }
    .cart-empty-icon {
        width: 72px;
        height: 72px;
        background: #f5f5f5;
        border-radius: 50%;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 1.75rem;
        color: #ccc;
        margin-bottom: 1.25rem;
    }
    .cart-empty h3 { font-size: 1.1rem; font-weight: 700; color: #111; margin-bottom: 0.5rem; }
    .cart-empty p { color: #999; font-size: 0.88rem; max-width: 36ch; margin: 0 auto 1.5rem; }

    /* ── Responsive ──────────────────────────────────────────── */


/* ----- frontend/checkout.blade.php block 1 ----- */

.checkout-stage {
        padding: var(--sp-4) 0 var(--sp-6);
        background: var(--bg-light);
    }
    .checkout-steps {
        display: flex;
        align-items: center;
        gap: 0.85rem;
        flex-wrap: wrap;
        margin-bottom: 1.2rem;
        color: var(--text-soft);
        font-size: 0.82rem;
        font-weight: 800;
        letter-spacing: 0.06em;
        text-transform: uppercase;
    }
    .checkout-steps span.is-active { color: var(--primary); }
    .checkout-layout {
        display: grid;
        grid-template-columns: minmax(0, 1.04fr) 400px;
        gap: 1.5rem;
    }
    .checkout-stack {
        display: grid;
        gap: 1rem;
    }
    .checkout-panel {
        padding: var(--sp-4);
        border-radius: var(--radius-lg);
        background: #FFFFFF;
        border: 1px solid var(--border);
        box-shadow: var(--shadow-md);
    }
    .checkout-panel-title {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        margin-bottom: var(--sp-3);
    }
    .checkout-panel-title h2,
    .checkout-panel-title h3 {
        margin: 0;
        font-size: 1.2rem;
    }
    .saved-address-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.85rem;
    }
    .saved-address-card {
        padding: 1.25rem;
        border-radius: var(--radius-md);
        background: #FFFFFF;
        border: 1px solid var(--border);
        text-align: left;
        transition: all 0.2s ease;
    }
    .saved-address-card:hover { border-color: var(--primary); background: var(--surface-strong); }
    .saved-address-card strong {
        display: block;
        margin-bottom: 0.25rem;
        font-size: 1rem;
    }
    .saved-address-card div {
        color: var(--text-muted);
        font-size: 0.86rem;
    }
    .checkout-form-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.9rem;
    }
    .checkout-form-grid .span-2 {
        grid-column: span 2;
    }
    .checkout-note {
        margin-top: 1rem;
        padding: 0.95rem 1rem;
        border-radius: 4px;
        background: var(--bg-light);
        color: #000;
        font-size: 0.86rem;
        font-weight: 700;
        border: 1px solid var(--border);
    }
    .payment-options {
        display: grid;
        gap: 0.8rem;
    }
    .payment-option {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        gap: 1rem;
        align-items: center;
        padding: 1.25rem;
        border-radius: var(--radius-md);
        background: #FFFFFF;
        border: 1.5px solid var(--border);
        cursor: pointer;
        transition: all 0.2s ease;
    }
    .payment-option.is-selected {
        border-color: #000000;
        background: #F7F7F7;
    }
    .checkout-summary {
        position: sticky;
        top: 108px;
    }
    .checkout-order-item {
        display: grid;
        grid-template-columns: 72px minmax(0, 1fr) auto;
        gap: 0.85rem;
        align-items: center;
        padding: 0.85rem 0;
        border-bottom: 1px solid var(--border);
    }
    .checkout-order-item:last-child { border-bottom: 0; }
    .checkout-order-item img {
        width: 72px;
        height: 72px;
        border-radius: var(--radius-sm);
        object-fit: cover;
        background: var(--bg-light);
    }
    .checkout-totals {
        margin-top: 0.8rem;
        padding-top: 0.8rem;
        border-top: 1px solid var(--border);
    }
    .checkout-total-row {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        padding: 0.5rem 0;
        color: var(--text-muted);
        font-weight: 700;
    }
    .checkout-total-row.is-total {
        color: var(--text);
        font-size: 1.12rem;
        font-weight: 800;
        padding-top: 0.8rem;
        margin-top: 0.3rem;
        border-top: 1px solid var(--border);
    }
    .checkout-submit {
        width: 100%;
        min-height: 58px;
        border: 0;
        border-radius: 4px;
        background: #000000;
        color: #fff;
        font-weight: 800;
        box-shadow: var(--shadow-sm);
        margin-top: 1rem;
    }
    .checkout-side-note {
        margin-top: 0.9rem;
        color: var(--text-soft);
        font-size: 0.82rem;
        font-weight: 700;
        text-align: center;
    }
    .checkout-auth-options {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 1rem;
        margin-bottom: 1.5rem;
    }
    .auth-option-card {
        padding: var(--sp-4);
        border-radius: var(--radius-md);
        background: #FFFFFF;
        border: 1px solid var(--border);
        text-align: center;
        cursor: pointer;
        transition: all 0.2s ease;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 0.5rem;
        text-decoration: none;
        color: inherit;
    }
    .auth-option-card:hover { border-color: var(--primary); background: var(--surface-strong); }
    .auth-option-card i { font-size: 1.5rem; color: var(--primary); }
    .auth-option-card strong { font-size: 0.94rem; }
    .auth-option-card span { font-size: 0.78rem; color: var(--text-muted); }
    .auth-option-card.is-active {
        border-color: var(--primary);
        border-width: 2px;
        background: var(--surface-strong);
    }


/* ----- frontend/search.blade.php block 1 ----- */

.search-page-form {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 0.85rem;
        max-width: 760px;
    }
    .search-results-shell {
        padding-bottom: 4rem;
    }
    .search-suggested-links {
        display: flex;
        flex-wrap: wrap;
        gap: 0.65rem;
        margin-top: 1rem;
    }
    .search-empty-state {
        padding: 2.2rem;
        text-align: center;
        border-radius: 30px;
        background: linear-gradient(180deg, rgba(247, 242, 234, 0.88), rgba(255, 255, 255, 0.96));
        border: 1px solid rgba(231, 222, 209, 0.92);
        box-shadow: var(--shadow-sm);
    }
    .search-empty-state i {
        font-size: 3.2rem;
        color: var(--text-soft);
        margin-bottom: 1rem;
    }


/* ----- frontend/blog/index.blade.php block 1 ----- */

/* ══════════════════════════════════════════════════════════
       VinFur – Blog Style 1  (Pixel-Perfect from Screenshot)
       ══════════════════════════════════════════════════════════ */

    /* ── Page Title / Breadcrumb ─────────────────────────── */
    .tf-page-title-blog {
        background: linear-gradient(180deg, #f5f0eb 0%, #efe9e1 100%);
        padding: 2.5rem 0 1.5rem;
    }
    .tf-page-title-blog .heading {
        font-family: var(--font-display);
        font-size: clamp(1.75rem, 3.5vw, 2.5rem);
        font-weight: 700;
        letter-spacing: 0.15em;
        text-transform: uppercase;
        color: #111;
        margin: 0 0 1.5rem;
        text-align: center;
    }
    .tf-page-title-blog .breadcrumbs {
        display: flex;
        align-items: center;
        gap: 0;
        list-style: none;
        margin: 0;
        padding: 0;
        font-size: 0.72rem;
        color: #999;
        letter-spacing: 0.06em;
        text-transform: uppercase;
    }
    .tf-page-title-blog .breadcrumbs a {
        color: #888;
        text-decoration: none;
        transition: color 0.2s ease;
    }
    .tf-page-title-blog .breadcrumbs a:hover { color: #111; }
    .tf-page-title-blog .breadcrumbs .sep {
        margin: 0 0.45rem;
        color: #bbb;
        font-size: 0.68rem;
    }

    /* ── Blog Section Wrapper ────────────────────────────── */
    .tf-blog-section {
        padding: 3rem 0 4rem;
    }
    .tf-blog-layout {
        display: grid;
        grid-template-columns: minmax(0, 1fr) 280px;
        gap: 3.5rem;
    }

    /* ── Blog Grid ─────────────────────────────────────── */
    .tf-blog-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 2.5rem;
    }

    /* ── Blog Card ─────────────────────────────────────── */
    .tf-blog-card {
        display: flex;
        flex-direction: column;
    }
    .tf-blog-card .card-img-wrap {
        position: relative;
        display: block;
        overflow: hidden;
        margin-bottom: 1rem;
    }
    .tf-blog-card .card-img-wrap img {
        width: 100%;
        aspect-ratio: 4 / 3;
        object-fit: cover;
        display: block;
        transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
    }
    .tf-blog-card:hover .card-img-wrap img {
        transform: scale(1.05);
    }

    /* Tags overlay — bottom-left of image, multiple tags */
    .tf-blog-card .card-tags-overlay {
        position: absolute;
        bottom: 12px;
        left: 12px;
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
        z-index: 1;
    }
    .tf-blog-card .card-tags-overlay .tag-pill {
        display: inline-block;
        background: rgba(255, 255, 255, 0.92);
        color: #111;
        font-size: 0.65rem;
        font-weight: 600;
        letter-spacing: 0.04em;
        padding: 4px 10px;
        text-decoration: none;
        transition: background 0.2s ease, color 0.2s ease;
        backdrop-filter: blur(4px);
    }
    .tf-blog-card .card-tags-overlay .tag-pill:hover {
        background: #111;
        color: #fff;
    }

    /* no image placeholder */
    .tf-blog-card .img-placeholder {
        width: 100%;
        aspect-ratio: 4 / 3;
        background: linear-gradient(145deg, #f1ede9, #e2ddd7);
        display: flex;
        align-items: center;
        justify-content: center;
        color: #bbb;
        font-size: 2.5rem;
        margin-bottom: 1rem;
    }

    /* ── Blog Meta Row ── author avatar + name + separator + date */
    .tf-blog-meta {
        display: flex;
        align-items: center;
        gap: 0;
        margin-bottom: 0.6rem;
        font-size: 0.78rem;
        color: #999;
    }
    .tf-blog-meta .author-wrap {
        display: inline-flex;
        align-items: center;
        gap: 0.4rem;
    }
    .tf-blog-meta .author-avatar {
        width: 24px;
        height: 24px;
        border-radius: 50%;
        background: #e0dbd6;
        flex-shrink: 0;
    }
    .tf-blog-meta .author-name {
        color: #666;
        text-decoration: none;
        font-weight: 500;
        font-size: 0.78rem;
        transition: color 0.2s ease;
    }
    .tf-blog-meta .author-name:hover { color: #111; }
    .tf-blog-meta .meta-sep {
        display: inline-block;
        width: 1px;
        height: 12px;
        background: #d4d0cb;
        margin: 0 0.75rem;
    }
    .tf-blog-meta .meta-date {
        color: #999;
        font-weight: 400;
        font-size: 0.78rem;
    }

    /* ── Blog Card Title ── */
    .tf-blog-card .card-title {
        margin: 0 0 0.75rem;
        font-family: var(--font-display);
        font-size: 0.82rem;
        font-weight: 700;
        line-height: 1.55;
        letter-spacing: 0.08em;
        text-transform: uppercase;
    }
    .tf-blog-card .card-title a {
        text-decoration: none;
        color: #111;
        transition: color 0.2s ease;
    }
    .tf-blog-card .card-title a:hover {
        color: #a68b6a;
    }

    /* ── Read More Link ── underline + arrow */
    .tf-blog-card .btn-readmore {
        display: inline-flex;
        align-items: center;
        gap: 0.5rem;
        font-size: 0.72rem;
        font-weight: 600;
        letter-spacing: 0.06em;
        text-transform: uppercase;
        text-decoration: none;
        color: #111;
        position: relative;
        padding-bottom: 3px;
        border-bottom: 1px solid #111;
        width: fit-content;
        transition: color 0.2s ease, border-color 0.2s ease;
    }
    .tf-blog-card .btn-readmore:hover {
        color: #a68b6a;
        border-color: #a68b6a;
    }
    .tf-blog-card .btn-readmore .arrow-icon {
        font-size: 0.72rem;
        transition: transform 0.2s ease;
    }
    .tf-blog-card .btn-readmore:hover .arrow-icon {
        transform: translateX(3px);
    }

    /* ═══════════════════════════════════════════════════════
       SIDEBAR — Matches VinFur exactly
       ═══════════════════════════════════════════════════════ */
    .tf-blog-sidebar {
        position: sticky;
        top: 100px;
    }

    /* ── Sidebar Widget Container ── */
    .tf-sidebar-widget {
        margin-bottom: 2rem;
    }
    .tf-sidebar-widget:last-child {
        margin-bottom: 0;
    }
    .tf-sidebar-widget .widget-title {
        font-family: var(--font-display);
        font-size: 0.78rem;
        font-weight: 700;
        letter-spacing: 0.14em;
        text-transform: uppercase;
        color: #111;
        margin: 0 0 1rem;
        padding-bottom: 0;
        border-bottom: none;
    }

    /* ── Categories Widget — simple text list ── */
    .tf-sidebar-categories {
        list-style: none;
        margin: 0;
        padding: 0;
    }
    .tf-sidebar-categories li a {
        display: block;
        padding: 0.35rem 0;
        text-decoration: none;
        color: #777;
        font-size: 0.85rem;
        font-weight: 400;
        transition: color 0.2s ease;
    }
    .tf-sidebar-categories li a:hover {
        color: #111;
    }

    /* ── Recent Posts Widget — thumbnail + meta + title ── */
    .tf-sidebar-posts {
        display: grid;
        gap: 1.1rem;
    }
    .tf-sidebar-post-item {
        display: flex;
        align-items: flex-start;
        gap: 0.75rem;
    }
    .tf-sidebar-post-thumb {
        width: 75px;
        height: 75px;
        flex-shrink: 0;
        overflow: hidden;
    }
    .tf-sidebar-post-thumb img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
        transition: transform 0.3s ease;
    }
    .tf-sidebar-post-item:hover .tf-sidebar-post-thumb img {
        transform: scale(1.06);
    }
    .tf-sidebar-post-thumb .no-thumb {
        width: 100%;
        height: 100%;
        background: #f0ece7;
        display: flex;
        align-items: center;
        justify-content: center;
        color: #c5bfb8;
        font-size: 1.2rem;
    }
    .tf-sidebar-post-info {
        display: flex;
        flex-direction: column;
        gap: 0.25rem;
        min-width: 0;
        padding-top: 2px;
    }
    .tf-sidebar-post-meta {
        display: flex;
        align-items: center;
        gap: 0;
        font-size: 0.7rem;
        color: #aaa;
        font-weight: 400;
    }
    .tf-sidebar-post-meta .sep {
        margin: 0 0.35rem;
        color: #ccc;
    }
    .tf-sidebar-post-info .post-link {
        font-size: 0.82rem;
        font-weight: 600;
        color: #333;
        text-decoration: none;
        line-height: 1.4;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
        transition: color 0.2s ease;
    }
    .tf-sidebar-post-info .post-link:hover {
        color: #111;
    }

    /* ── Tags Widget — hashtag links with / separator ── */
    .tf-sidebar-tags {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0;
        line-height: 2;
    }
    .tf-sidebar-tags a {
        display: inline;
        color: #777;
        font-size: 0.8rem;
        font-weight: 400;
        text-decoration: none;
        transition: color 0.2s ease;
    }
    .tf-sidebar-tags a:hover {
        color: #111;
    }
    .tf-sidebar-tags .tag-sep {
        color: #ccc;
        margin: 0 0.35rem;
        font-size: 0.72rem;
    }

    /* ═══════════════════════════════════════════════════════
       PAGINATION – VinFur Style (circle numbers)
       ═══════════════════════════════════════════════════════ */
    .tf-pagination {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0.5rem;
        margin-top: 3rem;
        list-style: none;
        padding: 0;
    }
    .tf-pagination .pagination-item a,
    .tf-pagination .pagination-item span {
        min-width: 36px;
        height: 36px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        text-decoration: none;
        font-size: 0.82rem;
        font-weight: 500;
        color: #555;
        border-radius: 50%;
        border: 1px solid transparent;
        background: transparent;
        transition: all 0.2s ease;
    }
    .tf-pagination .pagination-item a:hover {
        background: #f5f0eb;
        color: #111;
    }
    .tf-pagination .pagination-item.active span {
        background: #c4a76e;
        color: #fff;
        border-color: #c4a76e;
    }
    .tf-pagination .pagination-item.next-prev a {
        min-width: auto;
        padding: 0 0.5rem;
        border-radius: 0;
        font-weight: 700;
        font-size: 0.72rem;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        color: #111;
    }
    .tf-pagination .pagination-item.next-prev a:hover {
        background: transparent;
        color: #a68b6a;
    }

    /* ── Empty State ── */
    .tf-blog-empty {
        padding: 4.5rem 2rem;
        background: #faf8f6;
        border: 1px dashed #e0dbd6;
        text-align: center;
        color: #888;
    }
    .tf-blog-empty .empty-icon {
        font-size: 3.5rem;
        color: #d4d0cb;
        margin-bottom: 1.5rem;
    }
    .tf-blog-empty h3 {
        margin-bottom: 0.5rem;
        color: #444;
    }
    .tf-blog-empty .btn-explore {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        margin-top: 1rem;
        padding: 0.8rem 2rem;
        background: #111;
        color: #fff;
        text-decoration: none;
        font-size: 0.85rem;
        font-weight: 700;
        letter-spacing: 0.06em;
        transition: background 0.2s ease;
    }
    .tf-blog-empty .btn-explore:hover {
        background: #333;
        color: #fff;
    }

    /* ── Search results heading ── */
    .tf-search-results-heading {
        margin-bottom: 1.5rem;
    }
    .tf-search-results-heading h2 {
        font-size: 1.2rem;
        font-weight: 700;
        color: #111;
        margin: 0 0 0.3rem;
    }
    .tf-search-results-heading p {
        color: #888;
        font-size: 0.85rem;
        margin: 0;
    }

    /* ═══════════════════════════════════════════════════════
       RESPONSIVE
       ═══════════════════════════════════════════════════════ */


/* ----- frontend/blog/show.blade.php block 1 ----- */

/* ══════════════════════════════════════════════════════════
       VinFur – Blog Detail / Post (Pixel-Perfect from Screenshot)
       ══════════════════════════════════════════════════════════ */

    /* breadcrumb is handled by store-breadcrumb component */

    /* ── Post Body Section ────────────────────────────────── */
    .tf-post-section {
        padding: 1rem 0 4rem;
    }
    .tf-post-layout {
        display: grid;
        grid-template-columns: 180px minmax(0, 1fr);
        gap: 2rem;
        align-items: start;
    }

    /* ═══════════════════════════════════════════════════════
       LEFT SIDEBAR — Author Card + Categories + Tags
       ═══════════════════════════════════════════════════════ */
    .tf-post-sidebar {
        position: sticky;
        top: 100px;
        align-self: start;
        padding-top: 2.5rem;
    }

    /* ── Author Card ── */
    .tf-author-card {
        text-align: center;
        margin-bottom: 2rem;
    }
    .tf-author-avatar {
        width: 100px;
        height: 100px;
        border-radius: 50%;
        margin: 0 auto 0.75rem;
        overflow: hidden;
        background: #f0ece7;
    }
    .tf-author-avatar img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .tf-author-avatar .avatar-placeholder {
        width: 100%;
        height: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        background: linear-gradient(135deg, #e8e3dd, #d4cec6);
        color: #a09890;
        font-size: 2.5rem;
    }
    .tf-author-name {
        font-family: var(--font-display);
        font-size: 0.95rem;
        font-weight: 700;
        color: #111;
        margin: 0 0 0.2rem;
    }
    .tf-author-role {
        font-size: 0.72rem;
        color: #999;
        font-weight: 400;
        margin: 0 0 0.75rem;
    }
    .tf-author-socials {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0.5rem;
    }
    .tf-author-socials a {
        width: 32px;
        height: 32px;
        border-radius: 50%;
        border: 1px solid #e0dbd6;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        color: #666;
        text-decoration: none;
        font-size: 0.82rem;
        transition: all 0.2s ease;
    }
    .tf-author-socials a:hover {
        background: #111;
        border-color: #111;
        color: #fff;
    }

    /* ── Sidebar Widget ── */
    .tf-post-sidebar-widget {
        margin-bottom: 1.75rem;
    }
    .tf-post-sidebar-widget .widget-title {
        font-family: var(--font-display);
        font-size: 0.72rem;
        font-weight: 700;
        letter-spacing: 0.14em;
        text-transform: uppercase;
        color: #111;
        margin: 0 0 0.75rem;
    }

    /* ── Sidebar Categories ── */
    .tf-post-sidebar-cats {
        list-style: none;
        margin: 0;
        padding: 0;
    }
    .tf-post-sidebar-cats li a {
        display: block;
        padding: 0.3rem 0;
        text-decoration: none;
        color: #777;
        font-size: 0.82rem;
        font-weight: 400;
        transition: color 0.2s ease;
    }
    .tf-post-sidebar-cats li a:hover {
        color: #111;
    }

    /* ── Sidebar Tags ── */
    .tf-post-sidebar-tags {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0;
        line-height: 1.9;
    }
    .tf-post-sidebar-tags a {
        display: inline;
        color: #777;
        font-size: 0.78rem;
        font-weight: 400;
        text-decoration: none;
        transition: color 0.2s ease;
    }
    .tf-post-sidebar-tags a:hover { color: #111; }
    .tf-post-sidebar-tags .tag-sep {
        color: #ccc;
        margin: 0 0.3rem;
        font-size: 0.68rem;
    }

    /* ═══════════════════════════════════════════════════════
       MAIN CONTENT — Meta + Article + Tags + Share + Nav
       ═══════════════════════════════════════════════════════ */
    .tf-post-main {
        min-width: 0;
        padding-top: 0.2rem;
    }

    /* ── Post Meta Row ── */
    .tf-post-meta {
        display: flex;
        align-items: center;
        flex-wrap: wrap;
        gap: 0;
        margin-bottom: 0.8rem;
        font-size: 0.78rem;
        color: #999;
    }
    .tf-post-excerpt {
        color: #555;
        font-size: 0.92rem;
        line-height: 1.85;
        margin-bottom: 1.1rem;
    }
    .tf-post-meta .meta-item {
        display: inline-flex;
        align-items: center;
        gap: 0.35rem;
    }
    .tf-post-meta .meta-item i {
        font-size: 0.85rem;
        color: #c4a76e;
    }
    .tf-post-meta .meta-sep {
        display: inline-block;
        width: 4px;
        height: 4px;
        border-radius: 50%;
        background: #d4d0cb;
        margin: 0 0.75rem;
    }

    /* ── Article Content ── */
    .tf-post-content {
        color: #444;
        font-size: 0.92rem;
        line-height: 1.85;
    }
    .tf-post-content > *:first-child { margin-top: 0; }
    .tf-post-content > *:last-child { margin-bottom: 0; }
    .tf-post-content p {
        margin: 0 0 1.25rem;
        color: #555;
        line-height: 1.85;
    }
    .tf-post-content h1,
    .tf-post-content h2,
    .tf-post-content h3,
    .tf-post-content h4,
    .tf-post-content h5,
    .tf-post-content h6 {
        font-family: var(--font-display);
        color: #111;
        margin: 2rem 0 0.75rem;
        line-height: 1.3;
        font-weight: 700;
    }
    .tf-post-content h2 { font-size: 1.15rem; font-style: italic; }
    .tf-post-content h3 { font-size: 1.05rem; font-style: italic; }
    .tf-post-content ul, .tf-post-content ol {
        padding-left: 1.5rem;
        margin: 0.75rem 0 1.25rem;
    }
    .tf-post-content li {
        margin-bottom: 0.5rem;
        color: #555;
        line-height: 1.75;
    }
    .tf-post-content a {
        color: #c4a76e;
        text-decoration: underline;
        text-underline-offset: 3px;
    }
    .tf-post-content img {
        margin: 1.5rem 0;
        max-width: 100%;
        height: auto;
    }
    .tf-post-content blockquote {
        margin: 1.5rem 0;
        padding: 1rem 1.25rem;
        border-left: 3px solid #c4a76e;
        background: #faf8f5;
        color: #666;
        font-style: italic;
    }
    .tf-post-content table {
        width: 100%;
        margin: 1.5rem 0;
        border-collapse: collapse;
    }
    .tf-post-content th, .tf-post-content td {
        padding: 0.7rem 0.85rem;
        border: 1px solid #e8e4df;
        text-align: left;
        font-size: 0.88rem;
    }
    .tf-post-content th {
        background: #faf8f5;
        font-weight: 700;
    }
    .tf-post-content pre {
        margin: 1.5rem 0;
        padding: 1rem;
        background: #1e1e1e;
        color: #d4d4d4;
        overflow-x: auto;
        font-size: 0.85rem;
    }
    .tf-post-content code {
        font-family: Consolas, 'Courier New', monospace;
    }

    /* ── Featured Image ── */
    .tf-post-featured-img {
        margin-bottom: 1.5rem;
        overflow: hidden;
    }
    .tf-post-featured-img img {
        width: 100%;
        display: block;
    }

    /* ── Tags + Share Row ── */
    .tf-post-footer-row {
        display: flex;
        align-items: center;
        justify-content: space-between;
        flex-wrap: wrap;
        gap: 1rem;
        padding-top: 1.5rem;
        margin-top: 2rem;
        border-top: 1px solid #e8e4df;
    }
    .tf-post-footer-tags {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
    }
    .tf-post-footer-tags .tag-pill {
        display: inline-block;
        background: #f5f0eb;
        color: #555;
        font-size: 0.68rem;
        font-weight: 600;
        padding: 5px 12px;
        text-decoration: none;
        transition: all 0.2s ease;
    }
    .tf-post-footer-tags .tag-pill:hover {
        background: #111;
        color: #fff;
    }
    .tf-post-share {
        display: flex;
        align-items: center;
        gap: 0.5rem;
    }
    .tf-post-share .share-label {
        font-size: 0.78rem;
        font-weight: 500;
        color: #999;
        margin-right: 0.25rem;
    }
    .tf-post-share a {
        width: 32px;
        height: 32px;
        border-radius: 50%;
        border: 1px solid #e0dbd6;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        color: #666;
        text-decoration: none;
        font-size: 0.82rem;
        transition: all 0.2s ease;
    }
    .tf-post-share a:hover {
        background: #111;
        border-color: #111;
        color: #fff;
    }

    /* ── Prev / Next Navigation ── */
    .tf-post-nav {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 1.25rem 0;
        margin-top: 1.25rem;
        border-top: 1px solid #e8e4df;
        border-bottom: 1px solid #e8e4df;
    }
    .tf-post-nav a {
        display: inline-flex;
        align-items: center;
        gap: 0.4rem;
        text-decoration: none;
        font-size: 0.72rem;
        font-weight: 700;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: #111;
        transition: color 0.2s ease;
    }
    .tf-post-nav a:hover {
        color: #c4a76e;
    }
    .tf-post-nav .nav-arrow {
        font-size: 0.78rem;
    }

    /* ═══════════════════════════════════════════════════════
       COMMENT FORM
       ═══════════════════════════════════════════════════════ */
    .tf-comment-section {
        margin-top: 2rem;
        padding-top: 0;
    }
    .tf-comment-section .comment-title {
        font-family: var(--font-display);
        font-size: 0.85rem;
        font-weight: 700;
        letter-spacing: 0.1em;
        text-transform: uppercase;
        color: #111;
        margin: 0 0 0.5rem;
    }
    .tf-comment-section .comment-note {
        font-size: 0.75rem;
        color: #aaa;
        margin: 0 0 1.25rem;
    }
    .tf-comment-form {
        display: grid;
        gap: 1rem;
    }
    .tf-comment-form .form-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 1rem;
    }
    .tf-comment-form input,
    .tf-comment-form textarea {
        width: 100%;
        padding: 0.75rem 0;
        border: none;
        border-bottom: 1px solid #e0dbd6;
        background: transparent;
        font-size: 0.85rem;
        color: #333;
        outline: none;
        transition: border-color 0.2s ease;
        font-family: inherit;
    }
    .tf-comment-form input:focus,
    .tf-comment-form textarea:focus {
        border-bottom-color: #111;
    }
    .tf-comment-form input::placeholder,
    .tf-comment-form textarea::placeholder {
        color: #bbb;
        font-weight: 400;
    }
    .tf-comment-form textarea {
        min-height: 100px;
        resize: vertical;
    }
    .tf-comment-form .btn-submit {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 0.85rem 2.5rem;
        background: #111;
        color: #fff;
        border: none;
        font-size: 0.72rem;
        font-weight: 700;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        cursor: pointer;
        width: fit-content;
        transition: background 0.2s ease;
    }
    .tf-comment-form .btn-submit:hover {
        background: #333;
    }

    /* ═══════════════════════════════════════════════════════
       RESPONSIVE
       ═══════════════════════════════════════════════════════ */


/* ----- frontend/pages/cms.blade.php block 1 ----- */

.cms-page-wrap {
        padding-bottom: 4rem;
    }

    .cms-page-surface {
        width: 100%;
        background: transparent;
        border: none;
        border-radius: 0;
        padding: 0;
        box-shadow: none;
    }

    .cms-page-content {
        width: 100%;
        color: var(--text);
    }

    .cms-page-content > *:first-child {
        margin-top: 0;
    }

    .cms-page-content > *:last-child {
        margin-bottom: 0;
    }

    .cms-page-content h1,
    .cms-page-content h2,
    .cms-page-content h3,
    .cms-page-content h4,
    .cms-page-content h5,
    .cms-page-content h6 {
        margin: 0 0 1rem;
        color: var(--text);
        line-height: 1.2;
        font-weight: 800;
    }

    .cms-page-content h2,
    .cms-page-content h3,
    .cms-page-content h4,
    .cms-page-content h5,
    .cms-page-content h6 {
        margin-top: 2.5rem;
    }

    .cms-page-content p,
    .cms-page-content li {
        color: var(--text);
        font-size: 1.05rem;
        line-height: 1.8;
    }

    .cms-page-content p {
        margin: 0 0 0.4rem;
    }

    .cms-page-content ul,
    .cms-page-content ol {
        margin: 0 0 1.5rem;
        padding-left: 1.4rem;
    }

    .cms-page-content a {
        color: var(--accent);
        text-decoration: underline;
        text-underline-offset: 4px;
    }

    .cms-page-content img {
        max-width: 100%;
        height: auto;
        margin: 2rem 0;
        border-radius: 12px;
    }

    .cms-page-content blockquote {
        margin: 2rem 0;
        padding: 1.2rem 1.5rem;
        border-left: 3px solid var(--accent);
        background: #f9f9f9;
        color: var(--text-muted);
        border-radius: 0 8px 8px 0;
        font-style: italic;
    }

    .cms-page-content table {
        width: 100%;
        margin: 2rem 0;
        border-collapse: collapse;
    }

    .cms-page-content th,
    .cms-page-content td {
        padding: 1rem;
        border: 1px solid var(--border);
        text-align: left;
    }

    .cms-page-content th {
        background: #f9f9f9;
        font-weight: 700;
    }

    .cms-page-content pre {
        margin: 2rem 0;
        padding: 1.2rem;
        border-radius: 12px;
        background: #0f172a;
        color: #e2e8f0;
        overflow-x: auto;
    }

    .cms-page-content code {
        font-family: Consolas, monospace;
    }

    .cms-page-support {
        margin-top: 4rem;
        padding: 2.5rem 0;
        border-top: 1px solid var(--border);
        display: flex;
        align-items: center;
        justify-content: space-between;
        flex-wrap: wrap;
        gap: 1.5rem;
    }

    .cms-page-support-copy {
        font-size: 1.1rem;
        font-weight: 600;
        color: var(--text);
    }


/* ----- frontend/partials/phone-input.blade.php block 1 ----- */

.phone-input-container .input-group {
        display: flex;
        border: 1.5px solid var(--border-strong);
        border-radius: var(--radius-sm);
        overflow: hidden;
        transition: border-color 0.2s ease;
    }
    .phone-input-container .input-group:focus-within {
        border-color: var(--primary);
        box-shadow: 0 0 0 4px rgba(0, 0, 0, 0.04);
    }
    .phone-input-container .country-select-wrapper {
        border-right: 1.5px solid var(--border-strong);
        background: #f9f9f9;
        display: flex;
        align-items: center;
    }
    .phone-input-container .country-code-select {
        border: 0 !important;
        background: transparent !important;
        font-weight: 700;
        font-size: 0.9rem;
        padding: 0 0.75rem 0 1rem;
        min-height: 52px;
        width: 110px;
        box-shadow: none !important;
        cursor: pointer;
    }
    .phone-input-container .phone-number-input {
        border: 0 !important;
        padding-left: 1.25rem;
        min-height: 52px;
        box-shadow: none !important;
        font-weight: 500;
    }


/* ----- frontend/layouts/partials/mobile-bottom-nav.blade.php block 1 ----- */

/* ── Mobile Bottom Nav (App-like) ──────────────────────────────── */
.mobile-bottom-nav {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100% !important;
    max-width: 100vw !important;
    height: 65px;
    background: #ffffff;
    border-top: 1px solid var(--border);
    z-index: 1045;
    padding-bottom: env(safe-area-inset-bottom);
    box-shadow: 0 -2px 10px rgba(0,0,0,0.03);
    overflow: hidden !important;
}

.mobile-bottom-nav-inner {
    display: flex;
    align-items: center;
    justify-content: space-around;
    height: 100%;
    padding: 0 0.5rem;
}

.mobile-nav-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--text-muted);
    text-decoration: none;
    font-size: 0.65rem;
    font-weight: 700;
    gap: 4px;
    flex: 1;
    height: 100%;
    transition: color 0.2s;
    position: relative;
    -webkit-tap-highlight-color: transparent;
}

.mobile-nav-item i {
    font-size: 1.25rem;
    line-height: 1;
}

.mobile-nav-item:hover,
.mobile-nav-item.active {
    color: var(--primary);
}

.mobile-nav-item .action-count {
    position: absolute;
    top: 6px;
    right: calc(50% - 14px);
    width: 16px;
    height: 16px;
    font-size: 10px;
}


/* ----- frontend/layouts/partials/scroll-top.blade.php block 1 ----- */

.scroll-top-wrapper {
        position: fixed;
        bottom: 30px;
        right: 30px;
        width: 50px;
        height: 50px;
        z-index: 1000;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        opacity: 0;
        visibility: hidden;
        transform: translateY(20px);
        transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    }

    .scroll-top-wrapper.is-visible {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
    }

    .progress-ring {
        position: absolute;
        top: 0;
        left: 0;
        transform: rotate(-90deg);
        color: var(--primary, #000);
    }

    .progress-ring__circle {
        stroke-dasharray: 138.23; /* 2 * PI * r (2 * 3.14159 * 22) */
        stroke-dashoffset: 138.23;
        transition: stroke-dashoffset 0.1s linear;
    }

    .scroll-top-inner {
        width: 40px;
        height: 40px;
        border-radius: 50%;
        background: #000;
        color: #fff;
        border: none;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 1.2rem;
        box-shadow: 0 4px 12px rgba(0,0,0,0.15);
        transition: all 0.3s ease;
        position: relative;
        z-index: 2;
    }

    .scroll-top-wrapper:hover .scroll-top-inner {
        transform: scale(1.1);
        background: var(--primary, #333);
        box-shadow: 0 6px 16px rgba(0,0,0,0.2);
    }


/* ----- auth/login.blade.php block 1 ----- */

.auth-card { background: #fff; border: 1px solid var(--border); border-radius: 4px; padding: 40px; max-width: 480px; margin: 0 auto; box-shadow: var(--shadow-md); }
    .auth-divider { display: flex; align-items: center; gap: 12px; margin: 20px 0; color: var(--text-muted); font-size: .85rem; }
    .auth-divider::before, .auth-divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }
    .social-btn { display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%; padding: 11px; border: 1px solid var(--border); border-radius: 4px; background: #fff; font-size: .9rem; font-weight: 600; cursor: pointer; transition: all .2s; text-decoration: none; color: var(--text); }
    .social-btn:hover { background: var(--bg-light); color: var(--text); }


/* ----- auth/register.blade.php block 1 ----- */

.auth-card { background: #fff; border: 1px solid var(--border); border-radius: 4px; padding: 40px; max-width: 520px; margin: 0 auto; box-shadow: var(--shadow-md); }
    #registerForm .invalid-feedback { display: block; width: 100%; margin-top: 0.35rem; }


/* ----- frontend/account/invoice.blade.php block 1 ----- */

.invoice-page{color:#333;font-size:var(--text-sm);margin:0;padding:20px;}
        .invoice-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #667eea;}
        .brand{font-family:var(--font-display);font-size:24px;font-weight:var(--font-weight-extrabold);line-height:var(--line-height-heading);letter-spacing:var(--tracking-tight);color:#667eea;}
        .section-title{font-size:var(--text-xs);font-weight:var(--font-weight-bold);line-height:var(--line-height-compact);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:#718096;margin-bottom:8px;}
        table{width:100%;border-collapse:collapse;margin-bottom:20px;}
        th{background:#f7fafc;border-bottom:2px solid #e2e8f0;padding:10px;text-align:left;font-size:var(--text-xs);font-weight:var(--font-weight-bold);line-height:var(--line-height-compact);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:#718096;}
        td{padding:10px;border-bottom:1px solid #f0f0f0;line-height:1.55;}
        .totals{width:280px;margin-left:auto;}
        .total-row{display:flex;justify-content:space-between;padding:6px 0;font-size:var(--text-sm);line-height:1.5;}
        .total-final{font-size:var(--text-base);font-weight:var(--font-weight-bold);border-top:2px solid #333;margin-top:6px;padding-top:6px;}

/* =============================================================================
   Inline migration — auth, product share, utilities
   ============================================================================= */

.auth-heading { text-align: center; margin-bottom: 2rem; }
.auth-title { font-size: 1.5rem; font-weight: 800; margin-bottom: 0.375rem; }
.auth-title--sm { font-size: 1.4rem; margin-bottom: 0.5rem; }
.auth-subtitle { color: var(--text-muted); font-size: 0.875rem; }
.auth-subtitle--lead { line-height: 1.6; }
.auth-footer { text-align: center; margin-top: 1.5rem; font-size: 0.875rem; color: var(--text-muted); }
.auth-inline-link { color: var(--primary); font-weight: 600; }
.link-forgot { font-size: 0.8rem; color: var(--primary); }
.alert-tight { border-radius: 4px; font-size: 0.875rem; }
.alert-rounded { border-radius: 12px; font-size: 0.875rem; }
.btn-auth-submit { padding: 13px; border-radius: 4px; font-size: 0.95rem; font-weight: 700; }
.btn-auth-submit--round { border-radius: 12px; }
.btn-icon-toggle { cursor: pointer; }
.form-check-remember { font-size: 0.875rem; cursor: pointer; }
.auth-panel { background: #fff; border: 1px solid var(--border); border-radius: 20px; padding: 40px; max-width: 460px; margin: 0 auto; box-shadow: 0 4px 30px rgba(0,0,0,.06); }
.auth-icon-circle { width: 60px; height: 60px; border-radius: 50%; background: rgba(102,126,234,.1); color: var(--primary); display: inline-flex; align-items: center; justify-content: center; font-size: 1.5rem; margin-bottom: 1rem; }
.input-joined .input-group-text { background: var(--bg-light); border-color: var(--border); }
.input-joined .form-control { border-left: none; }

.placeholder-media-xl { width: 100%; height: 100%; display: grid; place-items: center; color: var(--text-soft); }
.placeholder-media-xl i { font-size: 4rem; }
.placeholder-media-md { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: var(--text-soft); }
.placeholder-media-md i { font-size: 3rem; }
.img-contain-brand { max-height: 44px; object-fit: contain; }
.text-soft-sm { color: var(--text-soft); font-size: 0.82rem; }

.stock-ok { color: #10b981; font-weight: 800; }
.stock-bad { color: #ef4444; font-weight: 800; }

.product-share-wrap { position: relative; }
.share-dropdown.share-dropdown--panel {
    display: none;
    position: absolute;
    bottom: calc(100% + 8px);
    left: 0;
    background: #fff;
    border: 1px solid #e0dbd6;
    box-shadow: 0 4px 16px rgba(0,0,0,0.1);
    z-index: 100;
    min-width: 220px;
    padding: 0.5rem 0;
    max-height: 400px;
    overflow-y: auto;
}
.share-dropdown-item--divider { border-top: 1px solid #f0ece7; margin-top: 0.25rem; padding-top: 0.65rem; }
.share-ico-facebook { color: #1877F2; }
.share-ico-instagram { color: #E4405F; }
.share-ico-x { color: #000; }
.share-ico-whatsapp { color: #25D366; }
.share-ico-telegram { color: #0088cc; }
.share-ico-pinterest { color: #BD081C; }
.share-ico-linkedin { color: #0A66C2; }
.share-ico-snapchat { color: #FFFC00; text-shadow: 0 0 1px #333; }
.share-ico-reddit { color: #FF5700; }
.share-ico-neutral { color: #666; }

.review-form-card--max { max-width: 720px; }
.review-section-title { font-size: 1.3rem; margin-bottom: 0.35rem; }
.review-section-lead { color: var(--text-muted); margin-bottom: 1rem; }
.surface-card--padded-max { max-width: 720px; padding: 1.2rem; }
.text-muted-tight { color: var(--text-muted); margin-top: 0.35rem; }
.review-stack { margin-top: 1rem; }
.review-card--max { max-width: 820px; }
.review-meta-date { color: var(--text-soft); font-size: 0.82rem; }
.review-stars-inline { margin-left: auto; color: #000; display: inline-flex; gap: 0.15rem; }
.review-item-title { font-size: 1rem; margin-bottom: 0.45rem; }
.review-body-text { margin: 0; color: var(--text-muted); }
.surface-card--empty-muted { max-width: 720px; padding: 1.2rem; color: var(--text-muted); }

.field-error-sm { font-size: 0.8rem; }
.label-tracked { letter-spacing: 0.5px; }


.shop-filter-toggle--static { cursor: default; pointer-events: none; }

/* Account area — reviews, wishlist */
.account-section-title { font-weight: 800; margin-bottom: 1.25rem; }
.account-review-card { background: #fff; border: 1px solid var(--border); border-radius: 16px; padding: 20px; margin-bottom: 14px; }
.account-review-row { display: flex; align-items: flex-start; gap: 14px; }
.account-review-thumb { width: 60px; height: 60px; border-radius: 10px; object-fit: cover; flex-shrink: 0; }
.account-review-body { flex: 1; min-width: 0; }
.account-review-product-link { font-weight: 700; margin-bottom: 2px; }
.account-review-product-link a { color: var(--text); text-decoration: none; }
.account-review-stars { color: #f6ad55; margin-bottom: 6px; }
.account-review-item-title { font-weight: 600; font-size: 0.9rem; margin-bottom: 4px; }
.account-review-text { font-size: 0.875rem; color: var(--text-muted); line-height: 1.6; }
.account-review-aside { text-align: right; flex-shrink: 0; }
.account-review-date { font-size: 0.75rem; color: var(--text-muted); }
.badge-pill-approved { font-size: 0.72rem; background: rgba(72,187,120,.1); color: var(--success); padding: 3px 10px; border-radius: 20px; font-weight: 600; display: inline-block; margin-top: 4px; }
.badge-pill-pending { font-size: 0.72rem; background: rgba(246,173,85,.1); color: #c05621; padding: 3px 10px; border-radius: 20px; font-weight: 600; display: inline-block; margin-top: 4px; }
.badge-pill-rejected { font-size: 0.72rem; background: rgba(252,129,129,.1); color: #c53030; padding: 3px 10px; border-radius: 20px; font-weight: 600; display: inline-block; margin-top: 4px; }
.account-empty-state { text-align: center; padding: 60px; background: #fff; border: 1px solid var(--border); border-radius: 16px; }
.account-empty-icon { font-size: 3.5rem; color: #e2e8f0; margin-bottom: 16px; display: block; }
