/**
 * PAGES.CSS
 * =========
 * Page-specific styles for InkCartridges.co.nz
 *
 * This file contains styles for:
 * - Homepage sections
 * - Category pages
 * - Product pages
 * - Cart and Checkout
 * - Account pages
 * - Business pages
 * - Informational pages
 * - Error pages
 */

/* ==========================================================================
   HOMEPAGE
   ========================================================================== */

/* Brand Grid - Mega menu brand columns */
.brand-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--spacing-lg);
}

.brand-column {
    text-align: left;
}

.brand-column__logo {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    height: 50px;
    margin-bottom: var(--spacing-sm);
    transition: all var(--transition-fast);
}

.brand-column__logo:hover {
    transform: scale(1.1);
}

.brand-column__img {
    width: auto;
    object-fit: contain;
}

/* Individual logo sizing to balance visual weight */
.brand-column__img--brother {
    height: 57px;
    margin-left: -4px;
}

.brand-column__img--canon {
    height: 48px;
}

.brand-column__img--epson {
    height: 20px;
}

.brand-column__img--hp {
    height: 37px;
    margin-left: -9px;
}

.brand-column__img--samsung {
    height: 20px;
}

.brand-column__name {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-heading);
    margin-bottom: var(--spacing-sm);
}

.brand-column__links {
    list-style: none;
    padding: 0;
    margin: 0;
}

.brand-column__links li {
    margin-bottom: var(--spacing-sm);
}

.brand-column__links a {
    font-size: var(--font-size-sm);
    color: var(--color-text);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.brand-column__links a:hover {
    color: var(--cyan-primary);
    text-decoration: underline;
}

@media (max-width: 1024px) {
    .brand-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--spacing-xl);
    }
}

@media (max-width: 768px) {
    .brand-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

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

/* Hero Section — Full-bleed background image */
.hero {
    padding: var(--spacing-3xl) 0 var(--spacing-2xl);
    background: url('/assets/images/hero-background.jpg') center center / cover no-repeat;
    text-align: center;
    position: relative;
    overflow: hidden;
}

/* Dark overlay for text readability */
.hero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.55);
    z-index: 0;
}

.hero .container {
    position: relative;
    z-index: 1;
}

.hero__title {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-extrabold);
    margin-bottom: var(--spacing-md);
    color: var(--white-primary);
    letter-spacing: var(--letter-spacing-tight);
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
}

.hero__title-highlight {
    color: var(--cyan-light);
}

.hero__subtitle {
    font-size: var(--font-size-lg);
    color: rgba(255, 255, 255, 0.9);
    margin-bottom: var(--spacing-lg);
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.6;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

.hero__trust-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
    margin-bottom: var(--spacing-xl);
}

.hero__stars {
    display: flex;
    gap: 2px;
}

.hero__trust-text {
    font-size: var(--font-size-sm);
    color: rgba(255, 255, 255, 0.85);
    font-weight: var(--font-weight-medium);
}

.hero__trust-sep {
    color: rgba(255, 255, 255, 0.5);
    font-size: var(--font-size-sm);
}

.hero__cta {
    display: flex;
    justify-content: center;
    gap: var(--spacing-md);
    flex-wrap: wrap;
}

.hero__btn-outline {
    color: var(--white-primary);
    border-color: rgba(255, 255, 255, 0.6);
}

.hero__btn-outline:hover {
    background-color: rgba(255, 255, 255, 0.15);
    border-color: var(--white-primary);
    color: var(--white-primary);
}

@media (max-width: 480px) {
    .hero__title {
        font-size: var(--font-size-xl);
    }

    .hero__subtitle {
        font-size: var(--font-size-base);
    }

    .hero__trust-row {
        flex-direction: column;
        gap: var(--spacing-xs);
    }

    .hero__trust-sep {
        display: none;
    }
}



/* Trust Bar - Bold accents */
.trust-bar {
    padding: var(--spacing-lg) 0;
    background-color: var(--steel-50);
    border-bottom: 1px solid var(--color-border);
}

.trust-bar__list {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--spacing-2xl);
}

.trust-bar__item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    color: var(--steel-700);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    transition: all 0.2s ease;
}

.trust-bar__item:hover {
    color: var(--cyan-primary);
}

.trust-bar__icon {
    font-size: var(--font-size-xl);
    color: var(--cyan-primary);
    transition: all 0.2s ease;
}

.trust-bar__item:hover .trust-bar__icon {
    transform: scale(1.1);
}

/* CMY color rotation for trust icons */
.trust-bar__item:nth-child(1) .trust-bar__icon { color: var(--cyan-primary); }
.trust-bar__item:nth-child(2) .trust-bar__icon { color: var(--magenta-primary); }
.trust-bar__item:nth-child(3) .trust-bar__icon { color: var(--yellow-dark); }
.trust-bar__item:nth-child(4) .trust-bar__icon { color: var(--cyan-dark); }

/* ==========================================================================
   FIND YOUR INK FAST - Guided Printer Finder
   ========================================================================== */

.ink-finder {
    padding: var(--spacing-lg) 0;
    background: linear-gradient(135deg, var(--cyan-dark) 0%, var(--cyan-primary) 100%);
}

.ink-finder__wrapper {
    background: var(--white-primary);
    border-radius: var(--radius-xl);
    padding: var(--spacing-md) var(--spacing-2xl) var(--spacing-xl);
    box-shadow: var(--shadow-xl);
    max-width: 1200px;
    margin: 0 auto;
    overflow-x: clip;
}

.ink-finder__header {
    text-align: center;
    margin-bottom: var(--spacing-md);
}

.ink-finder__title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-heading);
    margin: 0 0 var(--spacing-xs) 0;
}

.ink-finder__subtitle {
    font-size: var(--font-size-md);
    color: var(--color-text-muted);
    margin: 0;
}

/* Steps Layout */
.ink-finder__steps {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-lg);
    flex-wrap: nowrap;
}

.ink-finder__step {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.ink-finder__step[data-step="1"] {
    min-width: 0;
}

.ink-finder__step--disabled {
    opacity: 0.5;
    pointer-events: none;
}

.ink-finder__step--active {
    opacity: 1;
    pointer-events: auto;
}

.ink-finder__step--completed .ink-finder__step-number {
    background: var(--color-success);
}

/* Step Header */
.ink-finder__step-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.ink-finder__step-number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: var(--cyan-primary);
    color: var(--white-primary);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
    border-radius: 50%;
    flex-shrink: 0;
}

.ink-finder__step-label {
    font-size: 15px;
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    white-space: nowrap;
}

/* Brand Buttons Grid - 3x3 Layout */
.ink-finder__brands {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-sm);
    max-width: 340px;
}

.ink-finder__brand-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 98px;
    height: 75px;
    padding: var(--spacing-sm);
    background: var(--color-background-alt);
    border: 2px solid transparent;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
    flex-shrink: 0;
}

.ink-finder__brand-btn:hover {
    border-color: var(--cyan-light);
    background: var(--white-primary);
}

.ink-finder__brand-btn--selected {
    border-color: var(--cyan-primary);
    background: var(--cyan-light);
    box-shadow: var(--shadow-sm);
}

.ink-finder__brand-img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

/* Specific brand image sizing (50% larger) */
.ink-finder__brand-img--brother { height: 48px; }
.ink-finder__brand-img--canon { height: 39px; }
.ink-finder__brand-img--epson { height: 21px; }
.ink-finder__brand-img--hp { height: 36px; }
.ink-finder__brand-img--samsung { height: 21px; }
.ink-finder__brand-img--lexmark { height: 24px; }
.ink-finder__brand-img--oki { height: 28px; }
.ink-finder__brand-img--fuji-xerox { height: 28px; }
.ink-finder__brand-img--kyocera { height: 24px; }

/* Custom Select Dropdowns */
.custom-select {
    position: relative;
    width: 180px;
}

.custom-select__trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    height: 50px;
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
    font-family: inherit;
    text-align: left;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--white-primary);
    color: var(--color-text);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.custom-select__trigger:hover:not(:disabled) {
    border-color: var(--cyan-light);
}

.custom-select__trigger:focus {
    outline: none;
    border-color: var(--cyan-primary);
    box-shadow: 0 0 0 3px rgba(38, 127, 181, 0.15);
}

.custom-select__trigger:disabled {
    background-color: var(--color-background-alt);
    color: var(--color-text-muted);
    cursor: not-allowed;
}

.custom-select__trigger[aria-expanded="true"] {
    border-color: var(--cyan-primary);
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.custom-select__trigger[aria-expanded="true"] + .custom-select__dropdown {
    display: grid;
}

.custom-select__trigger[aria-expanded="true"] .custom-select__arrow {
    transform: rotate(180deg);
}

.custom-select__value {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
}

.custom-select__arrow {
    flex-shrink: 0;
    color: var(--color-text-muted);
    transition: transform var(--transition-fast);
}

/* Dropdown Menu */
.custom-select__dropdown {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    min-width: 180px;
    max-height: 280px; /* 6 rows of items with padding */
    overflow-y: auto;
    overscroll-behavior: contain;
    margin: 0;
    padding: var(--spacing-sm);
    list-style: none;
    background: var(--white-primary);
    border: 2px solid var(--cyan-primary);
    border-top: none;
    border-bottom-left-radius: var(--radius-md);
    border-bottom-right-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    z-index: 100;
    /* Grid layout applied when visible (via aria-expanded selector) */
    grid-template-columns: repeat(3, 1fr);
    grid-auto-flow: row;
    gap: var(--spacing-xs);
}

.custom-select__dropdown::-webkit-scrollbar {
    width: 6px;
}

.custom-select__dropdown::-webkit-scrollbar-track {
    background: var(--color-background-alt);
    border-radius: 3px;
}

.custom-select__dropdown::-webkit-scrollbar-thumb {
    background: var(--cyan-light);
    border-radius: 3px;
}

.custom-select__dropdown::-webkit-scrollbar-thumb:hover {
    background: var(--cyan-primary);
}

.custom-select__option {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
    color: var(--color-text);
    cursor: pointer;
    transition: all var(--transition-fast);
    border-radius: var(--radius-sm);
    background: var(--color-background-alt);
    white-space: normal;
    word-wrap: break-word;
    line-height: 1.3;
}

.custom-select__option:hover {
    background: var(--cyan-light);
    color: var(--cyan-dark);
}

.custom-select__option--selected {
    background: var(--cyan-primary);
    color: var(--white-primary);
    font-weight: var(--font-weight-medium);
}

.custom-select__option--selected:hover {
    background: var(--cyan-dark);
    color: var(--white-primary);
}

/* Empty state */
.custom-select__empty {
    padding: var(--spacing-md);
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    text-align: center;
    font-style: italic;
    grid-column: 1 / -1;
}

/* Responsive dropdown - single column on small screens */
@media (max-width: 600px) {
    .custom-select__dropdown {
        width: calc(100vw - 40px);
        max-width: calc(100vw - 40px);
        grid-template-columns: 1fr;
    }
}

/* Series dropdown - spans across to align with Find Compatible Ink button */
.ink-finder__step[data-step="2"] {
    position: relative;
}

.ink-finder__step[data-step="2"] .custom-select__dropdown {
    position: absolute;
    left: 0;
    width: 645px;
    max-width: calc(100vw - 48px);
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* Model dropdown - extends left to align with Series dropdown, 4 columns */
.ink-finder__step[data-step="3"] {
    position: relative;
}

.ink-finder__step[data-step="3"] .custom-select__dropdown {
    width: 645px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    left: -196px; /* Offset to align with Series dropdown (180px width + 16px gap) */
    right: auto;
}

.ink-finder .custom-select__trigger {
    font-size: 15px;
}

.ink-finder__step[data-step="2"] .custom-select__option,
.ink-finder__step[data-step="3"] .custom-select__option {
    white-space: normal;
    font-size: 15px;
    padding: 6px 8px;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

@media (max-width: 1024px) {
    .ink-finder__step[data-step="2"] .custom-select__dropdown {
        width: 540px;
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .ink-finder__step[data-step="2"] .custom-select__dropdown,
    .ink-finder__step[data-step="3"] .custom-select__dropdown {
        width: 100%;
        max-width: 100%;
        left: 0;
        right: 0;
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .ink-finder__step[data-step="2"] .custom-select__dropdown,
    .ink-finder__step[data-step="3"] .custom-select__dropdown {
        grid-template-columns: 1fr;
    }
}

/* Action Button */
.ink-finder__action {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    align-self: flex-start;
    margin-top: var(--spacing-xl);
}

.ink-finder__action-label {
    /* Spacer to align button with dropdowns */
    height: 24px;
    display: block;
}

.ink-finder__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    white-space: nowrap;
    height: 50px;
    padding: 0 var(--spacing-xl);
    flex-shrink: 0;
}

.ink-finder__btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Help Text */
.ink-finder__help {
    text-align: center;
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin: var(--spacing-lg) 0 0 0;
}

.ink-finder__help a {
    color: var(--cyan-primary);
    font-weight: var(--font-weight-medium);
}

.ink-finder__help a:hover {
    text-decoration: underline;
}

/* ============================================
 * Sticky CTA — May 2026 spec
 * (readfirst/ink-finder-may2026.md "Affordance")
 *
 * Appears at the bottom of the viewport once both series and model are
 * picked, but only when the inline submit button is off-screen — so the
 * customer never sees two of the same CTA stacked.
 * ============================================ */
.ink-finder__sticky-cta {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9000;
    background: var(--white-primary);
    border-top: 1px solid var(--color-border, #e2e8f0);
    box-shadow: 0 -8px 24px rgba(15, 23, 42, 0.12);
    padding: 12px 0 calc(12px + env(safe-area-inset-bottom, 0px));
    transform: translateY(100%);
    transition: transform 0.25s ease;
    pointer-events: none;
}

.ink-finder__sticky-cta--visible {
    transform: translateY(0);
    pointer-events: auto;
}

.ink-finder__sticky-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-md);
}

.ink-finder__sticky-label {
    flex: 1;
    min-width: 0;
    font-size: 14px;
    font-weight: var(--font-weight-medium);
    color: var(--color-text-heading);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ink-finder__sticky-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
    white-space: nowrap;
}

@media (max-width: 600px) {
    .ink-finder__sticky-label {
        display: none;
    }
    .ink-finder__sticky-btn {
        flex: 1;
        justify-content: center;
    }
}

/* "✓" prefix on selected model option (spec affordance). The dropdown JS
 * prepends the glyph to the textContent; bold weight comes from the
 * existing .custom-select__option--selected rule. This rule keeps the
 * glyph aligned and tinted to the cyan accent. */
.ink-finder__step[data-step="3"] .custom-select__option--selected {
    /* selected check is provided by JS-injected text "✓ <label>"; no
       pseudo-element needed. font-weight: 600 already applied via the
       shared .custom-select__option--selected rule. */
    letter-spacing: 0.01em;
}

/* Responsive - Ink Finder */
@media (max-width: 1200px) {
    .ink-finder__steps {
        flex-wrap: wrap;
        justify-content: center;
    }

    .ink-finder__action {
        width: auto;
    }

    .ink-finder__action-label {
        display: block;
        height: 24px;
    }

    .ink-finder__btn {
        justify-content: center;
    }
}

@media (max-width: 900px) {
    .ink-finder__steps {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: var(--spacing-md);
    }

    .ink-finder__step[data-step="1"] {
        grid-column: 1 / -1;
    }

    .ink-finder__brands {
        grid-template-columns: repeat(3, 1fr);
        max-width: 300px;
    }

    .ink-finder__action {
        grid-column: 1 / -1;
    }

    .ink-finder__action-label {
        display: none;
    }

    .ink-finder__btn {
        width: 100%;
    }
}

@media (max-width: 600px) {
    .ink-finder__wrapper {
        padding: var(--spacing-lg);
    }

    .ink-finder__steps {
        grid-template-columns: 1fr;
    }

    .ink-finder__brands {
        grid-template-columns: repeat(3, 1fr);
        max-width: 280px;
        margin: 0 auto;
    }

    .ink-finder__brand-btn {
        width: 85px;
        height: 65px;
    }

    .ink-finder__brand-img--brother { height: 38px; }
    .ink-finder__brand-img--canon { height: 30px; }
    .ink-finder__brand-img--epson { height: 16px; }
    .ink-finder__brand-img--hp { height: 28px; }
    .ink-finder__brand-img--samsung { height: 16px; }
    .ink-finder__brand-img--lexmark { height: 18px; }
    .ink-finder__brand-img--oki { height: 22px; }
    .ink-finder__brand-img--fuji-xerox { height: 22px; }
    .ink-finder__brand-img--kyocera { height: 18px; }

    .ink-finder__step--disabled {
        opacity: 0.4;
    }

    .custom-select {
        width: 100%;
    }
}

/* Ink Finder — Tab Switcher */
.ink-finder__tabs {
    display: flex;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-xl);
    border-bottom: 2px solid var(--color-border);
    padding-bottom: 0;
}

.ink-finder__tab {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-sm) var(--spacing-lg);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-muted);
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    cursor: pointer;
    transition: all var(--transition-fast);
    font-family: inherit;
}

.ink-finder__tab:hover {
    color: var(--cyan-primary);
}

.ink-finder__tab--active {
    color: var(--cyan-primary);
    border-bottom-color: var(--cyan-primary);
}

.ink-finder__tab svg {
    flex-shrink: 0;
}

/* Ink Finder — Tab Panels */
.ink-finder__tab-panel--hidden {
    display: none;
}

.ink-finder__panel-hint {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    text-align: center;
    margin: 0 0 var(--spacing-lg) 0;
}

/* Ink Finder — Cartridge Code Search */
.ink-finder__cartridge-search {
    text-align: center;
    padding: var(--spacing-lg) 0;
}

.ink-finder__cartridge-hint {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin: 0 0 var(--spacing-lg) 0;
}

.ink-finder__cartridge-form {
    display: flex;
    justify-content: center;
    gap: var(--spacing-md);
    max-width: 500px;
    margin: 0 auto;
}

.ink-finder__cartridge-input {
    flex: 1;
    height: 50px;
    padding: var(--spacing-sm) var(--spacing-lg);
    font-size: var(--font-size-base);
    font-family: inherit;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--white-primary);
    color: var(--color-text);
    transition: border-color var(--transition-fast);
}

.ink-finder__cartridge-input::placeholder {
    color: var(--color-text-muted);
}

.ink-finder__cartridge-input:focus {
    outline: none;
    border-color: var(--cyan-primary);
    box-shadow: 0 0 0 3px rgba(38, 127, 181, 0.15);
}

.ink-finder__cartridge-btn {
    flex-shrink: 0;
}

/* Ink Finder — Popular Printers */
.ink-finder__popular {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--color-border-light);
}

.ink-finder__popular-label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-muted);
}

.ink-finder__popular-chip {
    display: inline-block;
    padding: var(--spacing-xs) var(--spacing-md);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    color: var(--cyan-dark);
    background: var(--cyan-light);
    border-radius: var(--radius-full);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.ink-finder__popular-chip:hover {
    background: var(--cyan-primary);
    color: var(--white-primary);
}

/* Responsive — Ink Finder Tabs & Cartridge */
@media (max-width: 600px) {
    .ink-finder__tabs {
        gap: 0;
    }

    .ink-finder__tab {
        flex: 1;
        justify-content: center;
        padding: var(--spacing-sm) var(--spacing-sm);
        font-size: var(--font-size-xs);
    }

    .ink-finder__cartridge-form {
        flex-direction: column;
    }

    .ink-finder__cartridge-btn {
        width: 100%;
    }

    .ink-finder__popular {
        justify-content: center;
    }
}


/* ==========================================================================
   CATEGORIES SECTION (Landing)
   ========================================================================== */

.categories-section {
    padding: var(--spacing-3xl) 0;
    background: var(--color-background);
}

.categories-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--spacing-lg);
}

@media (max-width: 1024px) {
    .categories-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 600px) {
    .categories-section {
        padding: var(--spacing-2xl) 0;
    }

    .categories-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-md);
    }
}


/* ==========================================================================
   BRAND INTRO (Brand Landing Pages)
   ========================================================================== */

.brand-intro {
    max-width: 800px;
    margin: var(--spacing-md) 0 var(--spacing-lg);
    font-size: var(--font-size-sm);
    line-height: 1.75;
    color: var(--color-text);
}

.brand-intro p {
    margin: 0;
}

/* ==========================================================================
   FAQ SECTION (Landing)
   ========================================================================== */

.faq-section.faq-section {
    padding: var(--spacing-3xl) 0;
    background: var(--color-background);
    margin-bottom: 0;
}

.faq-list {
    max-width: 800px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.faq-item {
    background: var(--white-primary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: box-shadow var(--transition-normal);
}

.faq-item[open] {
    box-shadow: var(--shadow-md);
    border-color: var(--cyan-light);
}

.faq-question {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-heading);
    cursor: pointer;
    list-style: none;
    transition: color var(--transition-fast);
}

.faq-question::-webkit-details-marker {
    display: none;
}

.faq-question::marker {
    display: none;
    content: '';
}

.faq-question::after {
    content: '';
    display: inline-block;
    width: 10px;
    height: 10px;
    border-right: 2px solid var(--color-text-muted);
    border-bottom: 2px solid var(--color-text-muted);
    transform: rotate(45deg);
    flex-shrink: 0;
    margin-left: var(--spacing-md);
    transition: transform var(--transition-fast);
}

.faq-item[open] .faq-question::after {
    transform: rotate(-135deg);
}

.faq-question:hover {
    color: var(--cyan-primary);
}

.faq-answer {
    padding: 0 var(--spacing-lg) var(--spacing-lg);
    font-size: var(--font-size-sm);
    line-height: 1.7;
    color: var(--color-text);
    overflow: hidden;
    transition: max-height var(--transition-normal), opacity var(--transition-normal);
}

.faq-answer p {
    margin: 0;
}

@media (max-width: 600px) {
    .faq-section.faq-section {
        padding: var(--spacing-2xl) 0;
    }

    .faq-question {
        padding: var(--spacing-md);
        font-size: var(--font-size-sm);
    }

    .faq-answer {
        padding: 0 var(--spacing-md) var(--spacing-md);
    }
}


/* ==========================================================================
   STICKY HEADER
   ========================================================================== */

.site-header--sticky {
    position: sticky;
    top: 0;
    z-index: var(--z-sticky);
    box-shadow: var(--shadow-md);
}


/* ==========================================================================
   OEM VS COMPATIBLE COMPARISON
   ========================================================================== */

.comparison {
    padding: var(--spacing-3xl) 0;
    background-color: var(--color-background);
}

.comparison__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
}

.comparison__column {
    background: var(--white-primary);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    box-shadow: var(--shadow-md);
    border: 2px solid transparent;
    transition: all var(--transition-normal);
    display: flex;
    flex-direction: column;
}

.comparison__column:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.comparison__column--genuine {
    border-color: var(--color-border);
}

.comparison__column--genuine:hover {
    border-color: var(--color-primary);
}

.comparison__column--compatible {
    border-color: var(--cyan-primary);
    position: relative;
}

.comparison__column--compatible::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--cyan-primary), var(--cyan-dark));
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.comparison__header {
    text-align: center;
    padding-bottom: var(--spacing-lg);
    border-bottom: 1px solid var(--color-border);
    margin-bottom: var(--spacing-lg);
}

.comparison__badge {
    display: inline-block;
    padding: var(--spacing-2) var(--spacing-sm);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: var(--radius-full);
    margin-bottom: var(--spacing-sm);
}

.comparison__badge--genuine {
    background-color: var(--color-background-alt);
    color: var(--color-text);
}

.comparison__badge--compatible {
    background: linear-gradient(135deg, var(--cyan-primary), var(--cyan-dark));
    color: var(--white-primary);
}

.comparison__column-title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-heading);
    margin-bottom: var(--spacing-xs);
}

.comparison__column-subtitle {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin: 0;
}

.comparison__features {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--spacing-lg) 0;
    flex-grow: 1;
}

.comparison__feature {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) 0;
    font-size: var(--font-size-sm);
    color: var(--color-text);
    line-height: 1.5;
}

.comparison__feature:not(:last-child) {
    border-bottom: 1px solid var(--color-border-light);
}

.comparison__check {
    flex-shrink: 0;
    color: var(--color-success);
    margin-top: 2px;
}

.comparison__dash {
    flex-shrink: 0;
    color: var(--color-text-muted);
    margin-top: 2px;
}

.comparison__feature--neutral {
    color: var(--color-text-muted);
}

.comparison__footer {
    text-align: center;
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-border);
}

.comparison__best-for {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-md);
}

.comparison__best-for strong {
    color: var(--color-text);
}

.comparison__btn {
    width: 100%;
}

.comparison__note {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md) var(--spacing-lg);
    background-color: var(--cyan-primary-10);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    color: var(--color-text);
    text-align: center;
    margin: 0;
}

.comparison__note svg {
    flex-shrink: 0;
    color: var(--cyan-primary);
}

/* Responsive - Comparison */
@media (max-width: 900px) {
    .comparison__grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }

    .comparison__column--compatible {
        order: -1; /* Show compatible first on mobile */
    }
}

@media (max-width: 600px) {
    .comparison {
        padding: var(--spacing-2xl) 0;
    }

    .comparison__column {
        padding: var(--spacing-lg);
    }

    .comparison__note {
        flex-direction: column;
        text-align: center;
    }
}



/* ==========================================================================
   SOCIAL PROOF / CUSTOMER REVIEWS
   ========================================================================== */

.social-proof {
    padding: var(--spacing-3xl) 0;
    background-color: var(--white-primary);
}

.social-proof__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-xl);
}

.review-card {
    background: var(--color-background);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    display: flex;
    flex-direction: column;
    transition: all var(--transition-normal);
    border: 1px solid var(--color-border-light);
}

.review-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-4px);
    border-color: var(--color-border);
}

.review-card__stars {
    display: flex;
    gap: 2px;
    margin-bottom: var(--spacing-md);
    color: #f59e0b; /* Amber/gold for stars */
}

.review-card__quote {
    font-size: var(--font-size-md);
    color: var(--color-text);
    line-height: 1.7;
    margin: 0 0 var(--spacing-lg) 0;
    flex-grow: 1;
    font-style: italic;
    position: relative;
}

.review-card__quote::before {
    content: '"';
    position: absolute;
    top: -10px;
    left: -5px;
    font-size: 48px;
    color: var(--cyan-primary-10);
    font-family: Georgia, serif;
    line-height: 1;
    z-index: 0;
}

.review-card__author {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-border-light);
}

.review-card__name {
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-heading);
}

.review-card__location {
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

.review-card__location::before {
    content: '•';
    margin-right: var(--spacing-sm);
}

/* Responsive - Social Proof */
@media (max-width: 900px) {
    .social-proof__grid {
        grid-template-columns: 1fr;
        max-width: 500px;
        margin: 0 auto;
    }
}

@media (max-width: 600px) {
    .social-proof {
        padding: var(--spacing-2xl) 0;
    }

    .review-card {
        padding: var(--spacing-lg);
    }

    .review-card__quote {
        font-size: var(--font-size-sm);
    }
}


/* Section Headings */
.section-heading {
    text-align: center;
    margin-bottom: var(--spacing-2xl);
}

.section-heading__title {
    font-size: var(--font-size-2xl);
    margin-bottom: var(--spacing-sm);
}

.section-heading__subtitle {
    color: var(--color-text-light);
    max-width: 600px;
    margin: 0 auto;
}

/* Featured Sections */
.featured-categories,
.featured-products,
.brands,
.why-us,
.newsletter {
    padding: var(--spacing-3xl) 0;
}

.featured-categories {
    background-color: var(--color-background);
}

.featured-products {
    background-color: var(--color-background-alt);
}

/* Category Grid */
.category-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--spacing-lg);
}

/* Why Us / Benefits Section */
.why-us {
    background-color: var(--color-background);
}

.benefits-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--spacing-lg);
}

/* Brands Section */
.brands {
    background-color: var(--color-background-alt);
}

.brand-logos {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: var(--spacing-2xl);
}

.brand-logo {
    max-width: 120px;
    height: auto;
    filter: grayscale(100%);
    opacity: 0.6;
    transition: all var(--transition-normal);
}

.brand-logo:hover {
    filter: grayscale(0%);
    opacity: 1;
}

/* Product Finder Section */
.product-finder {
    padding: var(--spacing-3xl) 0;
    background-color: var(--color-background);
}

.finder-form {
    max-width: 900px;
    margin: 0 auto;
    padding: var(--spacing-xl);
}

.finder-form__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.finder-form__grid .form-group--button {
    display: flex;
    align-items: flex-end;
}

.finder-form__help {
    text-align: center;
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    margin-bottom: 0;
}

@media (max-width: 768px) {
    .finder-form__grid {
        grid-template-columns: 1fr;
    }
}

/* Brand Logos */
.brand-logo-link {
    display: block;
    transition: transform var(--transition-fast);
}

.brand-logo-link:hover {
    transform: scale(1.05);
    text-decoration: none;
}

.brand-logo-placeholder {
    width: 120px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-light);
    transition: all var(--transition-fast);
}

.brand-logo-link:hover .brand-logo-placeholder {
    border-color: var(--color-primary);
    color: var(--color-primary);
    box-shadow: var(--shadow-sm);
}

/* Newsletter Section */
.newsletter {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    color: var(--color-text-inverse);
    text-align: center;
}

.newsletter .section-heading__title {
    color: var(--color-text-inverse);
}

.newsletter .section-heading__subtitle {
    color: rgba(255, 255, 255, 0.8);
}

.newsletter__form {
    display: flex;
    justify-content: center;
    gap: var(--spacing-md);
    max-width: 500px;
    margin: 0 auto;
}

.newsletter__input {
    flex: 1;
    padding: var(--spacing-3) var(--spacing-4);
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-radius: var(--radius-md);
    background-color: rgba(255, 255, 255, 0.1);
    color: var(--color-text-inverse);
    font-size: var(--font-size-base);
}

.newsletter__input::placeholder {
    color: rgba(255, 255, 255, 0.6);
}

.newsletter__input:focus {
    outline: none;
    border-color: var(--color-text-inverse);
    background-color: rgba(255, 255, 255, 0.15);
}

.newsletter__button {
    padding: var(--spacing-3) var(--spacing-5);
    background-color: var(--color-accent);
    color: var(--color-text-inverse);
    border: none;
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-semibold);
    transition: background-color var(--transition-fast);
}

.newsletter__button:hover {
    background-color: var(--color-accent-dark);
}

.newsletter__privacy {
    margin-top: var(--spacing-md);
    font-size: var(--font-size-sm);
    color: rgba(255, 255, 255, 0.7);
}

.newsletter__privacy a {
    color: var(--color-text-inverse);
    text-decoration: underline;
}


/* ==========================================================================
   COMPATIBILITY GUARANTEE TRUST BLOCK
   ========================================================================== */

.trust-guarantee {
    padding: 0;
    margin-top: 0;
}

.trust-guarantee__bg {
    background: linear-gradient(135deg, #1a365d 0%, #2d4a6f 50%, #1e3a5f 100%);
    padding: var(--spacing-3xl) 0;
    position: relative;
    overflow: hidden;
}

/* Subtle pattern overlay */
.trust-guarantee__bg::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image:
        radial-gradient(circle at 20% 50%, rgba(255, 255, 255, 0.03) 0%, transparent 50%),
        radial-gradient(circle at 80% 80%, rgba(255, 255, 255, 0.03) 0%, transparent 50%);
    pointer-events: none;
}

.trust-guarantee__header {
    text-align: center;
    margin-bottom: var(--spacing-2xl);
}

.trust-guarantee__title {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--white-primary);
    margin-bottom: var(--spacing-sm);
}

.trust-guarantee__subtitle {
    font-size: var(--font-size-lg);
    color: rgba(255, 255, 255, 0.8);
    max-width: 600px;
    margin: 0 auto;
}

.trust-guarantee__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-2xl);
}

.trust-guarantee__item {
    text-align: center;
    padding: var(--spacing-lg);
    background: rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255, 255, 255, 0.1);
    transition: all var(--transition-normal);
}

.trust-guarantee__item:hover {
    background: rgba(255, 255, 255, 0.1);
    transform: translateY(-4px);
    border-color: rgba(255, 255, 255, 0.2);
}

.trust-guarantee__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    background: linear-gradient(135deg, var(--cyan-primary) 0%, var(--cyan-dark) 100%);
    border-radius: var(--radius-full);
    margin-bottom: var(--spacing-md);
    color: var(--white-primary);
    box-shadow: 0 8px 24px rgba(0, 188, 212, 0.3);
}

.trust-guarantee__item-title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--white-primary);
    margin-bottom: var(--spacing-sm);
}

.trust-guarantee__item-text {
    font-size: var(--font-size-sm);
    color: rgba(255, 255, 255, 0.75);
    line-height: 1.6;
    margin: 0;
}

.trust-guarantee__cta {
    text-align: center;
    padding-top: var(--spacing-lg);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.trust-guarantee__cta .btn {
    padding: var(--spacing-4) var(--spacing-8);
    font-size: var(--font-size-md);
}

.trust-guarantee__cta-note {
    margin-top: var(--spacing-md);
    font-size: var(--font-size-sm);
    color: rgba(255, 255, 255, 0.6);
}

/* Responsive - Tablet */
@media (max-width: 1024px) {
    .trust-guarantee__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Responsive - Mobile */
@media (max-width: 600px) {
    .trust-guarantee__bg {
        padding: var(--spacing-2xl) 0;
    }

    .trust-guarantee__title {
        font-size: var(--font-size-2xl);
    }

    .trust-guarantee__subtitle {
        font-size: var(--font-size-md);
    }

    .trust-guarantee__grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
    }

    .trust-guarantee__item {
        padding: var(--spacing-md);
    }

    .trust-guarantee__icon {
        width: 64px;
        height: 64px;
    }

    .trust-guarantee__icon svg {
        width: 32px;
        height: 32px;
    }
}


/* ==========================================================================
   CATEGORY / SHOP PAGES
   ========================================================================== */

.category-header {
    padding: var(--spacing-xl) 0;
    background-color: var(--color-background-alt);
    border-bottom: 1px solid var(--color-border);
}

.category-header__title {
    margin-bottom: var(--spacing-sm);
}

.category-header__description {
    color: var(--color-text-light);
    max-width: 800px;
}

.category-header__count {
    margin-top: var(--spacing-md);
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

/* Category page intro & FAQ (ink-cartridges, toner-cartridges) */
.category-intro {
    max-width: 800px;
    margin: 0 auto 2rem;
    line-height: 1.7;
    color: var(--color-text-light, #555);
}

.brand-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 2rem;
    justify-content: center;
}

.brand-filters__btn {
    padding: 0.5rem 1.25rem;
    border: 2px solid var(--color-border, #ddd);
    border-radius: var(--radius-sm, 6px);
    background: var(--white-primary, #fff);
    cursor: pointer;
    font-size: var(--font-size-sm, 0.95rem);
    font-weight: var(--font-weight-medium, 500);
    transition: all 0.2s;
}

.brand-filters__btn:hover {
    border-color: var(--color-primary, #267FB5);
    color: var(--color-primary, #267FB5);
}

.brand-filters__btn--active {
    background: var(--color-primary, #267FB5);
    color: var(--white-primary, #fff);
    border-color: var(--color-primary, #267FB5);
}

.faq-section {
    max-width: 800px;
    margin: 3rem auto;
}

.faq-section h2 {
    font-size: var(--font-size-xl, 1.5rem);
    margin-bottom: 1.5rem;
}

.faq-item {
    border-bottom: 1px solid var(--color-border, #e0e0e0);
}

.faq-item summary {
    padding: 1rem 0;
    cursor: pointer;
    font-weight: var(--font-weight-semibold, 600);
    font-size: 1.05rem;
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.faq-item summary::-webkit-details-marker {
    display: none;
}

.faq-item summary::after {
    content: '+';
    font-size: 1.4rem;
    font-weight: 300;
    transition: transform 0.2s;
}

.faq-item[open] summary::after {
    content: '\2212';
}

.faq-item .faq-answer {
    padding: 0 0 1rem;
    line-height: 1.7;
    color: var(--color-text-light, #555);
}

/* Filter Sidebar */
.filter-section {
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-lg);
    border-bottom: 1px solid var(--color-border);
}

.filter-section:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.filter-section__heading {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--spacing-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.filter-section__toggle {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    transition: transform var(--transition-fast);
}

.filter-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
}

.filter-list__item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.filter-list__count {
    margin-left: auto;
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

/* Price Filter */
.price-filter {
    display: flex;
    gap: var(--spacing-sm);
    align-items: center;
}

.price-filter__input {
    flex: 1;
    padding: var(--spacing-2) var(--spacing-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
}

.price-filter__separator {
    color: var(--color-text-muted);
}

/* Shop Toolbar */
.shop-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid var(--color-border);
    margin-bottom: var(--spacing-lg);
}

.shop-toolbar__info {
    color: var(--color-text-light);
    font-size: var(--font-size-sm);
}

.shop-toolbar__controls {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.shop-toolbar__sort {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.shop-toolbar__sort label {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

.shop-toolbar__sort select {
    padding: var(--spacing-2) var(--spacing-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    background-color: var(--color-background);
}

/* View Toggle */
.view-toggles {
    display: flex;
    gap: var(--spacing-1);
}

.view-toggle {
    padding: var(--spacing-2);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
    transition: all var(--transition-fast);
}

.view-toggle:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.view-toggle.active {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-text-inverse);
}

/* Active Filters */
.active-filters {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.active-filter {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-1);
    padding: var(--spacing-1) var(--spacing-3);
    background-color: var(--color-primary-bg);
    color: var(--color-primary);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
}

.active-filter__remove {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    margin-left: var(--spacing-1);
    border-radius: var(--radius-full);
    transition: background-color var(--transition-fast);
}

.active-filter__remove:hover {
    background-color: var(--color-primary);
    color: var(--color-text-inverse);
}


/* ==========================================================================
   PRODUCT PAGES
   ========================================================================== */

.product-detail {
    padding: var(--spacing-lg) 0 var(--spacing-md);
}

.product-detail__layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xl);
    align-items: stretch;
}

.product-detail__layout .product-gallery {
    position: relative;
    min-height: 0;
    overflow: hidden;
}

.product-detail__layout .product-gallery__main {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    aspect-ratio: unset;
    margin-bottom: 0;
    background-color: var(--product-image-bg);
}

.product-detail__layout .product-gallery__main img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* Product Gallery */
.product-gallery__main {
    aspect-ratio: 1;
    background-color: var(--product-image-bg);
    border-radius: var(--radius-xl);
    margin-bottom: var(--spacing-md);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.product-gallery__main img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.product-detail__layout--color-only {
    grid-template-columns: auto 1fr;
    gap: var(--spacing-xl);
}

.product-detail__layout--compatible {
    grid-template-columns: minmax(180px, 300px) 1fr;
    align-items: start;
}

.product-detail__layout--compatible .product-gallery__main {
    position: relative;
    aspect-ratio: 1;
}

.product-detail__layout--compatible .product-gallery__main img {
    object-fit: cover;
}

.product-gallery__main--color-only {
    aspect-ratio: auto;
    background-color: transparent;
    margin-bottom: 0;
}

.product-gallery__color-block {
    width: 96px;
    height: 96px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-lg);
}

/* Product Error State */
.product-error {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: var(--spacing-xl);
    gap: var(--spacing-md);
    min-height: 300px;
}

.product-error svg {
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-sm);
}

.product-error p {
    font-size: 1.125rem;
    color: var(--color-text-light);
    margin: 0;
}

.product-error .btn {
    margin-top: var(--spacing-xs);
}

.product-error .btn--outline {
    background: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-text);
}

.product-error .btn--outline:hover {
    background: var(--color-background-alt);
}

.product-gallery__thumbnails {
    display: flex;
    gap: var(--spacing-sm);
}

.product-gallery__thumb {
    width: 80px;
    height: 80px;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    cursor: pointer;
    overflow: hidden;
    transition: border-color var(--transition-fast);
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--product-image-bg);
}

.product-gallery__thumb:hover {
    border-color: var(--color-primary-light);
}

.product-gallery__thumb--active {
    border-color: var(--color-primary);
}

.product-gallery__thumb img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

/* Product Info */
.product-info__brand {
    font-family: var(--font-family-mono);
    color: var(--cyan-primary);
    font-size: 11px;
    font-weight: var(--font-weight-medium);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-extra-wide);
    margin-bottom: var(--spacing-sm);
}

.product-info__title {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-extrabold);
    letter-spacing: var(--letter-spacing-tight);
    margin-bottom: var(--spacing-xs);
}

.product-info__sku {
    font-family: var(--font-family-mono);
    color: var(--steel-400);
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-sm);
}

.product-info__pricing {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: var(--spacing-xs) var(--spacing-md);
    margin: var(--spacing-sm) 0 var(--spacing-xs);
    padding: var(--spacing-xs) 0;
}

.product-info__price {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
}

.product-info__price-was {
    font-size: var(--font-size-lg);
    color: var(--color-text-muted);
    text-decoration: line-through;
}

.product-info__price-save {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-accent);
    background-color: var(--color-accent-bg);
    padding: var(--spacing-1) var(--spacing-2);
    border-radius: var(--radius-sm);
}

.product-info__gst {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

/* Product Actions */
.product-info__actions {
    display: flex;
    gap: var(--spacing-md);
    margin: var(--spacing-sm) 0 var(--spacing-xs);
}

.product-info__actions .btn {
    padding: var(--spacing-2) var(--spacing-5);
    min-height: 40px;
}

.product-info__actions .btn--large {
    padding: var(--spacing-3) var(--spacing-6);
    min-height: 44px;
}

.product-info__quantity {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

/* Add-to-Cart Confirmation Strip */
.atc-confirmation {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 16px;
    background: #f0fdf4;
    border: 1px solid #86efac;
    border-radius: 8px;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height 0.35s ease, opacity 0.25s ease, padding 0.35s ease, margin-top 0.35s ease;
    margin-top: 0;
}
.atc-confirmation.atc-confirmation--visible {
    max-height: 56px;
    opacity: 1;
    padding: 12px 16px;
    margin-top: 12px;
}
.atc-confirmation__check {
    color: #16a34a;
    flex-shrink: 0;
    display: flex;
    align-items: center;
}
.atc-confirmation__text {
    flex: 1;
    font-size: 0.9rem;
    color: #15803d;
    font-weight: 500;
}
.atc-confirmation__cta {
    display: inline-flex;
    align-items: center;
    padding: 6px 14px;
    background: #16a34a;
    color: #fff;
    border-radius: 6px;
    font-size: 0.85rem;
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
    transition: background 0.15s ease;
}
.atc-confirmation__cta:hover {
    background: #15803d;
    color: #fff;
}

/* Product Trust Signals */
.product-info__trust {
    margin-top: var(--spacing-md);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-border);
}

.product-info__trust-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
    color: var(--color-text-light);
    font-size: var(--font-size-sm);
}

.product-info__trust-icon {
    color: var(--color-secondary);
    font-size: var(--font-size-md);
}

/* Product Compatibility */
.product-compatibility,
.recently-viewed {
    padding: var(--spacing-3xl) 0;
    border-top: 1px solid var(--color-border);
}

.related-products {
    padding: var(--spacing-md) 0 var(--spacing-lg);
    border-top: none;
}

.product-printers-wrap {
    padding: var(--spacing-sm) 0 0;
}

.compatibility-search {
    max-width: 400px;
    margin-bottom: var(--spacing-lg);
}

.compatibility-list {
    margin: var(--spacing-lg) 0;
}

.compatibility-brand {
    margin-bottom: var(--spacing-lg);
}

.compatibility-brand__name {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 1px solid var(--color-border-light);
}

.compatibility-models {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: var(--spacing-sm);
}

.compatibility-model {
    padding: var(--spacing-2) var(--spacing-3);
    background-color: var(--color-background-alt);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

.compatibility-model--link {
    text-decoration: none;
    cursor: pointer;
    transition: background-color var(--transition-fast), color var(--transition-fast);
}

.compatibility-model--link:hover {
    background-color: var(--cyan-light, #e0f7fa);
    color: var(--cyan-primary, #0097a7);
}

.compatibility-intro {
    color: var(--color-text-light);
    margin-bottom: var(--spacing-sm);
}

/* Product Gallery Image Placeholder */
.product-gallery__image-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    color: var(--color-text-muted);
}

/* Product Options (Genuine/Compatible selector) */
.product-option {
    border: none;
    margin: var(--spacing-md) 0;
}

.product-option__label {
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--spacing-sm);
    display: block;
}

.product-option__choices {
    display: flex;
    gap: var(--spacing-md);
}

.option-choice {
    flex: 1;
    position: relative;
    cursor: pointer;
}

.option-choice input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.option-choice__content {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--spacing-md);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-lg);
    transition: all var(--transition-fast);
}

.option-choice:hover .option-choice__content {
    border-color: var(--color-primary-light);
}

.option-choice input:checked + .option-choice__content {
    border-color: var(--color-primary);
    background-color: var(--color-primary-bg);
}

.option-choice__name {
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--spacing-1);
}

.option-choice__price {
    color: var(--color-text-light);
    font-size: var(--font-size-sm);
}

/* Quantity Selector */
.quantity-selector {
    display: flex;
    align-items: center;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.quantity-selector__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    background-color: var(--color-background-alt);
    border: none;
    cursor: pointer;
    transition: background-color var(--transition-fast);
}

.quantity-selector__btn:hover {
    background-color: var(--color-border);
}

.quantity-selector__input {
    width: 60px;
    height: 44px;
    text-align: center;
    border: none;
    border-left: 1px solid var(--color-border);
    border-right: 1px solid var(--color-border);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    -moz-appearance: textfield;
}

.quantity-selector__input::-webkit-outer-spin-button,
.quantity-selector__input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* Express Checkout */
.product-info__express {
    margin-top: var(--spacing-md);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-border);
    text-align: center;
}

.product-info__express-label {
    display: block;
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-sm);
}

.express-buttons {
    display: flex;
    gap: var(--spacing-md);
    justify-content: center;
}

.btn--express {
    flex: 1;
    max-width: 150px;
    padding: var(--spacing-3);
    background-color: var(--color-background-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-medium);
    transition: all var(--transition-fast);
}

.btn--express:hover {
    border-color: var(--color-border-dark);
    background-color: var(--color-background);
}

.product-info__afterpay-info {
    margin-top: var(--spacing-sm);
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

/* Feature List */
.product-info__features {
    margin-top: var(--spacing-md);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-border);
}

.product-info__features-heading {
    font-size: var(--font-size-md);
    margin-bottom: var(--spacing-sm);
}

.feature-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.feature-list li {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    color: var(--color-text-light);
}

.feature-list li svg {
    color: var(--color-secondary);
    flex-shrink: 0;
}



/* Compatible Printers List */
.compatible-printers-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: var(--spacing-sm);
    list-style: none;
    padding: 0;
}

.compatible-printers-list li {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-md);
}

.compatible-printers-list a {
    color: var(--color-primary);
    text-decoration: none;
}

.compatible-printers-list a:hover {
    text-decoration: underline;
}

/* Featured Products (Homepage) */
.featured-products {
    padding: var(--spacing-3xl) 0;
    background: var(--color-background-alt);
}

.featured-products__title {
    font-size: var(--font-size-2xl);
    text-align: center;
    margin-bottom: var(--spacing-xl);
}

.featured-products__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--spacing-lg);
}

.featured-products__cta {
    text-align: center;
    margin-top: var(--spacing-xl);
}

/* Related Products */
.related-products__group {
    margin-bottom: var(--spacing-md);
}

.related-products__group-heading {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--spacing-md);
}

.related-products__group-heading .badge {
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit;
    letter-spacing: inherit;
    padding: 0;
    background: none;
    border-radius: 0;
}

.related-products__type-group {
    margin-bottom: var(--spacing-md);
}

.related-products__title {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-light);
    letter-spacing: var(--letter-spacing-wide);
    text-transform: uppercase;
    margin-bottom: var(--spacing-md);
}

.related-products__grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: var(--spacing-md);
}

@media (max-width: 1024px) {
    .related-products__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (max-width: 768px) {
    .related-products__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 600px) {
    .related-products__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-sm);
    }
}

.related-products__grid .product-card__image-wrapper {
    aspect-ratio: 4 / 3;
}

.related-products__grid .product-card__image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.related-products__grid .product-card__content {
    padding: var(--spacing-xs) var(--spacing-sm);
    gap: 1px;
}

.related-products__grid .product-card__badge,
.related-products__grid .product-card__brand {
    display: none;
}

@media (max-width: 1024px) {
    .ribbon-detail-columns__right .related-products__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 600px) {
    .ribbon-detail-columns__right .related-products__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}


/* ── Product Reviews Section ─────────────────────────── */
.product-reviews {
    padding: var(--spacing-2xl) 0;
    border-top: 1px solid var(--color-border-light);
}

.product-reviews__header {
    margin-bottom: var(--spacing-xl);
}

.product-reviews__title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    margin: 0 0 var(--spacing-sm) 0;
}

.reviews-summary__stars {
    display: inline-flex;
    gap: 2px;
    color: #f59e0b;
    vertical-align: middle;
    margin-right: var(--spacing-xs);
}

.reviews-summary__avg {
    font-weight: var(--font-weight-bold);
    font-size: var(--font-size-lg);
    margin-right: var(--spacing-xs);
}

.reviews-summary__count {
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

.product-reviews__list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-xl);
}

.product-reviews__empty {
    color: var(--color-text-muted);
    font-style: italic;
}

.product-review-card {
    background: var(--color-background);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
}

.product-review-card__stars {
    display: flex;
    gap: 2px;
    color: #f59e0b;
    margin-bottom: var(--spacing-xs);
}

.product-review-card__title {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-semibold);
    margin: 0 0 var(--spacing-xs) 0;
}

.product-review-card__body {
    color: var(--color-text);
    line-height: 1.6;
    margin: 0 0 var(--spacing-sm) 0;
}

.product-review-card__meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.product-review-card__date::before {
    content: '·';
    margin-right: var(--spacing-sm);
}

/* Review Form */
.product-reviews__form-wrap {
    border-top: 1px solid var(--color-border-light);
    padding-top: var(--spacing-xl);
    max-width: 560px;
}

.product-reviews__form-title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    margin: 0 0 var(--spacing-lg) 0;
}

.review-form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.review-form__stars-label {
    display: block;
    font-weight: var(--font-weight-medium);
    margin-bottom: var(--spacing-xs);
    font-size: var(--font-size-sm);
}

.review-form__star-btns {
    display: flex;
    gap: 4px;
}

.review-form__star-btns button {
    background: none;
    border: none;
    cursor: pointer;
    padding: 2px;
    color: #f59e0b;
    transition: transform 0.1s ease;
}

.review-form__star-btns button:hover {
    transform: scale(1.2);
}

.review-form__field label {
    display: block;
    font-weight: var(--font-weight-medium);
    margin-bottom: var(--spacing-xs);
    font-size: var(--font-size-sm);
}

.review-form__field input,
.review-form__field textarea {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--font-size-md);
    font-family: inherit;
    transition: border-color 0.2s;
}

.review-form__field input:focus,
.review-form__field textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(38, 127, 181, 0.15);
}

.review-form__field textarea {
    resize: vertical;
    min-height: 100px;
}

.review-form__status {
    font-size: var(--font-size-sm);
    margin: 0;
}

.review-form__status--success {
    color: var(--color-success);
}

.review-form__status--error {
    color: var(--color-error);
}

/* Review Distribution Bars */
.reviews-summary__overview {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
    margin-bottom: var(--spacing-md);
}

.reviews-dist {
    display: flex;
    flex-direction: column;
    gap: 6px;
    max-width: 320px;
}

.reviews-dist__row {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-sm);
}

.reviews-dist__label {
    width: 28px;
    text-align: right;
    color: var(--color-text-muted);
    flex-shrink: 0;
}

.reviews-dist__bar {
    flex: 1;
    height: 8px;
    background: var(--color-border-light, #e5e7eb);
    border-radius: 4px;
    overflow: hidden;
}

.reviews-dist__fill {
    height: 100%;
    background: #f59e0b;
    border-radius: 4px;
    transition: width 0.3s ease;
}

.reviews-dist__count {
    width: 24px;
    text-align: left;
    color: var(--color-text-muted);
    font-size: var(--font-size-xs, 0.75rem);
    flex-shrink: 0;
}

/* FAQ Accordion */
.product-faq {
    padding: var(--spacing-2xl, 3rem) 0;
    border-top: 1px solid var(--color-border-light, #e5e7eb);
}

.faq-accordion__title {
    font-size: var(--font-size-xl, 1.25rem);
    font-weight: var(--font-weight-semibold, 600);
    margin: 0 0 var(--spacing-lg) 0;
}

.faq-accordion {
    display: flex;
    flex-direction: column;
    gap: 0;
    max-width: 760px;
}

.faq-accordion__item {
    border-bottom: 1px solid var(--color-border-light, #e5e7eb);
}

.faq-accordion__question {
    padding: var(--spacing-md) 0;
    font-weight: var(--font-weight-medium, 500);
    cursor: pointer;
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.faq-accordion__question::-webkit-details-marker { display: none; }

.faq-accordion__question::after {
    content: '+';
    font-size: 1.25rem;
    font-weight: 300;
    color: var(--color-text-muted);
    transition: transform 0.2s ease;
    flex-shrink: 0;
    margin-left: var(--spacing-md);
}

.faq-accordion__item[open] .faq-accordion__question::after {
    content: '\2212';
}

.faq-accordion__answer {
    padding: 0 0 var(--spacing-md) 0;
    color: var(--color-text-muted, #6b7280);
    line-height: 1.6;
}

/* Product Card Stars & Shipping Badge */
.product-card__rating {
    display: flex;
    align-items: center;
    gap: 4px;
    color: #f59e0b;
    font-size: var(--font-size-sm, 0.875rem);
    margin-top: 2px;
}

.product-card__star {
    flex-shrink: 0;
}

.product-card__review-count {
    color: var(--color-text-muted, #6b7280);
    font-size: var(--font-size-xs, 0.75rem);
}

/* "Free Shipping" — small inline pill that lives in the .product-card__info-row
   strip beneath the image (intentionally NOT an image overlay; overlaying
   marketing text on product photos covers cartridge detail and looks unprofessional). */
.product-card__free-shipping {
    display: inline-flex;
    align-items: center;
    font-size: 0.62rem;
    font-weight: 700;
    color: #047857;
    background: #ecfdf5;
    padding: 2px 7px;
    border-radius: 3px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    line-height: 1.4;
    white-space: nowrap;
}

/* Bought Together Section */
.bought-together {
    padding: var(--spacing-2xl, 3rem) 0;
}

.bought-together__title {
    font-size: var(--font-size-xl, 1.25rem);
    font-weight: var(--font-weight-semibold, 600);
    margin: 0 0 var(--spacing-lg) 0;
}

@media (max-width: 600px) {
    .product-reviews {
        padding: var(--spacing-xl) 0;
    }
    .product-review-card {
        padding: var(--spacing-md);
    }
}

/* Compatibility Section Enhancements */
.product-compatibility__intro {
    color: var(--color-text-light);
    max-width: 700px;
    margin-bottom: var(--spacing-xl);
}

.compatibility-check {
    margin-top: var(--spacing-xl);
    padding: var(--spacing-lg);
    background-color: var(--color-background-alt);
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-lg);
    flex-wrap: wrap;
}

.compatibility-check p {
    color: var(--color-text-light);
    margin: 0;
}

@media (max-width: 768px) {
    .product-detail__layout,
    .product-detail__layout--color-only,
    .product-detail__layout--compatible {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
    }

    .product-detail__layout--color-only .product-gallery {
        display: flex;
        justify-content: center;
    }

    .product-option__choices {
        flex-direction: column;
    }

    /* Compact product image on mobile — prioritize purchase info */
    .product-detail__layout .product-gallery__main {
        position: relative;
        aspect-ratio: 3 / 2;
        max-height: 220px;
        margin-bottom: var(--spacing-sm);
    }

    .product-detail__layout .product-gallery {
        min-height: auto;
    }
}


/* ==========================================================================
   STICKY MOBILE ADD-TO-CART BAR (Product Page)
   Shows fixed bar at bottom on mobile when main CTA scrolls out of view.
   ========================================================================== */

.sticky-atc {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: var(--z-sticky, 100);
    background: var(--white-primary);
    border-top: 1px solid var(--color-border);
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
    padding: var(--spacing-sm) var(--spacing-md);
    padding-bottom: calc(var(--spacing-sm) + env(safe-area-inset-bottom, 0px));
    transform: translateY(100%);
    transition: transform 0.3s ease;
}

.sticky-atc.is-visible {
    transform: translateY(0);
}

.sticky-atc__inner {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    max-width: var(--container-max-width);
    margin: 0 auto;
}

.sticky-atc__price {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    white-space: nowrap;
}

.sticky-atc__btn {
    flex: 1;
}

@media (max-width: 768px) {
    .sticky-atc {
        display: block;
    }
}

/* Mobile product detail layout fixes (iPhone) */
@media (max-width: 480px) {
    .product-info__title {
        font-size: var(--font-size-lg);
        word-break: break-word;
    }

    .product-info__pricing {
        flex-direction: row;
        align-items: baseline;
        flex-wrap: wrap;
        gap: var(--spacing-xs) var(--spacing-md);
    }

    .product-info__actions {
        flex-wrap: nowrap;
    }
    .product-info__add-to-cart {
        flex: 1 1 auto;
        min-width: 0;
        justify-content: center;
    }
    .product-info__actions > a.btn {
        flex: 1 1 100%;
        justify-content: center;
    }

    .product-trust-strip {
        gap: 4px 10px;
    }
}


/* ==========================================================================
   NEED HELP BANNER (Product + Shop pages)
   ========================================================================== */

.need-help {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md) var(--spacing-lg);
    background: var(--cyan-light);
    border: 1px solid var(--cyan-primary);
    border-radius: var(--radius-md);
    margin: var(--spacing-xl) 0;
}

.need-help__icon {
    flex-shrink: 0;
    color: var(--cyan-primary);
}

.need-help__text {
    font-size: var(--font-size-sm);
    color: var(--steel-700);
    line-height: 1.5;
}

.need-help__text strong {
    display: block;
    font-size: var(--font-size-base);
    margin-bottom: 2px;
}

.need-help__text a {
    color: var(--cyan-dark);
    font-weight: var(--font-weight-semibold);
}


/* ==========================================================================
   CART PAGE
   ========================================================================== */

.cart-page {
    padding: var(--spacing-sm) 0 var(--spacing-xl);
}

.cart-page__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.cart-page__title {
    margin: 0;
    font-size: var(--font-size-2xl);
    flex-shrink: 0;
    padding-top: 22px;
}

/* Compact checkout progress for cart page - same style but narrower */
.checkout-progress--compact {
    margin: 0;
    flex: 0 1 400px;
    max-width: 400px;
}

.checkout-progress--compact .checkout-progress__steps::before {
    left: 12%;
    right: 12%;
}

@media (max-width: 768px) {
    .cart-page__header {
        flex-direction: column;
        align-items: flex-start;
    }

    .checkout-progress--compact {
        width: 100%;
        max-width: 100%;
    }
}

/* Checkout page header - same style as cart page */
.checkout-page__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--spacing-lg);
    margin-bottom: 8px;
}

.checkout-page__title {
    margin: 0;
    font-size: var(--font-size-2xl);
    flex-shrink: 0;
}

@media (max-width: 768px) {
    .checkout-page__header {
        flex-direction: column;
        align-items: flex-start;
    }

    .checkout-page__title {
        padding-top: 0;
    }
}

/* Inline progress indicators within checkout form */
.checkout-progress--inline {
    margin: var(--spacing-xl) 0;
    padding: var(--spacing-lg) 0;
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
}

.checkout-progress--inline .checkout-progress__steps::before {
    left: 10%;
    right: 10%;
}

/* Cart Items - Compact layout */
.cart-items {
    background-color: var(--color-background);
    border: 1px solid var(--steel-200);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.cart-item {
    display: grid;
    grid-template-columns: 70px 1fr auto auto auto auto;
    gap: var(--spacing-md);
    align-items: center;
    padding: var(--spacing-sm) var(--spacing-md);
    border-bottom: 1px solid var(--color-border);
    min-height: 80px;
}

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

.cart-item__image {
    width: 70px;
    height: 70px;
    background-color: var(--product-image-bg);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.cart-item__image img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    padding: 4px;
}

.cart-item__details {
    min-width: 0;
}

.cart-item__name {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    margin-bottom: 2px;
    line-height: 1.3;
}

.cart-item__name a {
    color: var(--color-text);
}

.cart-item__name a:hover {
    color: var(--color-primary);
    text-decoration: none;
}

.cart-item__brand {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin-bottom: 2px;
}

.cart-item__sku {
    font-size: 11px;
    color: var(--color-text-muted);
}

.cart-item__price-mobile {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    display: none;
}

.cart-item__meta {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

.cart-item__price {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    white-space: nowrap;
}

.cart-item__quantity {
    display: flex;
    align-items: center;
}

.cart-item__total {
    font-weight: var(--font-weight-bold);
    font-size: var(--font-size-base);
    white-space: nowrap;
}

.cart-item__remove {
    color: var(--color-text-muted);
    transition: color var(--transition-fast);
    padding: var(--spacing-xs);
}

.cart-item__remove:hover {
    color: var(--color-error);
}

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

/* Quantity selector in cart - compact */
.cart-item .quantity-selector {
    display: flex;
    align-items: center;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    overflow: hidden;
}

.cart-item .quantity-selector__btn {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-background);
    border: none;
    cursor: pointer;
    transition: background-color 0.2s;
}

.cart-item .quantity-selector__btn:hover {
    background: var(--color-background-alt);
}

.cart-item .quantity-selector__input {
    width: 36px;
    height: 28px;
    text-align: center;
    border: none;
    border-left: 1px solid var(--color-border);
    border-right: 1px solid var(--color-border);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    -moz-appearance: textfield;
}

.cart-item .quantity-selector__input::-webkit-outer-spin-button,
.cart-item .quantity-selector__input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* Disabled checkout button */
.btn--disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

/* Cart Actions */
.cart-actions {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    padding: var(--spacing-lg) 0;
}

/* Cart Summary */
.cart-summary {
    background-color: var(--color-background-alt);
    padding: var(--spacing-xl);
    border-radius: var(--radius-xl);
    border: 1px solid var(--color-border);
    position: sticky;
    top: var(--spacing-lg);
}

.cart-summary__heading {
    font-size: var(--font-size-lg);
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--color-border);
}

.cart-summary__row {
    display: flex;
    justify-content: space-between;
    padding: var(--spacing-sm) 0;
}

.cart-summary__row--subtotal {
    border-bottom: 1px solid var(--color-border);
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-md);
}

.cart-summary__row--total {
    font-weight: var(--font-weight-bold);
    font-size: var(--font-size-lg);
    padding-top: var(--spacing-md);
    border-top: 2px solid var(--color-border-dark);
}

.cart-summary__gst {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    text-align: right;
    margin-top: var(--spacing-1);
}

.cart-summary__actions {
    margin-top: var(--spacing-xl);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.cart-summary__secure {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-md);
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

.cart-summary__secure-icon {
    color: var(--color-secondary);
}

/* Cart Loading State */
.cart-loading {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: var(--spacing-xl);
    padding: var(--spacing-lg) 0;
}

.cart-loading[hidden] {
    display: none;
}

.cart-loading__main {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.cart-loading__item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: var(--color-surface, #fff);
    border-radius: var(--radius-md, 8px);
    border: 1px solid var(--color-border);
}

.cart-loading__summary {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    background: var(--color-surface, #fff);
    border-radius: var(--radius-md, 8px);
    border: 1px solid var(--color-border);
    height: fit-content;
}

/* Skeleton elements */
.skeleton {
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s infinite;
    border-radius: var(--radius-sm, 4px);
}

@keyframes skeleton-loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.skeleton--image {
    width: 80px;
    height: 80px;
    min-width: 80px;
    border-radius: var(--radius-md, 8px);
}

.skeleton--text {
    height: 16px;
    width: 100%;
}

.skeleton--text-lg {
    height: 20px;
    width: 70%;
}

.skeleton--text-sm {
    height: 14px;
    width: 50%;
}

.skeleton--price {
    width: 80px;
    height: 20px;
    margin-left: auto;
}

.skeleton--heading {
    height: 24px;
    width: 60%;
    margin-bottom: var(--spacing-sm);
}

.skeleton--button {
    height: 48px;
    width: 100%;
    border-radius: var(--radius-md, 8px);
    margin-top: var(--spacing-sm);
}

.skeleton-group {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs, 8px);
}

@media (max-width: 768px) {
    .cart-loading {
        grid-template-columns: 1fr;
    }

    .cart-loading__summary {
        order: -1;
    }
}

/* Cart syncing state - subtle indicator when updating from server */
.cart-layout--syncing {
    position: relative;
}

.cart-layout--syncing::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--color-primary, #267FB5), transparent);
    background-size: 200% 100%;
    animation: syncing-bar 1.5s infinite;
    z-index: 10;
    border-radius: 2px;
}

@keyframes syncing-bar {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ============================================
   SHOP PAGE SKELETON LOADERS
   ============================================ */
.drilldown-loading {
    padding: var(--spacing-lg) 0;
}

.drilldown-loading[hidden] {
    display: none;
}

.drilldown-skeleton[hidden] {
    display: none;
}

/* Brand Box Skeleton */
.skeleton--brand-box {
    height: 120px;
    border-radius: var(--radius-lg, 12px);
    background: linear-gradient(90deg, #f0f0f0 25%, #e8e8e8 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s infinite;
}

/* Category Box Skeleton */
.skeleton--category-box {
    height: 160px;
    border-radius: var(--radius-lg, 12px);
    background: linear-gradient(90deg, #f0f0f0 25%, #e8e8e8 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s infinite;
}

/* Product Code Box Skeleton */
.skeleton--code-box {
    height: 80px;
    border-radius: var(--radius-md, 8px);
    background: linear-gradient(90deg, #f0f0f0 25%, #e8e8e8 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s infinite;
}

/* Product Card Skeleton */
.skeleton--product-card {
    height: 320px;
    border-radius: var(--radius-lg, 12px);
    background: linear-gradient(90deg, #f0f0f0 25%, #e8e8e8 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s infinite;
}

/* Section Title Skeleton */
.skeleton--section-title {
    height: 32px;
    width: 280px;
    border-radius: var(--radius-sm, 4px);
    margin-bottom: var(--spacing-md);
    background: linear-gradient(90deg, #f0f0f0 25%, #e8e8e8 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s infinite;
}

/* Products skeleton layout */
.drilldown-skeleton--products .products-section {
    margin-bottom: var(--spacing-xl);
}

.drilldown-skeleton--products .products-row {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: var(--spacing-md) !important;
    flex-wrap: unset !important;
}

.drilldown-skeleton--products .skeleton--product-card {
    width: 100%;
    max-width: none;
}

@media (max-width: 768px) {
    .skeleton--brand-box {
        height: 100px;
    }

    .skeleton--category-box {
        height: 140px;
    }

    .skeleton--product-card {
        height: 280px;
    }

    .drilldown-skeleton--products .products-row {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (min-width: 769px) and (max-width: 1024px) {
    .drilldown-skeleton--products .products-row {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

/* Cart Empty State */
.cart-empty {
    text-align: center;
    padding: var(--spacing-xl) var(--spacing-lg);
}

.cart-empty__icon {
    font-size: 3rem;
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-md);
}

.cart-empty__title {
    margin-bottom: var(--spacing-sm);
}

.cart-empty__text {
    color: var(--color-text-light);
    margin-bottom: var(--spacing-md);
}

/* Cart Layout */
.cart-layout {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: var(--spacing-2xl);
    align-items: start;
}

.cart-main {
    min-width: 0;
}

/* Checkout Progress */
.checkout-progress:not(.checkout-progress--compact) {
    margin-bottom: var(--spacing-lg);
}

.checkout-progress__steps {
    display: flex;
    justify-content: space-between;
    position: relative;
}

.checkout-progress__steps::before {
    content: '';
    position: absolute;
    top: 16px;
    left: 10%;
    right: 10%;
    height: 2px;
    background-color: var(--color-border);
}

.checkout-progress__step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-xs);
    position: relative;
    z-index: 1;
}

.checkout-progress__number {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-background);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-muted);
}

.checkout-progress__label {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.checkout-progress__step--active .checkout-progress__number {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-text-inverse);
}

.checkout-progress__step--active .checkout-progress__label {
    color: var(--color-primary);
    font-weight: var(--font-weight-medium);
}

.checkout-progress__step--completed .checkout-progress__number {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-text-inverse);
}

/* Cart Item Price */
.cart-item__price-current {
    font-weight: var(--font-weight-semibold);
    display: block;
}

.cart-item__price-was {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    text-decoration: line-through;
}

/* Quantity Selector Small */
.quantity-selector--sm {
    transform: scale(0.85);
    transform-origin: center;
}

.quantity-selector--sm .quantity-selector__btn {
    width: 36px;
    height: 36px;
}

.quantity-selector--sm .quantity-selector__input {
    width: 50px;
    height: 36px;
}

/* Cart Summary Enhancements */
.cart-summary__coupon {
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-lg);
    border-bottom: 1px solid var(--color-border);
}

.cart-summary__coupon-label {
    display: block;
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-sm);
}

.coupon-form {
    display: flex;
    gap: var(--spacing-sm);
}

.coupon-form__input {
    flex: 1;
    padding: var(--spacing-2) var(--spacing-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
}

.coupon-form__btn {
    white-space: nowrap;
}

.coupon-form__hint {
    margin-top: 6px;
    font-size: 0.85rem;
    line-height: 1.3;
    color: var(--color-text-muted, #6b7280);
}

.returning-guest-banner {
    margin: 0 0 16px;
    padding: 12px 16px;
    border-radius: 8px;
    background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
    color: #065f46;
    font-size: 0.95rem;
    line-height: 1.4;
    border: 1px solid #6ee7b7;
}
.coupon-form__hint--success {
    color: #15803d;
}
.coupon-form__hint--error {
    color: #b91c1c;
}

.coupon-applied {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-success-light, #e8f5e9);
    border: 1px solid var(--color-success, #4caf50);
    border-radius: var(--radius-md);
    width: 100%;
}

.coupon-applied__code {
    font-weight: var(--font-weight-bold);
    color: var(--color-success, #4caf50);
}

.coupon-applied__desc {
    flex: 1;
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.coupon-remove-btn {
    background: none;
    border: none;
    font-size: 1.25rem;
    color: var(--color-text-muted);
    cursor: pointer;
    padding: 0 var(--spacing-xs);
    line-height: 1;
}

.coupon-remove-btn:hover {
    color: var(--color-error, #f44336);
}

.cart-summary__totals {
    margin-bottom: var(--spacing-lg);
}

.cart-summary__row--savings {
    color: var(--color-secondary);
}

.cart-summary__shipping-message {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-lg);
    background-color: #fff8e1;
    border: 1px solid #ffe082;
    color: #f57c00;
    font-weight: 500;
}

.cart-summary__shipping-message svg {
    flex-shrink: 0;
    color: #f57c00;
}

.cart-summary__shipping-message--success {
    background-color: #e8f5e9;
    border-color: #a5d6a7;
    color: #2e7d32;
}

.cart-summary__shipping-message--success svg {
    color: #2e7d32;
}

.cart-summary__shipping-message--progress {
    background-color: var(--color-info-bg);
    color: var(--color-info);
}

/* Loyalty stamp card chip */
.cart-summary__stamp-card {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    margin: 0 0 var(--spacing-md);
    background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
    color: #92400e;
    border-radius: 999px;
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.2;
}
.cart-summary__stamp-card::before {
    content: "🏆";
    font-size: 1rem;
}

/* Free Shipping Progress Bar */
.cart-summary__shipping-bar {
    margin-bottom: var(--spacing-lg);
}

.shipping-bar {
    height: 6px;
    background: var(--steel-200);
    border-radius: 3px;
    overflow: hidden;
}

.shipping-bar__fill {
    height: 100%;
    background: var(--cyan-primary);
    border-radius: 3px;
    transition: width 0.4s ease;
}

.shipping-bar__fill--complete {
    background: #2e7d32;
}

.cart-summary__warning {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-md);
    background-color: #fff3e0;
    border: 1px solid #ffcc80;
    color: #e65100;
    font-weight: 500;
}

.cart-summary__warning svg {
    flex-shrink: 0;
    color: #e65100;
}

.cart-summary__express {
    margin-top: var(--spacing-lg);
    text-align: center;
}

.cart-summary__express-label {
    display: block;
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-sm);
}

.cart-summary__express-buttons {
    display: flex;
    gap: var(--spacing-sm);
}

.cart-summary__express-buttons .btn--express {
    flex: 1;
}

.cart-summary__express-buttons .btn--express.btn--disabled {
    opacity: 0.5;
    cursor: not-allowed;
    background-color: var(--color-background-alt, #f5f5f5);
    border-color: var(--color-border);
    color: var(--color-text-muted);
}

.coming-soon-badge {
    display: inline-block;
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 2px 6px;
    background-color: var(--color-warning-bg, #fef3c7);
    color: var(--color-warning, #d97706);
    border-radius: var(--radius-sm, 4px);
    margin-left: 0.5rem;
    vertical-align: middle;
}

.cart-summary__payment-icons {
    display: flex;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-md);
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.cart-summary__payment-icons span {
    padding: var(--spacing-1) var(--spacing-2);
    background-color: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
}

@media (max-width: 1024px) {
    .cart-layout {
        grid-template-columns: 1fr;
    }

    .cart-summary {
        position: static;
    }
}

@media (max-width: 768px) {
    .cart-item {
        grid-template-columns: 60px 1fr auto;
        gap: var(--spacing-sm);
        padding: var(--spacing-sm);
    }

    .cart-item__image {
        width: 60px;
        height: 60px;
        grid-row: span 2;
    }

    .cart-item__details {
        grid-column: 2 / -1;
    }

    .cart-item__price {
        display: none;
    }

    .cart-item__price-mobile {
        display: block;
        margin-top: 4px;
    }

    .cart-item__quantity {
        grid-column: 2;
        grid-row: 2;
    }

    .cart-item__total {
        grid-column: 3;
        grid-row: 2;
        font-size: var(--font-size-sm);
    }

    .cart-item__remove {
        position: absolute;
        top: var(--spacing-xs);
        right: var(--spacing-xs);
    }

    .cart-item {
        position: relative;
    }

    .checkout-progress__steps::before {
        display: none;
    }

    .checkout-progress__label {
        font-size: var(--font-size-xs);
    }
}


/* ==========================================================================
   CHECKOUT PAGE
   ========================================================================== */

/* Checkout Header */
.site-header--checkout .header-main {
    padding: var(--spacing-md) 0;
}

.site-header--checkout .header-main .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.checkout-header__secure {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    color: var(--color-secondary);
    font-weight: var(--font-weight-medium);
}

.checkout-header__back {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

.checkout-header__back:hover {
    color: var(--color-primary);
    text-decoration: none;
}

/* Checkout Page */
.checkout-page {
    padding: 4px 0 var(--spacing-3xl);
}

.checkout-page__title {
    margin-bottom: 0;
}

/* Checkout Layout */
.checkout-layout {
    display: grid;
    grid-template-columns: 1fr 400px;
    gap: var(--spacing-xl);
    align-items: start;
}

.checkout-form-wrapper {
    min-width: 0;
}

.checkout-form {
    margin: 0;
    padding: 0;
}

.checkout-form > .checkout-section:first-child {
    margin-top: 0;
}

/* Checkout Progress */
.checkout-progress:not(.checkout-progress--compact) {
    margin-bottom: var(--spacing-2xl);
}

/* Checkout Sections */
.checkout-section {
    /* Reset fieldset defaults */
    margin-inline: 0;
    min-inline-size: auto;
    /* Custom styling */
    background-color: var(--color-background);
    border: 1px solid var(--steel-200);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    margin-bottom: var(--spacing-lg);
}

.checkout-section__heading {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.checkout-section__number {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--steel-900);
    color: var(--white-primary);
    border-radius: var(--radius-sm);
    font-family: var(--font-family-mono);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
}

.checkout-section__title {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0;
}

.checkout-section__login-prompt {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    padding: var(--spacing-md);
    background-color: var(--color-background-alt);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-lg);
}

/* Form Rows */
.form-row {
    margin-bottom: var(--spacing-md);
}

.form-row--two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-md);
}

.form-row--three-col {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--spacing-md);
}

/* Form Elements */
.form-group {
    display: flex;
    flex-direction: column;
}

.form-label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    margin-bottom: var(--spacing-sm);
}

.form-input,
.form-select,
.form-textarea {
    padding: var(--spacing-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--font-size-base);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(8, 145, 178, 0.15);
    outline: none;
}

.form-input::placeholder,
.form-textarea::placeholder {
    color: var(--color-text-muted);
}

.form-hint {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin-top: var(--spacing-1);
}

/* Phone Input Group - Country Code + Number */
.phone-input-group {
    display: flex;
    gap: var(--spacing-2);
}

.phone-input-group .phone-country-code {
    width: 80px;
    flex-shrink: 0;
    padding: var(--spacing-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--font-size-base);
    background-color: var(--color-surface-secondary);
    color: var(--color-text);
    text-align: center;
}

.phone-input-group .phone-country-code:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(8, 145, 178, 0.15);
    outline: none;
}

.phone-input-group .phone-number {
    flex: 1;
    padding: var(--spacing-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--font-size-base);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.phone-input-group .phone-number:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(8, 145, 178, 0.15);
    outline: none;
}

.phone-input-group .phone-number::placeholder {
    color: var(--color-text-muted);
}

/* Delivery Type Selector */
.delivery-type-options {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-sm);
    background: rgba(8, 145, 178, 0.07);
    padding: 10px;
    border-radius: var(--radius-md, 8px);
}

.delivery-type-option {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    min-height: 72px;
    padding: 14px 16px;
    border: 1.5px solid var(--color-border, #d1d5db);
    border-radius: var(--radius-md, 8px);
    cursor: pointer;
    background: var(--white-primary, #fff);
    transition: border-color 0.15s, background-color 0.15s, box-shadow 0.15s;
    position: relative;
}

.delivery-type-option input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.delivery-type-option__icon-wrap {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--gray-100, #f3f4f6);
    border-radius: var(--radius-sm, 6px);
    color: var(--color-text-muted, #6b7280);
    transition: background-color 0.15s, color 0.15s;
}

.delivery-type-option__content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.delivery-type-option__name {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--color-text, #111827);
}

.delivery-type-option__desc {
    font-size: 0.775rem;
    color: var(--color-text-muted, #6b7280);
    line-height: 1.3;
}

/* Custom radio circle — hollow by default */
.delivery-type-option__check {
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 2px solid var(--color-border, #d1d5db);
    background: var(--white-primary, #fff);
    transition: border-color 0.15s, background-color 0.15s;
    margin-left: auto;
}

/* Hover state */
.delivery-type-option:hover {
    border-color: var(--color-text-muted, #9ca3af);
    box-shadow: 0 1px 4px rgba(0,0,0,0.07);
}

/* Selected state */
.delivery-type-option:has(input:checked) {
    border-color: var(--color-primary, #0891b2);
    border-width: 2px;
    background: rgba(8, 145, 178, 0.04);
}

.delivery-type-option:has(input:checked) .delivery-type-option__icon-wrap {
    background: rgba(8, 145, 178, 0.1);
    color: var(--color-primary, #0891b2);
}

.delivery-type-option:has(input:checked) .delivery-type-option__check {
    border-color: var(--color-primary, #0891b2);
    background: var(--color-primary, #0891b2);
    box-shadow: inset 0 0 0 3px var(--white-primary, #fff), inset 0 0 0 9px var(--color-primary, #0891b2);
}

/* Needs-attention state — triggered by JS */
.checkout-delivery-type.needs-attention .delivery-type-options {
    box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.4);
    border-radius: var(--radius-md, 8px);
}

.checkout-delivery-type.needs-attention .delivery-type-option {
    border-color: #fbbf24;
}

.delivery-type-hint {
    font-size: 0.75rem;
    color: var(--color-text-muted, #9ca3af);
    margin-top: var(--spacing-xs);
}

.delivery-type-attention-text {
    display: none;
    font-size: 0.8rem;
    color: #b45309;
    font-weight: 500;
    margin-top: 6px;
}

.checkout-delivery-type.needs-attention .delivery-type-attention-text {
    display: block;
}

.checkout-delivery-type.needs-attention .delivery-type-hint {
    display: none;
}

/* Checkbox Groups */
.form-group--checkbox {
    flex-direction: row;
    align-items: flex-start;
    gap: var(--spacing-sm);
}

.form-checkbox {
    width: 18px;
    height: 18px;
    margin: 0;
    flex-shrink: 0;
    cursor: pointer;
    accent-color: var(--color-primary);
}

.form-label--checkbox {
    font-weight: var(--font-weight-normal);
    margin-bottom: 0;
    cursor: pointer;
}

/* Payment Details */
.payment-details {
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
    background-color: var(--color-background-alt);
    border-radius: var(--radius-lg);
}

.payment-icon {
    padding: var(--spacing-1) var(--spacing-2);
    background-color: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
}

/* Checkout Submit */
.checkout-submit {
    padding-top: var(--spacing-xl);
    border-top: 1px solid var(--color-border);
}

.checkout-submit__button {
    margin-top: var(--spacing-lg);
}

.checkout-submit__secure {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-md);
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

/* Shipping Options */
.shipping-options,
.payment-options {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.shipping-option,
.payment-option {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.shipping-option:hover,
.payment-option:hover {
    border-color: var(--color-primary-light);
}

.shipping-option:has(input:checked),
.payment-option:has(input:checked) {
    border-color: var(--color-primary);
    background-color: var(--color-primary-bg);
}

.shipping-option__radio,
.payment-option__radio {
    margin-top: var(--spacing-1);
}

.shipping-option__details,
.payment-option__details {
    flex: 1;
}

.shipping-option__name,
.payment-option__name {
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--spacing-1);
}

.shipping-option__description,
.payment-option__description {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

.shipping-option__price {
    font-weight: var(--font-weight-semibold);
    white-space: nowrap;
}

.shipping-option__price--free {
    color: var(--color-secondary);
}

/* Checkout Summary */
.checkout-summary {
    background-color: var(--color-background-alt);
    padding: var(--spacing-xl);
    border-radius: var(--radius-xl);
    border: 1px solid var(--color-border);
}

.checkout-summary__heading {
    font-size: var(--font-size-lg);
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--color-border);
}

.checkout-summary__items {
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-lg);
    border-bottom: 1px solid var(--color-border);
}

.checkout-summary__item {
    display: flex;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.checkout-summary__item:last-child {
    margin-bottom: 0;
}

.checkout-summary__item-image {
    width: 60px;
    height: 60px;
    background-color: var(--product-image-bg);
    border-radius: var(--radius-md);
    flex-shrink: 0;
    position: relative;
}

.checkout-summary__item-image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: var(--radius-md);
    display: block;
}

.checkout-summary__item-details {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.checkout-summary__item-name {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    margin-bottom: var(--spacing-1);
}

.checkout-summary__item-qty {
    position: absolute;
    top: -6px;
    right: -6px;
    background: var(--color-primary, #267FB5);
    color: #fff;
    font-size: 0.6875rem;
    font-weight: 700;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
    z-index: 1;
}

.checkout-summary__item-price {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    white-space: nowrap;
}

.checkout-summary__item-title {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    margin-bottom: var(--spacing-1);
}

.checkout-summary__item-variant {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

.checkout-summary__edit {
    display: block;
    text-align: right;
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-lg);
}

.checkout-summary__coupon {
    padding: var(--spacing-lg) 0;
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
}

.checkout-summary__totals {
    padding: var(--spacing-lg) 0;
}

.checkout-summary__row {
    display: flex;
    justify-content: space-between;
    padding: var(--spacing-sm) 0;
    font-size: var(--font-size-sm);
}

.checkout-summary__row--savings {
    color: var(--color-secondary);
}

.checkout-summary__row--total {
    padding-top: var(--spacing-md);
    margin-top: var(--spacing-md);
    border-top: 1px solid var(--color-border);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
}

.checkout-summary__row--discount {
    color: var(--color-success, #4caf50);
}

.text-success {
    color: var(--color-success, #4caf50);
}

.checkout-summary__trust {
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--color-border);
}

.checkout-summary__trust-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    margin-bottom: var(--spacing-sm);
}

.checkout-summary__trust-item svg {
    color: var(--color-secondary);
}

/* Checkout Footer */
.site-footer--checkout {
    background-color: var(--color-background);
    border-top: 1px solid var(--color-border);
}

.footer-bottom--checkout {
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-md);
    text-align: center;
}

@media (max-width: 1024px) {
    .checkout-layout {
        grid-template-columns: 1fr;
    }

    .checkout-layout {
        grid-template-columns: 1fr;
    }

    .checkout-summary {
        order: -1;
    }
}

@media (max-width: 768px) {
    .site-header--checkout .header-main .container {
        flex-wrap: wrap;
        gap: var(--spacing-md);
    }

    .checkout-header__secure {
        order: 1;
        width: 100%;
        justify-content: center;
    }

    .form-row--two-col,
    .form-row--three-col {
        grid-template-columns: 1fr;
    }
}


/* ==========================================================================
   ACCOUNT PAGES
   ========================================================================== */

/* Hide account page content until auth is confirmed (prevents flash for guests) */
.account-page {
    visibility: hidden;
    padding: var(--spacing-xl) 0 var(--spacing-3xl);
}
.account-page.auth-ready {
    visibility: visible;
}

.account-page__title {
    margin-bottom: var(--spacing-xl);
}

/* Account Sidebar */
.account-sidebar {
    background-color: var(--steel-50);
    padding: var(--spacing-xl);
    border-radius: var(--radius-lg);
    border: 1px solid var(--steel-200);
}

.account-sidebar__user {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding-bottom: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    border-bottom: 1px solid var(--color-border);
}

.account-sidebar__avatar {
    width: 48px;
    height: 48px;
    background-color: var(--color-primary);
    color: var(--color-text-inverse);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
}

.account-sidebar__name {
    font-weight: var(--font-weight-semibold);
}

.account-sidebar__email {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

/* Account Navigation */
.account-nav__item {
    margin-bottom: var(--spacing-1);
}

.account-nav__link {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-3) var(--spacing-4);
    border-radius: var(--radius-md);
    color: var(--color-text);
    transition: all var(--transition-fast);
}

.account-nav__link:hover {
    background-color: var(--color-background);
    text-decoration: none;
}

.account-nav__link--active {
    background-color: var(--steel-900);
    color: var(--white-primary);
}

.account-nav__link--active:hover {
    background-color: var(--steel-800);
}

.account-nav__icon {
    font-size: var(--font-size-md);
    width: 20px;
    text-align: center;
}

/* Account Dashboard Cards */
.account-actions-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-2xl);
}

.account-action-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--spacing-xl);
    background-color: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    transition: all var(--transition-fast);
    text-decoration: none;
    color: var(--color-text);
}

.account-action-card:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-md);
    text-decoration: none;
}

.account-action-card__icon {
    font-size: 2rem;
    color: var(--color-primary);
    margin-bottom: var(--spacing-md);
}

.account-action-card__title {
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--spacing-1);
}

.account-action-card__description {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

/* Account Sections */
.account-section {
    background-color: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    margin-bottom: var(--spacing-lg);
}

.account-section__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--color-border);
}

.account-section__title {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0;
}

.account-section__link {
    font-size: var(--font-size-sm);
}

/* Account Savings Section */
.account-savings {
    background: linear-gradient(135deg, var(--color-primary-light) 0%, var(--color-background) 100%);
    border-color: var(--color-primary);
}

.savings-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--spacing-md);
}

.savings-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    background-color: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
}

.savings-card--total {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: white;
}

.savings-card--total .savings-card__icon {
    background-color: rgba(255, 255, 255, 0.2);
}

.savings-card--total .savings-card__label {
    color: rgba(255, 255, 255, 0.9);
}

.savings-card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background-color: var(--color-surface-secondary);
    border-radius: var(--radius-md);
    flex-shrink: 0;
}

.savings-card__content {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-1);
}

.savings-card__label {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
}

.savings-card__value {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
}

/* Account Coupons Section */
.coupons-grid {
    display: grid;
    gap: var(--spacing-md);
}

.coupon-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    background-color: var(--color-background);
    border: 1px dashed var(--color-primary);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
}

.coupon-card__discount {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
    white-space: nowrap;
    min-width: 80px;
    text-align: center;
}

.coupon-card__details {
    flex: 1;
    min-width: 0;
}

.coupon-card__code {
    display: inline-block;
    font-family: monospace;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    background-color: var(--color-surface-secondary);
    padding: var(--spacing-1) var(--spacing-2);
    border-radius: var(--radius-sm);
    letter-spacing: 0.05em;
}

.coupon-card__desc {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    margin-top: var(--spacing-1);
    margin-bottom: 0;
}

.coupon-card__meta {
    display: flex;
    gap: var(--spacing-md);
    margin-top: var(--spacing-1);
    font-size: var(--font-size-xs);
    color: var(--color-text-tertiary);
}

.coupon-card__copy {
    flex-shrink: 0;
}

@media (max-width: 640px) {
    .coupon-card {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-sm);
    }

    .coupon-card__discount {
        min-width: auto;
    }
}

/* Account Layout */
.account-layout {
    display: grid;
    grid-template-columns: 300px 1fr;
    gap: var(--spacing-2xl);
    align-items: start;
}

.account-content__heading {
    font-size: var(--font-size-2xl);
    margin-bottom: var(--spacing-lg);
}

/* Account Welcome */
.account-welcome {
    padding: var(--spacing-lg);
    background-color: var(--color-primary-bg);
    border-radius: var(--radius-lg);
    margin-bottom: var(--spacing-2xl);
}

.account-welcome p {
    margin-bottom: 0;
    color: var(--color-text);
}

/* Account Nav Items */
.account-nav__item a {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-3) var(--spacing-4);
    border-radius: var(--radius-md);
    color: var(--color-text);
    transition: all var(--transition-fast);
}

.account-nav__item a:hover {
    background-color: var(--color-background);
    text-decoration: none;
}

.account-nav__item--active a {
    background-color: var(--color-primary);
    color: var(--color-text-inverse);
}

.account-nav__item--active a:hover {
    background-color: var(--color-primary-dark);
}

.account-nav__item--logout a {
    color: var(--color-text-muted);
}

.account-nav__item--logout a:hover {
    color: var(--color-error);
    background-color: var(--color-error-bg);
}


/* Orders Table */
.orders-table-wrapper {
    overflow-x: auto;
}

.orders-table {
    width: 100%;
    border-collapse: collapse;
}

.orders-table th {
    text-align: left;
    padding: var(--spacing-md);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
    border-bottom: 1px solid var(--color-border);
}

.orders-table td {
    padding: var(--spacing-md);
    border-bottom: 1px solid var(--color-border-light);
}

.orders-table__row:last-child td {
    border-bottom: none;
}

.orders-table td a {
    color: var(--color-primary);
    font-weight: var(--font-weight-medium);
}

/* Order Status Badges */
.order-status {
    display: inline-block;
    padding: var(--spacing-1) var(--spacing-3);
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
}

.order-status--pending {
    background-color: var(--color-warning-bg);
    color: var(--color-warning);
}

.order-status--processing {
    background-color: var(--color-info-bg);
    color: var(--color-info);
}

.order-status--shipped {
    background-color: var(--color-primary-bg);
    color: var(--color-primary);
}

.order-status--delivered {
    background-color: var(--color-success-bg);
    color: var(--color-success);
}

.order-status--cancelled {
    background-color: var(--color-error-bg);
    color: var(--color-error);
}

/* Order Detail Page */
.order-detail-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: var(--spacing-xl);
    margin-top: var(--spacing-lg);
}

.order-main {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
}

.order-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.order-actions {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.order-actions .btn--full {
    width: 100%;
    justify-content: center;
}

.order-items h2,
.order-summary h2,
.order-shipping h2 {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 1px solid var(--color-border);
}

.order-items-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.order-item {
    display: grid;
    grid-template-columns: 80px 1fr auto;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background-color: var(--color-background-alt);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    align-items: center;
}

.order-item__image {
    width: 80px;
    height: 80px;
    background-color: var(--product-image-bg);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    border: 1px solid var(--color-border);
}

.order-item__image img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.order-item__image svg {
    color: var(--color-text-muted);
}

.order-item__details {
    min-width: 0;
}

.order-item__details h3 {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    margin: 0 0 var(--spacing-xs) 0;
    line-height: 1.3;
}

.order-item__details p {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin: 0;
}

.order-item__details .order-item__sku {
    color: var(--color-text-light);
}

.order-item__details .order-item__qty {
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
}

.order-item__price {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    text-align: right;
    white-space: nowrap;
}

/* Order Summary */
.order-summary {
    background-color: var(--color-background-alt);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    border: 1px solid var(--color-border);
    height: fit-content;
}

.order-summary__list {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--spacing-sm) var(--spacing-md);
    margin: 0;
}

.order-summary__list dt {
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

.order-summary__list dd {
    text-align: right;
    font-size: var(--font-size-sm);
    margin: 0;
}

.order-summary__list dt.order-summary__total,
.order-summary__list dd.order-summary__total {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    padding-top: var(--spacing-md);
    margin-top: var(--spacing-sm);
    border-top: 1px solid var(--color-border);
}

/* Order Shipping Address */
.order-shipping {
    margin-top: var(--spacing-lg);
    background-color: var(--color-background-alt);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    border: 1px solid var(--color-border);
}

.order-shipping address {
    font-style: normal;
    font-size: var(--font-size-sm);
    line-height: 1.6;
    color: var(--color-text);
}

.order-date {
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
    margin-top: var(--spacing-sm);
}

@media (max-width: 900px) {
    .order-detail-grid {
        grid-template-columns: 1fr;
    }

    .order-sidebar {
        order: -1;
    }

    .order-item {
        grid-template-columns: 70px 1fr;
        grid-template-rows: auto auto;
    }

    .order-item__image {
        width: 70px;
        height: 70px;
        grid-row: span 2;
    }

    .order-item__price {
        grid-column: 2;
        text-align: left;
        font-size: var(--font-size-base);
    }
}

/* Address Card styles moved to components.css */

/* Account Empty State */
.account-empty {
    text-align: center;
    padding: var(--spacing-2xl);
}

.account-empty svg {
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-md);
}

.account-empty p {
    color: var(--color-text-light);
    margin-bottom: var(--spacing-lg);
}

/* Printers Preview */
.printers-preview {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.printer-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background-color: var(--color-background-alt);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
}

.printer-card svg {
    color: var(--color-primary);
    flex-shrink: 0;
}

.printer-card__details {
    flex: 1;
    min-width: 0;
}

.printer-card__name {
    display: block;
    font-weight: var(--font-weight-medium);
}

.printer-card__location {
    display: block;
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

/* Printer modal overlay */
.printer-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
}

.printer-modal[hidden] {
    display: none;
}

.printer-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.6);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.printer-modal__container {
    position: relative;
    width: 100%;
    max-width: 920px;
    max-height: 88vh;
    overflow-y: auto;
    border-radius: 20px;
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.05),
        0 20px 60px -15px rgba(0, 0, 0, 0.3),
        0 0 40px rgba(0, 0, 0, 0.08);
    background: #fff;
    animation: printerModalIn 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}

.printer-modal__container::-webkit-scrollbar {
    width: 6px;
}

.printer-modal__container::-webkit-scrollbar-track {
    background: transparent;
}

.printer-modal__container::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.15);
    border-radius: 3px;
}

@keyframes printerModalIn {
    from { opacity: 0; transform: scale(0.92) translateY(16px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
}

.printer-modal__close {
    position: absolute;
    top: 1.25rem;
    right: 1.25rem;
    z-index: 2;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--color-border, #e2e8f0);
    border-radius: 50%;
    background: #fff;
    color: var(--color-text-muted, #64748b);
    cursor: pointer;
    transition: all 0.15s ease;
}

.printer-modal__close:hover {
    background: var(--steel-50, #f8fafc);
    border-color: var(--steel-300, #cbd5e1);
    color: var(--color-text, #1e293b);
    transform: scale(1.05);
}

.printer-modal__container .ink-finder--account {
    margin-bottom: 0;
    background: none;
    padding: 0;
}

.printer-modal__container .ink-finder--account .ink-finder__wrapper {
    box-shadow: none;
    border-radius: 0;
}

.printer-modal__container .ink-finder__wrapper {
    padding: 2rem 2.5rem 2.5rem;
}

.printer-modal__container .ink-finder__header {
    margin-bottom: 1.75rem;
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--color-border, #e2e8f0);
}

.printer-modal__container .ink-finder__title {
    font-size: 1.5rem;
}

.printer-modal__container .ink-finder__subtitle {
    margin-top: 0.35rem;
    font-size: 0.95rem;
    color: var(--color-text-muted, #64748b);
}

/* Vertical step layout so dropdowns get full modal width */
.printer-modal__container .ink-finder__steps {
    flex-direction: column;
    gap: 1.25rem;
}

.printer-modal__container .ink-finder__step {
    width: 100%;
}

/* Step headers inline with trigger */
.printer-modal__container .ink-finder__step .ink-finder__step-header {
    margin-bottom: 0.5rem;
}

/* Brand buttons in a uniform grid row */
.printer-modal__container .ink-finder__brands {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0.5rem;
    max-width: none;
}

.printer-modal__container .ink-finder__brand-btn {
    width: 100%;
    height: 44px;
    padding: 0.4rem 0.5rem;
    border-radius: 8px;
    background: #f8fafc;
    border: 1.5px solid #e2e8f0;
}

.printer-modal__container .ink-finder__brand-btn:hover {
    border-color: #267FB5;
    background: #f0f9ff;
}

.printer-modal__container .ink-finder__brand-btn--selected {
    border-color: #267FB5;
    background: #eff8ff;
    box-shadow: 0 0 0 3px rgba(38, 127, 181, 0.12);
}

.printer-modal__container .ink-finder__brand-img,
.printer-modal__container .ink-finder__brand-img[class*="--"] {
    max-height: 18px;
    height: auto !important;
    width: auto;
    max-width: 100%;
    object-fit: contain;
}

/* Custom select takes full width in modal */
.printer-modal__container .custom-select {
    width: 100%;
}

/* Dropdowns render inline (not absolute) so they don't get clipped */
.printer-modal__container .custom-select__trigger[aria-expanded="true"] + .custom-select__dropdown,
.printer-modal__container .custom-select__dropdown {
    position: static;
    width: 100% !important;
    left: auto !important;
    max-height: 360px;
    border-top: none;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* Responsive: 3 cols on smaller modals, 2 on mobile */
@media (max-width: 768px) {
    .printer-modal__container .custom-select__dropdown {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 480px) {
    .printer-modal__container .custom-select__dropdown {
        grid-template-columns: 1fr !important;
    }
    .printer-modal__container .ink-finder__brands {
        grid-template-columns: repeat(3, 1fr);
        gap: 0.375rem;
    }
}

@media (max-width: 768px) {
    .printer-modal {
        padding: 0.75rem;
    }

    .printer-modal__container {
        max-height: 90vh;
        border-radius: 16px;
    }

    .printer-modal__container .ink-finder__wrapper {
        padding: 1.5rem 1.25rem 1.75rem;
    }
}

/* Ink-finder inside account content area */
.ink-finder--account {
    margin-bottom: var(--spacing-xl);
}

.ink-finder--account .ink-finder__wrapper {
    padding: var(--spacing-xl);
}

.ink-finder--account .ink-finder__header {
    margin-bottom: var(--spacing-lg);
}

.ink-finder__action-row {
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--color-border);
}

.ink-finder__action-row .form-group {
    margin-bottom: var(--spacing-md);
}

.ink-finder__action-buttons {
    display: flex;
    gap: var(--spacing-sm);
}

@media (max-width: 1024px) {
    .account-layout {
        grid-template-columns: 1fr;
    }

    .account-sidebar {
        order: -1;
    }
}

@media (max-width: 768px) {
    .orders-table thead {
        display: none;
    }

    .orders-table tr {
        display: block;
        padding: var(--spacing-md);
        border-bottom: 1px solid var(--color-border);
    }

    .orders-table td {
        display: flex;
        justify-content: space-between;
        padding: var(--spacing-sm) 0;
        border-bottom: none;
    }

    .orders-table td::before {
        content: attr(data-label);
        font-weight: var(--font-weight-medium);
        color: var(--color-text-muted);
    }
}


/* ==========================================================================
   ACCOUNT DASHBOARD - REDESIGNED
   ========================================================================== */

/* Welcome subtitle */
.account-content__welcome {
    color: var(--color-text-light);
    margin-bottom: var(--spacing-xl);
    font-size: var(--font-size-md);
}

/* Sidebar section dividers */
.account-nav__divider {
    font-size: 0.6875rem;
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
    padding: var(--spacing-md) var(--spacing-md) var(--spacing-1);
    margin-top: var(--spacing-sm);
    list-style: none;
}

.account-nav__divider:first-child {
    margin-top: 0;
}

/* Sidebar trust micro-panel */
.account-sidebar__trust {
    margin-top: var(--spacing-xl);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--color-border);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.account-sidebar__trust-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

.account-sidebar__trust-item svg {
    flex-shrink: 0;
    color: var(--color-primary);
}

/* --- Action Center --- */
.dash-action-center {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-2xl);
}

/* Dash cards */
.dash-card {
    background: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
    display: flex;
    flex-direction: column;
}

.dash-card--primary {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 1px var(--color-primary-light);
}

.dash-card__header {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.dash-card__header svg {
    color: var(--color-primary);
    flex-shrink: 0;
}

.dash-card__title {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-heading);
    margin: 0;
}

/* Empty state inside cards */
.dash-card__empty {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.dash-card__empty p {
    color: var(--color-text-light);
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-md);
}

.dash-card__empty-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    flex-wrap: wrap;
}

.dash-card__empty-link {
    font-size: var(--font-size-sm);
    color: var(--color-primary);
}

/* Skeleton loaders */
.dash-card__skeleton {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.skeleton-line {
    background: linear-gradient(90deg, var(--steel-100) 25%, var(--steel-200) 50%, var(--steel-100) 75%);
    background-size: 200% 100%;
    animation: skeleton-shimmer 1.5s infinite;
    border-radius: var(--radius-sm);
}

.skeleton-line--lg {
    height: 20px;
    width: 80%;
}

.skeleton-line--md {
    height: 18px;
    width: 60%;
}

.skeleton-line--sm {
    height: 14px;
    width: 45%;
}

.skeleton-line--btn {
    height: 40px;
    width: 120px;
    border-radius: var(--radius-md);
}

@keyframes skeleton-shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Quick Reorder card content */
.dash-reorder__product {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.dash-reorder__thumb {
    width: 56px;
    height: 56px;
    background: var(--steel-50);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    overflow: hidden;
}

.dash-reorder__thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.dash-reorder__thumb svg {
    color: var(--color-text-muted);
}

.dash-reorder__name {
    display: block;
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-heading);
    font-size: var(--font-size-sm);
}

.dash-reorder__meta {
    display: block;
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin-top: 2px;
}

.dash-reorder__actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-top: auto;
}

.dash-reorder__link {
    font-size: var(--font-size-sm);
    color: var(--color-primary);
}

/* Order Status card content */
.dash-status__info {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
    flex-wrap: wrap;
}

.dash-status__order-num {
    font-weight: var(--font-weight-semibold);
    font-family: var(--font-family-mono);
    font-size: var(--font-size-sm);
    color: var(--color-text-heading);
}

.dash-status__badge {
    display: inline-block;
    padding: 2px 10px;
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    text-transform: capitalize;
}

.dash-status__badge--processing {
    background: var(--yellow-light);
    color: var(--yellow-dark);
}

.dash-status__badge--shipped {
    background: var(--cyan-light);
    color: var(--cyan-dark);
}

.dash-status__badge--delivered {
    background: #dcfce7;
    color: #166534;
}

.dash-status__badge--pending {
    background: var(--steel-100);
    color: var(--steel-600);
}

.dash-status__eta {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    margin-bottom: var(--spacing-lg);
}

/* --- My Printers section --- */
.dash-printers {
    margin-bottom: var(--spacing-2xl);
}

.dash-section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-lg);
}

.dash-section-title {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-heading);
    margin: 0;
}

.dash-section-link {
    font-size: var(--font-size-sm);
    color: var(--color-primary);
}

.dash-printers__skeleton {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--spacing-md);
}

.skeleton-card {
    height: 120px;
    background: linear-gradient(90deg, var(--steel-100) 25%, var(--steel-200) 50%, var(--steel-100) 75%);
    background-size: 200% 100%;
    animation: skeleton-shimmer 1.5s infinite;
    border-radius: var(--radius-lg);
}

.dash-printers__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.dash-printer-card {
    background: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    transition: all var(--transition-fast);
}

.dash-printer-card:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-sm);
}

.dash-printer-card__brand {
    font-size: var(--font-size-xs);
    font-family: var(--font-family-mono);
    text-transform: uppercase;
    color: var(--color-primary);
    letter-spacing: 0.05em;
}

.dash-printer-card__model {
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-heading);
    font-size: var(--font-size-sm);
}

.dash-printer-card__actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-top: auto;
    padding-top: var(--spacing-sm);
}

.dash-printer-card__actions .btn--small {
    font-size: var(--font-size-xs);
}

.dash-printers__add-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px dashed var(--color-border-dark);
    border-radius: var(--radius-md);
    color: var(--color-text-light);
    font-size: var(--font-size-sm);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.dash-printers__add-btn:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
    text-decoration: none;
}

.dash-printers__empty {
    text-align: center;
    padding: var(--spacing-2xl) var(--spacing-lg);
    background: var(--steel-50);
    border: 1px dashed var(--color-border);
    border-radius: var(--radius-lg);
}

.dash-printers__empty svg {
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-md);
}

.dash-printers__empty p {
    color: var(--color-text-light);
    margin-bottom: var(--spacing-lg);
    font-size: var(--font-size-sm);
}

/* --- My Favourites section --- */
.dash-favourites {
    margin-bottom: var(--spacing-2xl);
}

.dash-favourites__skeleton {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: var(--spacing-md);
    margin-top: var(--spacing-md);
}

.dash-favourites__skeleton .skeleton-card {
    height: 220px;
}

.dash-favourites__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: var(--spacing-md);
    margin-top: var(--spacing-md);
}

.dash-fav-card {
    background: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    display: flex;
    flex-direction: column;
}

.dash-fav-card:hover {
    border-color: var(--color-border-dark);
    box-shadow: var(--shadow-md);
}

.dash-fav-card__link {
    display: block;
    text-decoration: none;
    color: inherit;
    flex: 1;
}

.dash-fav-card__link:hover {
    text-decoration: none;
}

.dash-fav-card__image {
    aspect-ratio: 4 / 3;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-sm);
    background: var(--product-image-bg);
}

.dash-fav-card__image img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.dash-fav-card__info {
    padding: var(--spacing-sm) var(--spacing-md);
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.dash-fav-card__name {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.3;
}

.dash-fav-card__brand {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

.dash-fav-card__price {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
    margin-top: 2px;
}

.dash-fav-card__cart-btn {
    margin: var(--spacing-sm) var(--spacing-md) var(--spacing-md);
    width: calc(100% - var(--spacing-md) * 2);
}

.dash-favourites__empty {
    text-align: center;
    padding: var(--spacing-2xl) var(--spacing-lg);
    background: var(--steel-50);
    border: 1px dashed var(--color-border);
    border-radius: var(--radius-lg);
}

.dash-favourites__empty svg {
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-md);
}

.dash-favourites__empty p {
    color: var(--color-text-light);
    margin-bottom: var(--spacing-lg);
    font-size: var(--font-size-sm);
}

/* --- Secondary tiles --- */
.dash-tiles {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-2xl);
}

.dash-tile {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    background: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    text-decoration: none;
    color: var(--color-text);
    transition: all var(--transition-fast);
}

.dash-tile:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-sm);
    text-decoration: none;
    transform: translateY(-2px);
}

.dash-tile__icon {
    width: 44px;
    height: 44px;
    background: var(--color-primary-bg);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--color-primary);
}

.dash-tile__text {
    flex: 1;
    min-width: 0;
}

.dash-tile__title {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-heading);
    margin: 0 0 2px;
}

.dash-tile__desc {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin: 0;
}

.dash-tile__arrow {
    flex-shrink: 0;
    color: var(--color-text-muted);
    transition: transform var(--transition-fast);
}

.dash-tile:hover .dash-tile__arrow {
    transform: translateX(3px);
    color: var(--color-primary);
}

/* --- Dashboard responsive --- */
@media (max-width: 1024px) {
    .dash-action-center {
        grid-template-columns: 1fr;
    }

    .dash-tiles {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .dash-printers__grid {
        grid-template-columns: 1fr;
    }

    .dash-printers__skeleton {
        grid-template-columns: 1fr;
    }

    .dash-tile__icon {
        width: 40px;
        height: 40px;
    }
}

/* --- Dashboard Navigation Grid --- */
.account-savings-banner {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md) var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.08), rgba(59, 130, 246, 0.06));
    border: 1px solid rgba(34, 197, 94, 0.25);
    border-radius: var(--radius-lg, 12px);
}
.account-savings-banner__icon {
    width: 48px; height: 48px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(34, 197, 94, 0.15);
    color: rgb(22, 163, 74);
    border-radius: 50%;
    flex-shrink: 0;
}
.account-savings-banner__label {
    font-size: 12px;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 600;
}
.account-savings-banner__value {
    font-size: 28px;
    font-weight: 800;
    color: rgb(22, 163, 74);
    line-height: 1.1;
    margin: 2px 0;
}
.account-savings-banner__sub {
    font-size: 13px;
    color: var(--color-text-muted);
}

.drilldown-box__count {
    display: block;
    margin-top: 6px;
    font-size: 11px;
    color: var(--color-text-muted);
    font-weight: 500;
}

.dash-nav-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-md);
}

.dash-nav-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-xl) var(--spacing-md);
    background: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    text-decoration: none;
    color: var(--color-text);
    transition: all var(--transition-fast);
}

.dash-nav-card:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-sm);
    text-decoration: none;
    transform: translateY(-2px);
}

.dash-nav-card__icon {
    width: 52px;
    height: 52px;
    background: var(--color-primary-bg);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    transition: background var(--transition-fast);
}

.dash-nav-card:hover .dash-nav-card__icon {
    background: var(--color-primary);
    color: #fff;
}

.dash-nav-card__title {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-heading);
    margin: 0;
}

.dash-nav-card__desc {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin: 0;
    line-height: 1.4;
}

@media (max-width: 1024px) {
    .dash-nav-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .dash-nav-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-sm);
    }

    .dash-nav-card {
        padding: var(--spacing-md) var(--spacing-sm);
    }

    .dash-nav-card__icon {
        width: 44px;
        height: 44px;
    }
}


/* ==========================================================================
   AUTH PAGES (Login/Register)
   ========================================================================== */

.auth-page {
    padding: var(--spacing-3xl) 0;
    background-color: var(--steel-900);
    min-height: calc(100vh - 200px);
    display: flex;
    align-items: center;
    position: relative;
}

/* Halftone dot pattern overlay */
.auth-page::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle, rgba(255,255,255,0.04) 1px, transparent 1px);
    background-size: 20px 20px;
    pointer-events: none;
}

.auth-container {
    max-width: 480px;
    margin: 0 auto;
    background-color: var(--color-background);
    padding: var(--spacing-2xl);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-2xl);
    position: relative;
    z-index: 1;
}

.auth-tabs {
    display: flex;
    margin-bottom: var(--spacing-xl);
    border-bottom: 2px solid var(--color-border);
}

.auth-tabs__tab {
    flex: 1;
    padding: var(--spacing-md);
    font-weight: var(--font-weight-medium);
    text-align: center;
    color: var(--color-text-light);
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: all var(--transition-fast);
}

.auth-tabs__tab:hover {
    color: var(--color-primary);
}

.auth-tabs__tab--active {
    border-bottom-color: var(--color-primary);
    color: var(--color-primary);
}

.auth-form__heading {
    text-align: center;
    margin-bottom: var(--spacing-sm);
}

.auth-form__subheading {
    text-align: center;
    color: var(--color-text-light);
    margin-bottom: var(--spacing-xl);
}

.auth-form__forgot {
    display: block;
    text-align: right;
    font-size: var(--font-size-sm);
    margin-top: var(--spacing-sm);
}

.auth-social {
    margin: var(--spacing-xl) 0;
    text-align: center;
}

.auth-social__divider {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

.auth-social__divider::before,
.auth-social__divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background-color: var(--color-border);
}

.auth-social__buttons {
    display: flex;
    gap: var(--spacing-md);
}

.auth-social__btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-medium);
    transition: all var(--transition-fast);
}

.auth-social__btn:hover {
    border-color: var(--color-border-dark);
    background-color: var(--color-background-alt);
}

/* Auth Form Wrapper */
.auth-form-wrapper {
    background-color: var(--color-background);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-2xl);
    padding: var(--spacing-2xl);
    position: relative;
    z-index: 1;
}

.auth-panel[hidden] {
    display: none;
}

/* Password Input */
.password-input-wrapper {
    position: relative;
}

.password-toggle {
    position: absolute;
    right: var(--spacing-3);
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-text-muted);
    padding: var(--spacing-1);
    transition: color var(--transition-fast);
}

.password-toggle:hover {
    color: var(--color-primary);
}

/* Auth Form Switch */
.auth-form__switch {
    text-align: center;
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

.auth-switch-btn {
    color: var(--color-primary);
    font-weight: var(--font-weight-medium);
    text-decoration: underline;
}

.auth-switch-btn:hover {
    color: var(--color-primary-dark);
}

/* Auth Messages */
.auth-message {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-lg);
    font-size: var(--font-size-sm);
}

.auth-message--success {
    background-color: #ecfdf5;
    border: 1px solid #10b981;
    color: #065f46;
}

.auth-message--success svg {
    flex-shrink: 0;
    color: #10b981;
}

.auth-message--error {
    background-color: #fef2f2;
    border: 1px solid #ef4444;
    color: #991b1b;
}

.auth-message--error svg {
    flex-shrink: 0;
    color: #ef4444;
}

/* Auth Success States */
.auth-success-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto var(--spacing-lg);
    background-color: #eff6ff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.auth-success-icon svg {
    color: #3b82f6;
}

.auth-success-icon--check {
    background-color: #ecfdf5;
}

.auth-success-icon--check svg {
    color: #10b981;
}

.auth-success-note {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
    background-color: #fffbeb;
    border: 1px solid #fcd34d;
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    color: #92400e;
    text-align: left;
    margin-bottom: var(--spacing-xl);
}

.auth-success-note svg {
    flex-shrink: 0;
    color: #f59e0b;
}

.auth-success-actions {
    margin-top: var(--spacing-lg);
}

/* Verify Email Page */
.verify-email-page {
    min-height: calc(100vh - 200px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-2xl) var(--spacing-md);
}

.verify-email-card {
    background-color: var(--color-background);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-lg);
    padding: var(--spacing-2xl) var(--spacing-xl);
    text-align: center;
    max-width: 480px;
    width: 100%;
}

.verify-email-icon {
    width: 100px;
    height: 100px;
    margin: 0 auto var(--spacing-xl);
    background-color: #ecfdf5;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.verify-email-icon svg {
    color: #10b981;
}

.verify-email-heading {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
    margin-bottom: var(--spacing-md);
}

.verify-email-text {
    color: var(--color-text-light);
    font-size: var(--font-size-md);
    line-height: 1.6;
    margin-bottom: var(--spacing-lg);
}

.verify-email-note {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
    background-color: #fffbeb;
    border: 1px solid #fcd34d;
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    color: #92400e;
    text-align: left;
    margin-bottom: var(--spacing-xl);
}

.verify-email-note svg {
    flex-shrink: 0;
    color: #f59e0b;
}

.verify-email-actions {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.verify-email-actions .btn {
    width: 100%;
}

@media (min-width: 480px) {
    .verify-email-actions {
        flex-direction: row;
    }

    .verify-email-actions .btn {
        flex: 1;
    }
}

/* Form Row Split */
.form-row--split {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-lg);
}

/* Social Login Buttons */
.btn--social {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-3);
    background-color: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-medium);
    transition: all var(--transition-fast);
}

.btn--social:hover {
    border-color: var(--color-border-dark);
    background-color: var(--color-background-alt);
}


/* Minimal Header (for auth pages) */
.site-header--minimal .header-main .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.site-header--centered .header-main .container {
    justify-content: center;
}

.header-back-link {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

.header-back-link:hover {
    color: var(--color-primary);
    text-decoration: none;
}

/* Minimal Footer */
.site-footer--minimal {
    background-color: var(--color-background);
    border-top: 1px solid var(--color-border);
}

.site-footer--minimal .footer-bottom {
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-md);
    text-align: center;
}

/* Form Label Optional */
.form-label__optional {
    font-weight: var(--font-weight-normal);
    color: var(--color-text-muted);
}

/* Container Narrow */
.container--narrow {
    max-width: 500px;
}



/* ==========================================================================
   INFORMATIONAL PAGES
   ========================================================================== */

.page-header {
    padding: var(--spacing-2xl) 0;
    background-color: var(--steel-50);
    text-align: center;
    border-bottom: 1px solid var(--color-border);
}

.page-header__title {
    margin-bottom: var(--spacing-sm);
    position: relative;
    display: inline-block;
}

.page-header__title::after {
    content: '';
    display: block;
    width: 100px;
    height: 3px;
    background: var(--accent-strip-gradient);
    margin: var(--spacing-sm) auto 0;
}

.page-header__description {
    max-width: 700px;
    margin: 0 auto;
    color: var(--color-text-light);
}

/* Content Sections */
.content-section {
    padding: var(--spacing-3xl) 0;
}

.content-section--alt {
    background-color: var(--color-background-alt);
}

/* Policy/Legal Content */
.policy-content,
.legal-content,
.faq-content {
    padding: var(--spacing-3xl) 0;
}

.policy-section,
.legal-section,
.faq-section {
    margin-bottom: var(--spacing-2xl);
}

.policy-section:last-child,
.legal-section:last-child,
.faq-section:last-child {
    margin-bottom: 0;
}

.policy-section__title,
.legal-section__title,
.faq-section__title {
    font-size: var(--font-size-xl);
    margin-bottom: var(--spacing-md);
    color: var(--color-text-heading);
    padding-left: var(--spacing-md);
    border-left: 3px solid var(--cyan-primary);
}

.policy-highlight {
    background-color: var(--color-info-bg);
    border-left: 4px solid var(--color-info);
    padding: var(--spacing-lg);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    margin: var(--spacing-lg) 0;
}

.policy-highlight p:last-child {
    margin-bottom: 0;
}

.legal-table {
    width: 100%;
    border-collapse: collapse;
    margin: var(--spacing-md) 0 var(--spacing-sm);
    font-size: var(--font-size-sm);
}

.legal-table th,
.legal-table td {
    padding: var(--spacing-sm) var(--spacing-md);
    text-align: left;
    border: 1px solid var(--color-border);
}

.legal-table thead th {
    background-color: var(--color-surface-raised);
    font-weight: 600;
    color: var(--color-text-heading);
}

.legal-table tbody tr:nth-child(even) {
    background-color: var(--color-surface);
}

/* ---- Contact Page ---- */

/* Hero Override */
.page-header--contact {
    background: linear-gradient(135deg, var(--cyan-dark) 0%, var(--cyan-primary) 60%, #3a9fd4 100%);
    border-bottom: none;
    padding: var(--spacing-xl) 0 var(--spacing-lg);
    position: relative;
    overflow: hidden;
}

.page-header--contact::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle, rgba(255,255,255,0.08) 1px, transparent 1px);
    background-size: 24px 24px;
    pointer-events: none;
}

.page-header--contact .page-header__title {
    color: #fff;
}

.page-header--contact .page-header__title::after {
    width: 60px;
    background: rgba(255,255,255,0.6);
}

.page-header--contact .page-header__description {
    color: rgba(255,255,255,0.85);
}

/* Hero Contact Cards */
.contact-hero-cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-md);
    margin-top: var(--spacing-xl);
    max-width: 100%;
}

.contact-hero-card {
    background: rgba(255,255,255,0.12);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,0.18);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg) var(--spacing-md);
    text-align: center;
    color: #fff;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.contact-hero-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.15);
}

.contact-hero-card__icon {
    width: 48px;
    height: 48px;
    margin: 0 auto var(--spacing-sm);
    background: rgba(255,255,255,0.15);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
}

.contact-hero-card__icon svg {
    width: 22px;
    height: 22px;
    stroke: #fff;
}

.contact-hero-card__title {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--spacing-xs);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    opacity: 0.7;
}

.contact-hero-card__value {
    font-size: 1.1rem;
    font-weight: var(--font-weight-bold);
    line-height: 1.4;
}

.contact-hero-card__value a {
    color: #fff;
    text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,0.3);
    transition: border-color 0.2s;
}

.contact-hero-card__value a:hover {
    border-color: #fff;
}

.contact-hero-card__note {
    font-size: var(--font-size-xs);
    opacity: 0.7;
    margin-top: var(--spacing-xs);
}

/* Content section spacing */
.contact-content {
    padding-top: var(--spacing-xl);
}

/* Form Card */
.contact-form-wrapper {
    background: #fff;
    border-radius: var(--radius-2xl);
    border: 1px solid var(--color-border-light);
    box-shadow: var(--shadow-md);
    overflow: hidden;
}

.contact-form-header {
    padding: var(--spacing-xl) var(--spacing-xl) var(--spacing-lg);
    border-bottom: 1px solid var(--color-border-light);
}

.contact-form-header h2 {
    font-size: var(--font-size-xl);
    color: var(--color-text-heading);
    margin-bottom: var(--spacing-xs);
}

.contact-form-header p {
    color: var(--color-text-light);
    font-size: var(--font-size-sm);
    margin: 0;
}

.contact-form-wrapper .contact-form {
    padding: var(--spacing-xl);
}

.contact-form-wrapper .form-input,
.contact-form-wrapper .form-select,
.contact-form-wrapper .form-textarea,
.contact-form-wrapper .phone-number,
.contact-form-wrapper .phone-country-code {
    background-color: var(--steel-50);
    border-radius: var(--radius-lg);
    transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.contact-form-wrapper .form-input:focus,
.contact-form-wrapper .form-select:focus,
.contact-form-wrapper .form-textarea:focus,
.contact-form-wrapper .phone-number:focus,
.contact-form-wrapper .phone-country-code:focus {
    background-color: #fff;
    border-color: var(--cyan-primary);
    box-shadow: 0 0 0 3px var(--cyan-light);
}

.contact-form__submit-area {
    border-top: 1px solid var(--color-border-light);
    padding-top: var(--spacing-lg);
    margin-top: var(--spacing-md);
}

.contact-form__submit-area .btn {
    width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
}

.contact-form__submit-area .btn svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

.contact-form__note {
    text-align: center;
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin-top: var(--spacing-md);
    margin-bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs);
}

.contact-form__note svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    stroke: var(--color-text-muted);
}

/* Sidebar */
.contact-info {
    position: sticky;
    top: var(--spacing-lg);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.contact-sidebar-card {
    background: #fff;
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    box-shadow: 0 1px 3px rgba(15,23,42,0.04);
}

.contact-sidebar-card h3 {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-heading);
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 2px solid var(--cyan-light);
}

/* Office card */
.contact-sidebar-card address {
    font-style: normal;
    color: var(--color-text);
    line-height: 1.7;
}

.contact-sidebar-card .office-note {
    font-size: var(--font-size-sm);
    font-style: italic;
    color: var(--color-text-muted);
    margin-top: var(--spacing-sm);
}

/* Quick Links */
.contact-quicklinks__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-1);
}

.contact-quicklinks__list li a {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-md);
    color: var(--color-text);
    text-decoration: none;
    font-size: var(--font-size-sm);
    transition: background-color 0.15s ease, color 0.15s ease;
}

.contact-quicklinks__list li a:hover {
    background-color: var(--cyan-light);
    color: var(--cyan-dark);
}

.contact-quicklinks__list li a svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    stroke: var(--color-text-muted);
    transition: stroke 0.15s ease;
}

.contact-quicklinks__list li a:hover svg {
    stroke: var(--cyan-dark);
}

/* Social Links */
.contact-social .social-links {
    display: flex;
    gap: var(--spacing-sm);
}

.contact-social .social-link {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-full);
    background: var(--steel-100);
    color: var(--steel-500);
    transition: background-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.contact-social .social-link:hover {
    background: var(--cyan-primary);
    color: #fff;
    box-shadow: var(--shadow-cyan);
}

.contact-social .social-link svg {
    width: 20px;
    height: 20px;
}

/* Contact Responsive */
@media (max-width: 768px) {
    .contact-hero-cards {
        grid-template-columns: repeat(2, 1fr);
        min-width: 0;
    }

    .contact-hero-card {
        min-width: 0;
        word-break: break-word;
    }

    .page-header--contact {
        padding: var(--spacing-lg) 0 var(--spacing-md);
    }

    .contact-info {
        position: static;
    }
}

@media (max-width: 480px) {
    .page-header--contact {
        padding: var(--spacing-md) 0;
    }

    .contact-form-wrapper .contact-form {
        padding: var(--spacing-md);
    }

    .contact-form-header {
        padding: var(--spacing-md) var(--spacing-md) var(--spacing-sm);
    }

    .contact-hero-card__icon {
        width: 36px;
        height: 36px;
    }

    .contact-hero-card__icon svg {
        width: 18px;
        height: 18px;
    }

    .contact-hero-card {
        padding: var(--spacing-md) var(--spacing-sm);
    }
}


/* ==========================================================================
   SEARCH RESULTS PAGE
   ========================================================================== */

.search-page {
    padding: var(--spacing-xl) 0 var(--spacing-3xl);
}

.search-header {
    margin-bottom: var(--spacing-xl);
}

.search-header__title {
    margin-bottom: var(--spacing-sm);
}

.search-header__query {
    color: var(--color-primary);
}

.search-header__count {
    color: var(--color-text-light);
}

.search-suggestions-section {
    margin-bottom: var(--spacing-xl);
    padding: var(--spacing-lg);
    background-color: var(--color-background-alt);
    border-radius: var(--radius-lg);
}

.search-suggestions-section__title {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-md);
}

.search-suggestions-section__list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.search-suggestion-link {
    padding: var(--spacing-2) var(--spacing-4);
    background-color: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    color: var(--color-text);
    transition: all var(--transition-fast);
}

.search-suggestion-link:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
    text-decoration: none;
}

.search-no-results {
    text-align: center;
    padding: var(--spacing-3xl);
}

.search-no-results__icon {
    font-size: 4rem;
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-lg);
}

.search-no-results__title {
    margin-bottom: var(--spacing-md);
}

.search-no-results__text {
    color: var(--color-text-light);
    margin-bottom: var(--spacing-xl);
}


/* ==========================================================================
   ERROR PAGES
   ========================================================================== */

.error-page {
    padding: var(--spacing-3xl) 0;
    text-align: center;
}

.error-content {
    max-width: 700px;
    margin: 0 auto;
}

.error-code {
    font-size: 8rem;
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
    line-height: 1;
    margin-bottom: var(--spacing-lg);
}

.error-content__title {
    font-size: var(--font-size-2xl);
    margin-bottom: var(--spacing-md);
}

.error-content__message {
    color: var(--color-text-light);
    margin-bottom: var(--spacing-2xl);
    font-size: var(--font-size-md);
    line-height: 1.7;
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
}

.error-content__search {
    max-width: 480px;
    margin: 0 auto var(--spacing-2xl);
}

.error-content__search p {
    margin-bottom: var(--spacing-md);
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
}

.error-content__search .search-form--large {
    display: flex;
    gap: 0;
}

.error-content__search .search-form__input {
    flex: 1;
    border-radius: var(--radius-md) 0 0 var(--radius-md);
    border-right: none;
}

.error-content__search .search-form__button {
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    padding: var(--spacing-sm) var(--spacing-lg);
}

.error-content__suggestions {
    margin-bottom: var(--spacing-2xl);
}

.error-content__suggestions h2 {
    font-size: var(--font-size-lg);
    margin-bottom: var(--spacing-md);
}

.error-content__suggestions ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.error-content__suggestions li {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.error-content__actions {
    display: flex;
    justify-content: center;
    gap: var(--spacing-md);
    flex-wrap: wrap;
    margin-bottom: var(--spacing-3xl);
}

.error-content__categories {
    margin-bottom: var(--spacing-2xl);
}

.error-content__categories h2 {
    font-size: var(--font-size-lg);
    margin-bottom: var(--spacing-lg);
}

.category-links {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--spacing-md);
}

.error-content__help {
    padding: var(--spacing-lg);
    background: var(--color-background-alt);
    border-radius: var(--radius-lg);
    max-width: 520px;
    margin: 0 auto;
}

.error-content__help p {
    margin: 0;
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.error-content__help a {
    color: var(--cyan-primary);
}


/* ==========================================================================
   ORDER CONFIRMATION
   ========================================================================== */

.confirmation-page {
    padding: var(--spacing-xl) 0 var(--spacing-3xl);
}

.confirmation-header {
    text-align: center;
    margin-bottom: var(--spacing-2xl);
}

.confirmation-header__icon {
    width: 80px;
    height: 80px;
    margin: 0 auto var(--spacing-lg);
    background-color: var(--color-success-bg);
    color: var(--color-success);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
}

.confirmation-header__title {
    margin-bottom: var(--spacing-sm);
}

.confirmation-header__order-number {
    color: var(--color-primary);
    font-weight: var(--font-weight-semibold);
}

.confirmation-header__message {
    color: var(--color-text-light);
    max-width: 500px;
    margin: 0 auto;
}

/* Confirmation Details Grid */
.confirmation-details {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-2xl);
}

.confirmation-card {
    background-color: var(--color-background-alt);
    padding: var(--spacing-xl);
    border-radius: var(--radius-xl);
    border: 1px solid var(--color-border);
}

.confirmation-card__heading {
    font-size: var(--font-size-md);
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--color-border);
}

.confirmation-card__list {
    margin: 0;
    padding: 0;
}

.confirmation-card__list dd {
    margin: 0;
}

.confirmation-card__address {
    font-style: normal;
    line-height: 1.6;
    margin-bottom: var(--spacing-md);
}

.confirmation-card__shipping-method {
    margin: 0;
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-border-light);
    font-size: var(--font-size-sm);
    line-height: 1.8;
}

.confirmation-card__row {
    display: flex;
    justify-content: space-between;
    padding: var(--spacing-2) 0;
}

.confirmation-card__label {
    color: var(--color-text-light);
}

.confirmation-card__value {
    font-weight: var(--font-weight-medium);
}

/* Next Steps */
.confirmation-next {
    background-color: var(--color-background-alt);
    padding: var(--spacing-xl);
    border-radius: var(--radius-xl);
    margin-bottom: var(--spacing-2xl);
}

.confirmation-next__heading {
    text-align: center;
    margin-bottom: var(--spacing-lg);
}

.confirmation-next__steps {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-lg);
}

.confirmation-step {
    text-align: center;
    padding: var(--spacing-md);
}

.confirmation-step__number {
    width: 36px;
    height: 36px;
    margin: 0 auto var(--spacing-md);
    background-color: var(--color-primary);
    color: var(--color-text-inverse);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: var(--font-weight-bold);
}

.confirmation-step__text {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

/* Confirmation Actions */
.confirmation-actions {
    display: flex;
    justify-content: center;
    gap: var(--spacing-md);
    flex-wrap: wrap;
}

/* Confirmation Items */
.confirmation-items {
    background-color: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
    margin-bottom: var(--spacing-2xl);
}

.confirmation-items__heading {
    font-size: var(--font-size-lg);
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--color-border);
}

.confirmation-items__list {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--spacing-lg) 0;
}

.confirmation-item {
    display: grid;
    grid-template-columns: 80px 1fr auto auto;
    gap: var(--spacing-md);
    align-items: center;
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid var(--color-border-light);
}

.confirmation-item:last-child {
    border-bottom: none;
}

.confirmation-item--fallback {
    padding: 2rem;
    text-align: center;
    list-style: none;
}

.confirmation-item--fallback p {
    margin: 0;
    color: var(--color-text-muted);
}

.confirmation-item__image {
    width: 80px;
    height: 80px;
    background-color: var(--color-background-alt);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    border: 1px solid var(--color-border-light);
}

.confirmation-item__image img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    padding: 4px;
}

.confirmation-item__color-block {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
}

.confirmation-item__details {
    min-width: 0;
}

.confirmation-item__title {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    margin: 0 0 var(--spacing-xs) 0;
    line-height: 1.3;
    color: var(--color-text);
}

.confirmation-item__meta {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin: 0;
}

.confirmation-item__meta span {
    display: inline-block;
}

.confirmation-item__meta span + span::before {
    content: "•";
    margin: 0 var(--spacing-xs);
    color: var(--color-border);
}

.confirmation-item__meta .badge {
    font-size: 11px;
    padding: 2px 6px;
    margin-left: var(--spacing-xs);
    vertical-align: middle;
}

.confirmation-item__meta .badge::before {
    display: none;
}

.confirmation-item__quantity {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    white-space: nowrap;
    text-align: center;
    min-width: 60px;
}

.confirmation-item__price {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
    white-space: nowrap;
    text-align: right;
    min-width: 80px;
}

/* Confirmation Totals */
.confirmation-totals {
    background-color: var(--color-background-alt);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    margin: 0;
}

.confirmation-totals__row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-sm) 0;
    font-size: var(--font-size-sm);
}

.confirmation-totals__row dt {
    color: var(--color-text-light);
}

.confirmation-totals__row dd {
    margin: 0;
    font-weight: var(--font-weight-medium);
}

.confirmation-totals__row--savings {
    color: var(--color-success);
}

.confirmation-totals__row--savings dd {
    color: var(--color-success);
    font-weight: var(--font-weight-semibold);
}

.confirmation-totals__row--total {
    border-top: 2px solid var(--color-border);
    margin-top: var(--spacing-sm);
    padding-top: var(--spacing-md);
    font-size: var(--font-size-lg);
}

.confirmation-totals__row--total dt,
.confirmation-totals__row--total dd {
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
}

/* Post-purchase prompt cards */
.confirmation-card--accent {
    background: var(--cyan-light, #D4E8F5);
    border: 1px solid var(--cyan-primary, #267FB5);
    text-align: center;
}

.confirmation-card--accent h3 {
    margin: 0 0 0.5rem;
    font-size: 1.1rem;
}

.confirmation-card--accent p {
    margin: 0 0 1rem;
    color: var(--steel-600, #475569);
    font-size: var(--font-size-sm);
}

.confirmation-card--subtle {
    background: var(--steel-50, #F8FAFC);
    border: 1px solid var(--steel-200, #E2E8F0);
    text-align: center;
}

.confirmation-card--subtle h3 {
    margin: 0 0 0.5rem;
    font-size: 1.1rem;
}

.confirmation-card--subtle p {
    margin: 0 0 1rem;
    color: var(--steel-600, #475569);
    font-size: var(--font-size-sm);
}

/* Post-purchase hooks container */
.confirmation-relationship {
    display: grid;
    gap: 1rem;
    margin-bottom: 2rem;
}

/* Confirmation Help */
.confirmation-help {
    background-color: var(--color-background-alt);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
    text-align: center;
    margin-top: var(--spacing-2xl);
}

.confirmation-help h3 {
    margin-bottom: var(--spacing-sm);
}

.confirmation-help p {
    color: var(--color-text-light);
    margin-bottom: var(--spacing-lg);
}

.confirmation-help__contact {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--spacing-lg);
}

.confirmation-help__link {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    color: var(--color-text);
    font-size: var(--font-size-sm);
    transition: color var(--transition-fast);
}

.confirmation-help__link:hover {
    color: var(--color-primary);
    text-decoration: none;
}

.confirmation-help__link svg {
    color: var(--color-primary);
}

/* Confirmation Next Steps - Improved */
.confirmation-next__steps {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--spacing-lg);
}

.confirmation-next__steps li {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: var(--color-background);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border-light);
}

.confirmation-next__icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-primary-light);
    border-radius: var(--radius-md);
    color: var(--color-primary);
}

.confirmation-next__steps li h3 {
    font-size: var(--font-size-sm);
    margin: 0 0 var(--spacing-xs) 0;
    color: var(--color-text);
}

.confirmation-next__steps li p {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    margin: 0;
    line-height: 1.4;
}

/* Responsive Confirmation Items */
@media (max-width: 640px) {
    .confirmation-item {
        grid-template-columns: 60px 1fr;
        gap: var(--spacing-sm);
    }

    .confirmation-item__image {
        width: 60px;
        height: 60px;
        grid-row: span 2;
    }

    .confirmation-item__details {
        grid-column: 2;
    }

    .confirmation-item__quantity,
    .confirmation-item__price {
        grid-column: 2;
        text-align: left;
        min-width: auto;
    }

    .confirmation-item__quantity {
        display: inline;
    }

    .confirmation-item__price {
        display: inline;
        margin-left: var(--spacing-md);
    }

    .confirmation-next__steps {
        grid-template-columns: 1fr;
    }

    .confirmation-help__contact {
        flex-direction: column;
        align-items: center;
    }
}


/* ==========================================================================
   RESPONSIVE ADJUSTMENTS
   ========================================================================== */

@media (max-width: 768px) {
    .hero__title {
        font-size: var(--font-size-xl);
    }

    .newsletter__form {
        flex-direction: column;
    }

    .auth-container {
        margin: 0 var(--spacing-md);
        padding: var(--spacing-xl);
    }

    .error-code {
        font-size: 5rem;
    }
}

@media (max-width: 480px) {
    .hero {
        padding: var(--spacing-2xl) 0;
    }

    .trust-bar__list {
        gap: var(--spacing-lg);
    }

    .trust-bar__item {
        flex-basis: 100%;
        justify-content: center;
    }

    .confirmation-details {
        grid-template-columns: 1fr;
    }
}


/* ==========================================================================
   SHOP PAGE - Filter & Product Grid
   ========================================================================== */

.shop-page {
    padding: var(--spacing-xl) 0;
    background-color: var(--color-background-alt);
    min-height: 60vh;
}

.shop-page__layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: var(--spacing-xl);
    align-items: start;
}

/* Filter Sidebar */
.shop-filters {
    background: var(--white-primary);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    position: sticky;
    top: var(--spacing-lg);
}

.shop-filters__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-heading);
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-md);
    border-bottom: 2px solid var(--cyan-primary);
}

/* Filter Brand Items */
.filter-brand {
    border-bottom: 1px solid var(--color-border-light);
}

.filter-brand:last-child {
    border-bottom: none;
}

.filter-brand__header {
    display: flex;
    align-items: center;
    width: 100%;
    padding: var(--spacing-md) 0;
    background: none;
    border: none;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.filter-brand__header:hover {
    background-color: var(--color-background-alt);
    margin: 0 calc(-1 * var(--spacing-md));
    padding-left: var(--spacing-md);
    padding-right: var(--spacing-md);
    width: calc(100% + var(--spacing-lg));
}

.filter-brand__logo {
    width: 40px;
    height: 30px;
    object-fit: contain;
    margin-right: var(--spacing-md);
}

.filter-brand__name {
    flex: 1;
    text-align: left;
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
}

.filter-brand__arrow {
    transition: transform var(--transition-fast);
    color: var(--color-text-muted);
}

.filter-brand__header[aria-expanded="true"] .filter-brand__arrow {
    transform: rotate(180deg);
}

.filter-brand__options {
    list-style: none;
    padding: 0 0 var(--spacing-md) var(--spacing-lg);
    margin: 0;
}

.filter-brand__options li {
    margin-bottom: var(--spacing-xs);
}

.filter-brand__options a {
    display: block;
    padding: var(--spacing-xs) var(--spacing-sm);
    color: var(--color-text-light);
    font-size: var(--font-size-sm);
    border-radius: var(--radius-sm);
    transition: all var(--transition-fast);
}

.filter-brand__options a:hover {
    background-color: var(--cyan-light);
    color: var(--cyan-dark);
    text-decoration: none;
}

/* Products Section */
.shop-products {
    min-width: 0;
}

.shop-products__grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--spacing-md);
}

/* Product Box */
.product-box {
    background: var(--white-primary);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: all var(--transition-fast);
    display: flex;
    flex-direction: column;
}

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

.product-box__link {
    display: block;
    text-decoration: none;
    color: inherit;
    flex: 1;
}

.product-box__image {
    aspect-ratio: 1;
    background: var(--product-image-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-md);
}

.product-box__image svg {
    color: var(--color-text-muted);
}

.product-box__content {
    padding: var(--spacing-sm);
}

.product-box__brand {
    font-size: var(--font-size-xs);
    color: var(--cyan-primary);
    font-weight: var(--font-weight-medium);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.product-box__title {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
    margin: var(--spacing-xs) 0;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.product-box__pricing {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-xs);
}

.product-box__price {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-heading);
}

.product-box__price-was {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    text-decoration: line-through;
}

.product-box__stock {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
}

.product-box__stock--in {
    color: var(--color-success);
}

.product-box__cart-btn {
    margin: var(--spacing-sm);
    margin-top: 0;
    width: calc(100% - var(--spacing-md));
}

/* Load More Section */
.shop-products__load-more {
    display: flex;
    justify-content: center;
    padding: var(--spacing-2xl) 0;
}

/* Active Filter Link Highlight */
.filter-brand__options--active {
    background-color: var(--cyan-primary) !important;
    color: var(--white-primary) !important;
    font-weight: var(--font-weight-semibold);
}

/* Active Filters Bar */
.active-filters {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md) var(--spacing-lg);
    background: var(--cyan-light);
    border-radius: var(--radius-lg);
    margin-bottom: var(--spacing-lg);
    flex-wrap: wrap;
}

.active-filters__list {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
    flex: 1;
}

.active-filters__tag {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
    background: var(--white-primary);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--cyan-dark);
    box-shadow: var(--shadow-sm);
}

.active-filters__remove {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    padding: 0;
    background: var(--color-background-alt);
    border: none;
    border-radius: 50%;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.active-filters__remove:hover {
    background: var(--color-error);
    color: var(--white-primary);
}

.active-filters__remove svg {
    width: 12px;
    height: 12px;
}

.active-filters__clear {
    padding: var(--spacing-xs) var(--spacing-md);
    background: transparent;
    border: 1px solid var(--cyan-primary);
    border-radius: var(--radius-md);
    color: var(--cyan-primary);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    cursor: pointer;
    transition: all var(--transition-fast);
    white-space: nowrap;
}

.active-filters__clear:hover {
    background: var(--cyan-primary);
    color: var(--white-primary);
}

.active-filters__search-query {
    font-weight: var(--font-weight-semibold);
    color: var(--cyan-dark);
    font-size: var(--font-size-base);
}

/* Products Header */
.shop-products__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-md);
}

.shop-products__count {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin: 0;
}

/* No Results State */
.shop-products__no-results {
    grid-column: 1 / -1;
    text-align: center;
    padding: var(--spacing-3xl) var(--spacing-xl);
    background: var(--white-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}

.shop-products__no-results svg {
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-lg);
}

.shop-products__no-results h3 {
    font-size: var(--font-size-xl);
    color: var(--color-text-heading);
    margin-bottom: var(--spacing-sm);
}

.shop-products__no-results p {
    color: var(--color-text-muted);
    margin: 0;
}

.shop-products__no-results a {
    color: var(--cyan-primary);
    font-weight: var(--font-weight-medium);
}

.shop-products__no-results a:hover {
    text-decoration: underline;
}

/* Shop Products Loading State */
.shop-products__loading {
    grid-column: 1 / -1;
    text-align: center;
    padding: var(--spacing-3xl) var(--spacing-xl);
    background: var(--white-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}

.shop-products__loading p {
    color: var(--color-text-muted);
    margin-top: var(--spacing-md);
}

.loading-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid var(--color-border);
    border-top-color: var(--cyan-primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin: 0 auto;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* Product Box Badge (Compatible label) */
.product-box__link {
    position: relative;
}

.product-box__badge {
    position: absolute;
    top: var(--spacing-sm);
    left: var(--spacing-sm);
    padding: var(--spacing-2) var(--spacing-xs);
    font-size: 11px;
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: var(--radius-sm);
    z-index: 1;
}

.product-box__badge--compatible {
    background: var(--yellow-primary);
    color: var(--black-primary);
}

/* Responsive - Shop Page */
@media (max-width: 1400px) {
    .shop-products__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (max-width: 1100px) {
    .shop-products__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 900px) {
    .shop-page__layout {
        grid-template-columns: 240px 1fr;
    }

    .shop-products__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .shop-page__layout {
        grid-template-columns: 1fr;
    }

    .shop-filters {
        position: static;
    }

    .shop-products__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 600px) {
    .shop-products__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 400px) {
    .shop-products__grid {
        grid-template-columns: 1fr;
    }
}


/* ==========================================================================
   SMART SEARCH DROPDOWN
   ========================================================================== */

/* Note: Width for .search-wrapper is controlled in layout.css (50% for nav bar) */
.search-wrapper {
    position: relative;
}

.search-results {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--white-primary);
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    box-shadow: var(--shadow-xl);
    z-index: var(--z-dropdown);
    max-height: 450px;
    overflow-y: auto;
    margin-top: 2px;
}

.search-results__list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.search-results__item {
    border-bottom: 1px solid var(--color-border-light);
}

.search-results__item:last-child {
    border-bottom: none;
}

.search-results__item--focused,
.search-results__item:hover {
    background-color: var(--cyan-light);
}

.search-results__link {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    text-decoration: none;
    color: inherit;
}

.search-results__image {
    width: 50px;
    height: 50px;
    background: var(--color-background-alt);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.search-results__image svg {
    color: var(--color-text-muted);
}

.search-results__info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.search-results__brand {
    font-size: var(--font-size-xs);
    color: var(--cyan-primary);
    font-weight: var(--font-weight-medium);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.search-results__name {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.search-results__name mark {
    background-color: var(--yellow-light);
    color: inherit;
    padding: 0 2px;
    border-radius: 2px;
}

.search-results__sku {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

.search-results__price-info {
    text-align: right;
    flex-shrink: 0;
}

.search-results__price {
    display: block;
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-heading);
}

.search-results__stock {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
}

.search-results__stock--in {
    color: var(--color-success);
}

.search-results__empty {
    padding: var(--spacing-lg);
    text-align: center;
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

.search-results__view-all {
    background-color: var(--color-background-alt);
    border-top: 1px solid var(--color-border);
}

.search-results__view-all a {
    display: block;
    padding: var(--spacing-md);
    text-align: center;
    color: var(--cyan-primary);
    font-weight: var(--font-weight-medium);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.search-results__view-all a:hover {
    background-color: var(--cyan-light);
    color: var(--cyan-dark);
}

/* Responsive - Search Dropdown */
@media (max-width: 768px) {
    .search-wrapper {
        max-width: none;
    }

    .search-results {
        max-height: 60vh;
    }

    .search-results__link {
        padding: var(--spacing-md);
    }

    .search-results__image {
        width: 40px;
        height: 40px;
    }
}

/* ==========================================================================
   SEARCH AUTOCOMPLETE
   ========================================================================== */

.search-form {
    position: relative;
}

.search-autocomplete {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--white-primary);
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    box-shadow: var(--shadow-xl);
    z-index: 1000;
    max-height: 400px;
    overflow-y: auto;
    margin-top: 2px;
    display: none;
}

.search-autocomplete.is-open {
    display: block;
}

.search-autocomplete__list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.search-autocomplete__item {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    padding: var(--spacing-3) var(--spacing-4);
    cursor: pointer;
    border-bottom: 1px solid var(--color-border-light);
    transition: background-color var(--transition-fast);
}

.search-autocomplete__item:last-child {
    border-bottom: none;
}

.search-autocomplete__item:hover,
.search-autocomplete__item.is-selected {
    background-color: var(--cyan-light);
}

.search-autocomplete__item--printer {
    background-color: rgba(0, 128, 128, 0.03);
}

.search-autocomplete__item--printer:hover,
.search-autocomplete__item--printer.is-selected {
    background-color: var(--cyan-light);
}

.search-autocomplete__icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-background-alt);
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
}

.search-autocomplete__item--printer .search-autocomplete__icon {
    background: var(--cyan-light);
    color: var(--cyan-primary);
}

.search-autocomplete__content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.search-autocomplete__name {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.search-autocomplete__meta {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

.search-autocomplete__item--printer .search-autocomplete__meta {
    color: var(--cyan-primary);
}

.search-autocomplete__empty {
    padding: var(--spacing-4);
    text-align: center;
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

/* Responsive */
@media (max-width: 768px) {
    .search-autocomplete {
        position: fixed;
        left: var(--spacing-3);
        right: var(--spacing-3);
        max-height: 50vh;
    }
}


/* ==========================================================================
   SHOP PAGE - DRILL-DOWN NAVIGATION
   ========================================================================== */

/* Drilldown variant of shop page */
.shop-page--drilldown {
    padding: var(--spacing-md) 0 var(--spacing-2xl);
    background-color: var(--steel-50);
}

/* Title */
.drilldown-title {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-extrabold);
    letter-spacing: var(--letter-spacing-tight);
    color: var(--color-text-heading);
    margin: 0 0 var(--spacing-3) 0;
    text-align: left;
}


/* Brand Section Wrappers */
.brand-section {
    margin-bottom: 0;
}

/* ── Shop Section Cards ── */
.shop-section-card {
    background: var(--white-primary);
    border: 1px solid var(--steel-200);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg) var(--spacing-lg) var(--spacing-5);
    margin-bottom: var(--spacing-5);
    position: relative;
}

.shop-section-card__header {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    margin-bottom: var(--spacing-5);
}

.shop-section-card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: var(--radius-lg);
    flex-shrink: 0;
}

.shop-section-card__icon--ink {
    background: var(--cyan-light);
    color: var(--cyan-primary);
}

.shop-section-card__icon--ribbon {
    background: var(--steel-100);
    color: var(--steel-500);
}

.shop-section-card__title {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    color: var(--steel-800);
    margin: 0;
    letter-spacing: -0.01em;
}

.shop-section-card__link {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-top: var(--spacing-5);
    padding-top: var(--spacing-4);
    border-top: 1px solid var(--steel-100);
    color: var(--cyan-primary);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    text-decoration: none;
    transition: color 0.15s;
}

.shop-section-card__link:hover {
    color: var(--cyan-dark);
}

/* Tiles inside section cards — refined look */
.shop-section-card .drilldown-box {
    border-width: 1px;
    box-shadow: none;
    min-height: 0;
}

.shop-section-card .drilldown-box::after {
    display: none;
}

.shop-section-card .drilldown-box:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(38, 127, 181, 0.1);
}

.shop-section-card .drilldown-box--brand {
    min-height: 80px;
    padding: var(--spacing-3) var(--spacing-5);
}

/* Legacy — keep for backward compat */
.shop-brands-panel {
    background: var(--white-primary);
    border: 1px solid var(--steel-200);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-sm);
    padding: var(--spacing-lg);
    position: relative;
    overflow: hidden;
}

.shop-brands-panel__accent {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--cyan-primary);
}

/* Stagger-in animation for brand tiles */
@keyframes brandTileIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Brand tiles inside section cards */
.shop-section-card .drilldown-box--brand {
    animation: brandTileIn 0.3s ease-out both;
}

.shop-brands-panel .drilldown-box--brand {
    animation: brandTileIn 0.3s ease-out both;
}

/* Cartridge tiles staggered at 30ms intervals */
.shop-section-card .drilldown-box--brand:nth-child(1) { animation-delay: 0ms; }
.shop-section-card .drilldown-box--brand:nth-child(2) { animation-delay: 30ms; }
.shop-section-card .drilldown-box--brand:nth-child(3) { animation-delay: 60ms; }
.shop-section-card .drilldown-box--brand:nth-child(4) { animation-delay: 90ms; }
.shop-section-card .drilldown-box--brand:nth-child(5) { animation-delay: 120ms; }
.shop-section-card .drilldown-box--brand:nth-child(6) { animation-delay: 150ms; }
.shop-section-card .drilldown-box--brand:nth-child(7) { animation-delay: 180ms; }
.shop-section-card .drilldown-box--brand:nth-child(8) { animation-delay: 210ms; }
.shop-section-card .drilldown-box--brand:nth-child(9) { animation-delay: 240ms; }
.brand-section--cartridges .drilldown-box--brand:nth-child(1) { animation-delay: 0ms; }
.brand-section--cartridges .drilldown-box--brand:nth-child(2) { animation-delay: 30ms; }
.brand-section--cartridges .drilldown-box--brand:nth-child(3) { animation-delay: 60ms; }
.brand-section--cartridges .drilldown-box--brand:nth-child(4) { animation-delay: 90ms; }
.brand-section--cartridges .drilldown-box--brand:nth-child(5) { animation-delay: 120ms; }
.brand-section--cartridges .drilldown-box--brand:nth-child(6) { animation-delay: 150ms; }
.brand-section--cartridges .drilldown-box--brand:nth-child(7) { animation-delay: 180ms; }
.brand-section--cartridges .drilldown-box--brand:nth-child(8) { animation-delay: 210ms; }
.brand-section--cartridges .drilldown-box--brand:nth-child(9) { animation-delay: 240ms; }

@media (prefers-reduced-motion: reduce) {
    .shop-brands-panel .drilldown-box--brand,
    .shop-section-card .drilldown-box--brand,
    .shop-section-card .drilldown-box--ribbon {
        animation: none;
    }
}

.drilldown-grid--ribbons {
    grid-template-columns: repeat(5, 1fr);
}

.drilldown-box.drilldown-box--ribbon {
    min-height: 0;
    flex-direction: row;
    padding: var(--spacing-sm) var(--spacing-md);
    cursor: pointer;
    animation: brandTileIn 0.3s ease-out both;
    transition: border-color 0.2s, box-shadow 0.2s, background 0.2s, color 0.2s;
    text-decoration: none;
    background: #fff;
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: none;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs);
}

.drilldown-box.drilldown-box--ribbon:hover {
    border-color: var(--cyan-primary);
    color: var(--cyan-primary);
    box-shadow: 0 2px 8px rgba(8, 145, 178, 0.12);
    background: #fff;
    text-decoration: none;
    transform: none;
}

.drilldown-box--ribbon .drilldown-box__label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-heading);
    text-align: center;
}

.drilldown-box.drilldown-box--ribbon:hover .drilldown-box__label {
    color: var(--cyan-primary);
}

.drilldown-box--ribbon .drilldown-box__image {
    max-width: 100%;
    max-height: 48px;
    object-fit: contain;
}
.drilldown-box--ribbon .drilldown-box__label--below {
    font-size: var(--font-size-xs, 12px);
    font-weight: var(--font-weight-medium, 500);
    color: var(--color-text-muted, #888);
    margin-top: 2px;
}
.drilldown-box.drilldown-box--ribbon:has(.drilldown-box__image) {
    flex-direction: column;
    padding: var(--spacing-sm);
    gap: 4px;
}

.ribbon-brand-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 10px;
    background: var(--steel-100);
    color: var(--steel-600);
    font-size: var(--font-size-xs, 0.75rem);
    font-weight: var(--font-weight-semibold);
    margin-left: var(--spacing-xs);
}

/* Ribbon tile stagger — animation-delay set inline by JS */

/* Ribbon Model Pills (device model drill-down) */
.ribbon-model-pills {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    flex-wrap: wrap;
    margin-bottom: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--steel-50);
    border: 1px solid var(--steel-100);
    border-radius: var(--radius-md);
}

.ribbon-model-pills__label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--steel-500);
    white-space: nowrap;
    flex-shrink: 0;
}

.ribbon-model-pills__inner {
    display: flex;
    gap: var(--spacing-xs);
    flex-wrap: wrap;
}

.ribbon-model-btn {
    padding: 3px 12px;
    border-radius: 16px;
    border: 1.5px solid var(--steel-200);
    background: var(--white-primary);
    color: var(--steel-600);
    font-size: var(--font-size-xs, 0.75rem);
    font-weight: var(--font-weight-medium);
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s, color 0.15s;
    white-space: nowrap;
}

.ribbon-model-btn:hover {
    border-color: var(--cyan-primary);
    color: var(--cyan-primary);
}

.ribbon-model-btn--active {
    border-color: var(--cyan-primary);
    background: var(--cyan-light, #e0f2fe);
    color: var(--cyan-primary);
    font-weight: var(--font-weight-semibold);
}

/* Ribbon Model Section — shown BELOW product grid when a brand is selected */
.ribbon-model-section {
    margin-top: var(--spacing-lg);
}

.ribbon-model-section__heading {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--steel-700);
    margin-bottom: var(--spacing-md);
}

.ribbon-model-section__grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--spacing-sm);
}

.ribbon-model-section__grid .ribbon-model-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    white-space: normal;
    text-align: center;
}

@media (max-width: 768px) {
    .ribbon-model-section__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 480px) {
    .ribbon-model-section__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Ribbon Filter Bar */
.ribbon-filters {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    flex-wrap: wrap;
    margin-bottom: var(--spacing-md);
}

.ribbon-filters__colors {
    display: flex;
    gap: var(--spacing-xs);
    flex-wrap: wrap;
    flex: 1;
}

.ribbon-color-btn {
    padding: 5px 14px;
    border-radius: 20px;
    border: 1.5px solid var(--steel-200);
    background: var(--white-primary);
    color: var(--steel-700);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s, color 0.15s;
    white-space: nowrap;
}

.ribbon-color-btn:hover {
    border-color: var(--cyan-primary);
    color: var(--cyan-primary);
}

.ribbon-color-btn--active {
    border-color: var(--cyan-primary);
    background: var(--cyan-primary);
    color: var(--white-primary);
}

.ribbon-color-btn--active:hover {
    color: var(--white-primary);
}

.ribbon-sort-select {
    padding: 6px 32px 6px 12px;
    border-radius: var(--radius-md);
    border: 1.5px solid var(--steel-200);
    background: var(--white-primary);
    color: var(--steel-700);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    flex-shrink: 0;
}

@media (max-width: 480px) {
    .ribbon-filters {
        gap: var(--spacing-sm);
    }
    .ribbon-sort-select {
        width: 100%;
    }
}

/* Ribbon Products Grid (ribbons.html page) */
.ribbon-products-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: var(--spacing-md);
    padding: var(--spacing-xs) 0 var(--spacing-sm);
    align-items: start;
}

.ribbon-products-grid .product-card {
    flex: unset;
    max-width: none;
    min-width: 0;
}

@media (max-width: 1024px) {
    .ribbon-products-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (max-width: 768px) {
    .ribbon-products-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 480px) {
    .ribbon-products-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-sm);
    }
}

/* Ribbon section headings */
.ribbon-section-heading {
    font-size: var(--font-size-xl);
    font-weight: 600;
    margin: var(--spacing-lg) 0 var(--spacing-sm);
}

.ribbon-section-heading:first-of-type {
    margin-top: 0;
}

/* Ribbon products skeleton grid */
.drilldown-skeleton--products .ribbon-products-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: var(--spacing-md);
}

@media (max-width: 1024px) {
    .drilldown-skeleton--products .ribbon-products-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (max-width: 768px) {
    .drilldown-skeleton--products .ribbon-products-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 480px) {
    .drilldown-skeleton--products .ribbon-products-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Ribbons pagination centering */
.pagination__center {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-3);
    padding: var(--spacing-6) 0;
}

/* Breadcrumb Navigation */
/* Header with breadcrumb and product type */
.drilldown-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
}

.drilldown-header__left {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.drilldown-header__right {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    background: var(--cyan-light, #e6f4f9);
    border: 1px solid var(--cyan-primary, #267fb5);
    border-radius: var(--radius-md);
    padding: var(--spacing-xs) var(--spacing-md);
    font-size: var(--font-size-sm);
}

/* Wraps yield-banner + inline shipping pill so both live to the right of
   the breadcrumb and lift the H1 above the fold. Contract pinned by
   tests/shipping-bar-inline-may2026.test.js. */
.drilldown-header__right-group {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
    justify-content: flex-end;
    margin-left: auto;
}

.drilldown-header__right strong {
    color: var(--cyan-dark, #1a5a7a);
}

.drilldown-header__right span {
    color: var(--color-text);
    font-weight: var(--font-weight-medium);
}

.drilldown-header__product-type {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-heading);
    padding-left: var(--spacing-sm);
    border-left: 2px solid var(--color-border);
    margin-left: var(--spacing-sm);
}

.drilldown-breadcrumb {
    padding: var(--spacing-xs) 0;
}

.drilldown-breadcrumb__list {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    list-style: none;
    padding: 0;
    margin: 0;
}

.drilldown-breadcrumb__item {
    display: flex;
    align-items: center;
    font-family: var(--font-family-mono);
    font-size: var(--font-size-xs);
}

.drilldown-breadcrumb__item:not(:last-child)::after {
    content: '';
    display: inline-block;
    width: 6px;
    height: 6px;
    border-right: 2px solid var(--color-text-muted);
    border-bottom: 2px solid var(--color-text-muted);
    transform: rotate(-45deg);
    margin-left: var(--spacing-sm);
}

.drilldown-breadcrumb__link {
    display: inline-flex;
    align-items: center;
    padding: var(--spacing-xs) var(--spacing-sm);
    background: none;
    border: none;
    color: var(--cyan-primary);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: all var(--transition-fast);
}

.drilldown-breadcrumb__link:hover {
    background-color: var(--cyan-light);
    color: var(--cyan-dark);
}

.drilldown-breadcrumb__item--current span {
    color: var(--color-text-muted);
    font-weight: var(--font-weight-medium);
    padding: var(--spacing-xs) var(--spacing-sm);
}

/* Content Area */
.drilldown-content {
    min-height: 0;
}

.drilldown-level {
    animation: fadeIn 0.2s ease-out;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Grid Layouts */
.drilldown-grid {
    display: grid;
    gap: var(--spacing-3);
}

.drilldown-grid--brands {
    grid-template-columns: repeat(5, 1fr);
}

.drilldown-grid--categories {
    grid-template-columns: repeat(4, 1fr);
}

.drilldown-grid--codes {
    grid-template-columns: repeat(8, 1fr);
}

/* Drill-down Box (clickable cards) */
.drilldown-box {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-md);
    background: var(--white-primary);
    border: 1.5px solid var(--steel-200);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xs);
    cursor: pointer;
    transition: transform var(--transition-fast), box-shadow var(--transition-normal), border-color var(--transition-normal);
    min-height: 160px;
    position: relative;
    overflow: hidden;
}

.drilldown-box::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--cyan-primary);
    opacity: 0;
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    transition: opacity 0.25s ease;
}

.drilldown-box:hover {
    border-color: var(--cyan-primary);
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.drilldown-box:hover::after {
    opacity: 1;
}

.drilldown-box:focus {
    outline: none;
    border-color: var(--cyan-primary);
    box-shadow: 0 0 0 3px rgba(38, 127, 181, 0.15), 0 1px 3px rgba(0, 0, 0, 0.04);
}

.drilldown-box:active {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
}

/* Brand Box Specifics */
.drilldown-box--brand {
    min-height: 56px;
    padding: var(--spacing-sm) var(--spacing-lg);
}

.drilldown-box__logo {
    max-width: 100%;
    height: auto;
    object-fit: contain;
    transition: transform var(--transition-normal);
}

.drilldown-box:hover .drilldown-box__logo {
    transform: scale(1.04);
}

/* Brand-specific logo sizing — matched to mega nav dropdown */
.drilldown-box__logo--brother { height: 22px; }
.drilldown-box__logo--canon { height: 20px; }
.drilldown-box__logo--epson { height: 20px; }
.drilldown-box__logo--hp { height: 29px; }
.drilldown-box__logo--samsung { height: 19px; }
.drilldown-box__logo--lexmark { height: 24px; }
.drilldown-box__logo--oki { height: 24px; }
.drilldown-box__logo--fuji-xerox { height: 29px; }
.drilldown-box__logo--kyocera { height: 26px; }
.drilldown-box__logo--dymo { height: 28px; }

.drilldown-box__name {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-heading);
    text-align: center;
}

/* Category Box Specifics */
.drilldown-box--category {
    min-height: 180px;
}

.drilldown-box__icon {
    margin-bottom: var(--spacing-md);
    color: var(--cyan-primary);
}

.drilldown-box--category:hover .drilldown-box__icon {
    color: var(--cyan-dark);
}

/* Product Code Box Specifics */
.drilldown-box--code {
    min-height: 100px;
    padding: var(--spacing-sm) var(--spacing-xs);
}

.drilldown-box__code {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-heading);
    font-family: var(--font-mono, monospace);
    letter-spacing: 0.5px;
    word-break: break-all;
    line-height: 1.2;
}

.drilldown-box__name {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}

.drilldown-box__count {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin-top: var(--spacing-xs);
}

/* Ribbon Detail Two-Column Layout */
.ribbon-detail-columns {
    padding: var(--spacing-xl) 0;
}
.ribbon-detail-columns__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-3xl);
    align-items: start;
}
.ribbon-detail-columns__left .product-compat-devices {
    grid-column: auto;
    padding-top: 0;
    border-top: none;
}
.ribbon-detail-columns__right .ribbon-description {
    padding: 0 0 var(--spacing-lg);
    border-top: none;
}
.ribbon-detail-columns__right .related-products {
    padding: 0;
}
.ribbon-detail-columns__right .related-products__grid {
    grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 768px) {
    .ribbon-detail-columns__grid {
        grid-template-columns: 1fr;
    }
    .ribbon-detail-columns__right .related-products__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Ribbon Compatible Devices — spans both columns inside product layout grid */
.product-compat-devices {
    grid-column: 1 / -1;
    padding: var(--spacing-lg) 0 0;
    border-top: 1px solid var(--color-border);
}
.product-compat-devices__title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-text-heading);
    margin: 0 0 var(--spacing-sm);
}
.product-compat-devices__content {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--color-text);
}

/* Shared ribbon section heading style */
.ribbon-section__title,
.ribbon-description__title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-text-heading);
    margin: 0 0 var(--spacing-sm);
    text-transform: none;
    letter-spacing: normal;
}

/* Ribbon Description Section */
.ribbon-description {
    padding: var(--spacing-xl) 0;
    border-top: 1px solid var(--color-border);
}
.ribbon-description--inline {
    padding: 0.5rem 0 0;
    border-top: none;
}
.ribbon-description__content {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--color-text);
}
/* Override any inline font styles from pasted rich text */
.ribbon-description__content *,
.product-compat-devices__content * {
    font-family: inherit !important;
    font-size: inherit !important;
    color: inherit !important;
}

/* Product Info Banner (printers & yield) */
/* Compatible Printers Banner */
.product-printers-banner {
    background: var(--color-bg-light, #f8f9fa);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-sm) var(--spacing-md);
    margin-bottom: var(--spacing-md);
    line-height: 1.6;
    font-size: var(--font-size-sm);
}

.product-printers-banner strong {
    color: var(--color-text-heading);
    margin-right: var(--spacing-sm);
}

.product-printers-banner span {
    color: var(--color-text);
}

.printer-link {
    color: var(--color-primary);
    text-decoration: none;
    font-weight: var(--font-weight-medium);
}

.printer-link:hover {
    text-decoration: underline;
}


/* Products Section (Level 4) */
.products-section {
    margin-bottom: var(--spacing-lg);
}

.products-section__title {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-heading);
    margin: 0 0 var(--spacing-sm) 0;
    padding-bottom: var(--spacing-xs);
    border-bottom: 2px solid var(--color-border);
}

.products-section__badge {
    display: inline-block;
    padding: var(--spacing-2) var(--spacing-sm);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: var(--radius-sm);
}

.products-section__badge--genuine {
    background: var(--cyan-primary);
    color: var(--white-primary);
}

.products-section__badge--compatible {
    background: var(--yellow-primary);
    color: var(--black-primary);
}

/* Sub-code sections (grouped drums & supplies) */
.subcode-section {
    margin-bottom: 2rem;
}
.subcode-section__title {
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--border-color, #e5e7eb);
}

/* Product Grid (wrapping layout) */
.products-row {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    gap: var(--spacing-sm);
    padding: var(--spacing-xs) 0 var(--spacing-sm);
}

/*
 * Row-break for the (familyKey, yieldTier) grouping contract.
 * `flex-basis: 100%` + zero height forces the wrapping flex container
 * (.products-row, .product-grid) to start the next card on a fresh row,
 * so e.g. TN645 / TN645XL / TN645XXL each get their own row of K, C, M, Y,
 * CMY, KCMY cards. Margin reset prevents any inherited gap from showing.
 *
 * Spec: readfirst/code-yield-grouping-may2026.md
 * Pinned by tests/code-yield-grouping-may2026.test.js.
 */
.products-row__break {
    flex-basis: 100%;
    width: 100%;
    height: 0;
    margin: 0;
    padding: 0;
    border: 0;
    pointer-events: none;
}
.product-grid > .products-row__break {
    /* CSS Grid layouts ignore flex-basis — span every column instead. */
    grid-column: 1 / -1;
}

/* Product Card */
.product-card {
    position: relative;
    flex: 0 0 calc(14.285% - var(--spacing-sm));
    max-width: 185px;
    min-width: 140px;
    display: flex;
    flex-direction: column;
    background: var(--white-primary);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    transition: all var(--transition-fast);
}

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

/* Medium laptops: 7-card flex-basis would clamp to min-width:140px and overflow.
   Fall back to 6 cols below the comfortable 7-up threshold. */
@media (max-width: 1099px) {
    .product-card {
        flex: 0 0 calc(16.666% - var(--spacing-sm));
    }
}

/* Shop / search / brand / printer pages: trim outer gutters so 7 cards fit
   without shrinking each card too much. Scoped via body class on shop.html. */
body.page-shop {
    --container-max-width: 1240px;
    --container-padding: 24px;
}

.product-card__link {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
    flex-grow: 1;
}

.product-card__image-wrapper {
    /* 4:3 — see components.css comment. Saves ~44px per card on the shop
       grid (181px-wide cards) without cropping any cartridge image. */
    aspect-ratio: 4 / 3;
    background: var(--product-image-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    position: relative;
    padding: var(--spacing-xs);
}

.product-card__image-wrapper img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.product-card__image-wrapper svg {
    color: var(--color-text-muted);
}

/* Favourite button on product cards */
.product-card__fav-btn {
    position: absolute;
    top: var(--spacing-xs, 8px);
    right: var(--spacing-xs, 8px);
    z-index: 2;
    background: rgba(255, 255, 255, 0.9);
    border-radius: 50%;
    width: 28px;
    height: 28px;
    padding: 0;
    opacity: 1;
    transition: transform var(--transition-fast, 0.15s);
}

.product-card__fav-btn:hover {
    transform: scale(1.1);
    background: white;
}

.product-card__fav-btn svg {
    width: 14px;
    height: 14px;
}

.product-card__color-block {
    width: 100%;
    height: 100%;
    border-radius: var(--radius-sm);
}

.product-card__content {
    /* Balanced horizontal padding (was right:0 — looked off-centre).
       Vertical padding kept tight so the image sits right above content. */
    padding: 8px 10px 10px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex-grow: 1;
}

.product-card__footer {
    margin-top: auto;
}

.product-card__title {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
    margin: 0;
    line-height: 1.3;
    /* Clamp to 4 lines so long generic names ("Compatible Ink Cartridge
       Replacement for Epson …") show enough text to identify which
       cartridge the card represents. Reserves ~64px and keeps cards
       in the same row aligned. */
    min-height: calc(var(--font-size-xs) * 1.3 * 4);
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.product-card:hover .product-card__title {
    -webkit-line-clamp: unset;
    display: block;
}

.product-card__color {
    display: inline-block;
    font-size: 11px;
    color: var(--color-text-muted);
    margin: 0;
}

.product-card__pricing {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    margin: 0;
}

.product-card__price {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-heading);
}

.product-card__price-was {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    text-decoration: line-through;
}

.product-card__stock {
    font-size: 11px;
    font-weight: var(--font-weight-medium);
    margin: 0;
    margin-right: var(--spacing-sm);
}

.product-card__stock--in {
    color: var(--color-success);
}

.product-card__cart-btn {
    font-size: var(--font-size-xs);
    padding: 6px var(--spacing-sm);
}

/* Loading State */
.drilldown-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-3xl);
    text-align: center;
}

/* When showing skeletons, don't center - allow full width grid layout */
.drilldown-loading:has(.drilldown-skeleton:not([hidden])) {
    display: block;
    padding: var(--spacing-lg) 0;
    text-align: left;
}

.drilldown-loading p {
    color: var(--color-text-muted);
    margin-top: var(--spacing-md);
}

/* Empty State */
.drilldown-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-3xl);
    text-align: center;
    background: var(--white-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}

.drilldown-empty svg {
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-lg);
}

.drilldown-empty h3 {
    font-size: var(--font-size-xl);
    color: var(--color-text-heading);
    margin: 0 0 var(--spacing-sm) 0;
}

.drilldown-empty p {
    color: var(--color-text-muted);
    margin: 0;
}

/* Error State (shop-transient-failure-recovery-may2026.md)
   Separate pane from .drilldown-empty so a real failure (server cold-start,
   network blip) is visually distinct from "no products in this category" and
   carries a Retry CTA. Visually parented to .drilldown-empty so identical
   metrics carry over (same container chrome, same vertical rhythm). */
.drilldown-error {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-3xl);
    text-align: center;
    background: var(--white-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}

.drilldown-error svg {
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-lg);
}

.drilldown-error h3 {
    font-size: var(--font-size-xl);
    color: var(--color-text-heading);
    margin: 0 0 var(--spacing-sm) 0;
}

.drilldown-error p {
    color: var(--color-text-muted);
    margin: 0 0 var(--spacing-lg) 0;
    max-width: 36rem;
}

.drilldown-error__btn {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-xl);
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--white-primary);
    background: var(--color-primary, #0066cc);
    border: 0;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: background-color 120ms ease, transform 80ms ease;
}

.drilldown-error__btn:hover {
    background: var(--color-primary-dark, #004a99);
}

.drilldown-error__btn:active {
    transform: translateY(1px);
}

.drilldown-error__btn:focus-visible {
    outline: 2px solid var(--color-primary, #0066cc);
    outline-offset: 2px;
}

.drilldown-error__btn[disabled] {
    opacity: 0.6;
    cursor: progress;
}

/* Responsive - Drill-down Navigation */
@media (max-width: 1200px) {
    .drilldown-grid--brands {
        grid-template-columns: repeat(5, 1fr);
    }

    .drilldown-grid--categories {
        grid-template-columns: repeat(4, 1fr);
    }

}

@media (max-width: 1024px) {
    .drilldown-grid--brands {
        grid-template-columns: repeat(3, 1fr);
    }

    .drilldown-grid--ribbons {
        grid-template-columns: repeat(3, 1fr);
    }

    .drilldown-grid--categories {
        grid-template-columns: repeat(2, 1fr);
    }

    .shop-brands-panel {
        padding: var(--spacing-md);
    }

    .shop-section-card {
        padding: var(--spacing-md);
    }

    .drilldown-box--brand {
        min-height: 84px;
    }

    .drilldown-box--category {
        min-height: 150px;
    }
}

@media (max-width: 768px) {
    .drilldown-title {
        font-size: var(--font-size-xl);
        margin-bottom: var(--spacing-1);
    }

    /* When the breadcrumb wraps onto its own row, drop the inline pill to a
       full-width strip rather than leaving it stranded right-aligned on a
       half-empty row. The 480px rules go further (column stack); these
       cover the tablet middle ground. */
    .drilldown-header__right-group {
        width: 100%;
        margin-left: 0;
        justify-content: flex-start;
    }

    .shipping-info-bar--inline {
        flex: 1 1 auto;
        justify-content: center;
        white-space: normal;
    }

    .drilldown-grid--brands {
        grid-template-columns: repeat(2, 1fr);
    }

    .drilldown-grid--ribbons {
        grid-template-columns: repeat(2, 1fr);
    }

    .shop-brands-panel {
        padding: var(--spacing-md) var(--spacing-sm);
        border-radius: var(--radius-lg);
    }

    .shop-section-card {
        padding: var(--spacing-md) var(--spacing-sm);
        border-radius: var(--radius-lg);
    }

    .shop-section-card__header {
        gap: var(--spacing-2);
        margin-bottom: var(--spacing-4);
        padding-bottom: var(--spacing-3);
    }

    .shop-section-card__title {
        font-size: var(--font-size-base);
    }

    .drilldown-grid--categories {
        grid-template-columns: repeat(2, 1fr);
    }

    .drilldown-grid--codes {
        grid-template-columns: repeat(5, 1fr);
    }

    .drilldown-box {
        padding: var(--spacing-md);
        min-height: 120px;
    }

    .drilldown-box--brand {
        min-height: 80px;
        padding: var(--spacing-sm) var(--spacing-md);
    }

    .drilldown-box--category {
        min-height: 140px;
    }

    /* Brand logos keep same size as mega nav at all breakpoints */

    .drilldown-box__icon svg {
        width: 36px;
        height: 36px;
    }

    .product-card {
        flex: 0 0 calc(20% - var(--spacing-sm));
        min-width: 120px;
        max-width: 170px;
    }

    /* max-height intentionally not set — the 4:3 aspect-ratio on the
       image-wrapper handles vertical sizing automatically and stays
       proportional at any card width. */
}

@media (max-width: 480px) {
    .shop-page--drilldown {
        padding: var(--spacing-lg) 0 var(--spacing-2xl);
    }

    .drilldown-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-xs);
    }

    .drilldown-header__left {
        flex-direction: column;
        align-items: flex-start;
        width: 100%;
    }

    .drilldown-header__right {
        width: 100%;
        justify-content: center;
        margin-top: var(--spacing-xs);
    }

    .drilldown-header__right-group {
        width: 100%;
        margin-left: 0;
        flex-direction: column;
        align-items: stretch;
        gap: var(--spacing-xs);
    }

    .shipping-info-bar--inline {
        width: 100%;
        justify-content: center;
        white-space: normal;
        text-align: center;
    }

    .drilldown-header__product-type {
        font-size: var(--font-size-sm);
        border-left: none;
        padding-left: 0;
        margin-left: 0;
    }

    .drilldown-title {
        font-size: var(--font-size-lg);
    }

    .shop-brands-panel {
        padding: var(--spacing-sm);
        border-radius: var(--radius-md);
    }

    .drilldown-breadcrumb__link,
    .drilldown-breadcrumb__item--current span {
        font-size: var(--font-size-xs);
        padding: var(--spacing-2) var(--spacing-xs);
    }

    .product-printers-banner {
        padding: var(--spacing-sm) var(--spacing-md);
        font-size: var(--font-size-sm);
    }

    .drilldown-grid--brands,
    .drilldown-grid--ribbons,
    .drilldown-grid--categories {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-sm);
    }

    .drilldown-grid--codes {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--spacing-sm);
    }

    .drilldown-box {
        padding: var(--spacing-sm);
        min-height: 100px;
    }

    .drilldown-box--brand {
        min-height: 72px;
        padding: var(--spacing-sm);
    }

    .drilldown-box--category {
        min-height: 120px;
    }

    .drilldown-box--code {
        min-height: 70px;
        padding: var(--spacing-xs);
    }

    .drilldown-box__code {
        font-size: var(--font-size-sm);
    }

    .drilldown-box__code {
        font-size: var(--font-size-md);
    }

    .drilldown-box__name {
        font-size: var(--font-size-sm);
    }

    .products-section__title {
        font-size: var(--font-size-md);
        flex-wrap: wrap;
    }

    .product-card {
        /* 2 cards per row on phones. The row's gap is var(--spacing-sm)
           (8px); each card subtracts half the gap from its 50% width. */
        flex: 0 0 calc(50% - var(--spacing-sm) / 2);
        min-width: 0;
        max-width: none;
    }

    /* max-height intentionally not set — see 768px-rule note. The 4:3
       aspect ratio gives ~110px-tall images on ~145px-wide cards on phones,
       which keeps two cards comfortably side-by-side. */

    .product-card__content {
        padding: 8px;
    }

    .product-card__title {
        font-size: var(--font-size-xs);
    }

    .product-card__price {
        font-size: var(--font-size-sm);
    }

    .product-card__footer-row {
        flex-direction: column;
        align-items: flex-start;
    }
}


/* Drilldown section headings */
.drilldown-section-heading {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
    color: var(--steel-600);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: var(--spacing-3);
    padding: 0;
    border: none;
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
}

/* Section heading icon */
.drilldown-section-heading__icon {
    display: inline-flex;
    align-items: center;
    color: inherit;
}

.drilldown-section-heading--cartridges .drilldown-section-heading__icon {
    color: var(--cyan-primary);
}


/* Text-only brand boxes (for brands without logos) */
.drilldown-box__brand-text {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-heading);
    letter-spacing: 0.02em;
}




/* =============================================
   COLOR PACK BUNDLES
   ============================================= */
.color-packs-section {
    margin-bottom: var(--spacing-2xl);
    padding: var(--spacing-xl);
    background: linear-gradient(135deg, #f0f9ff 0%, #faf5ff 100%);
    border-radius: var(--radius-lg);
    border: 1px solid #e0e7ff;
}
.color-packs-section__title {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-heading);
    margin: 0 0 var(--spacing-xs);
}
.color-packs-section__subtitle {
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
    margin: 0 0 var(--spacing-lg);
}
.color-packs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--spacing-lg);
}
.color-pack-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    position: relative;
    transition: box-shadow 0.2s ease;
}
.color-pack-card:hover {
    box-shadow: var(--shadow-md);
}
.color-pack-card__badge {
    position: absolute;
    top: var(--spacing-sm);
    right: var(--spacing-sm);
    background: #16a34a;
    color: #fff;
    font-size: 11px;
    font-weight: var(--font-weight-bold);
    padding: 2px 8px;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.color-pack-card__source {
    font-size: 11px;
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--spacing-xs);
}
.color-pack-card__source--genuine { color: #1d4ed8; }
.color-pack-card__source--compatible { color: #7c3aed; }
.color-pack-card__name {
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-base);
    color: var(--color-text-heading);
    margin-bottom: var(--spacing-sm);
}
.color-pack-card__swatches {
    display: flex;
    gap: 6px;
    margin-bottom: var(--spacing-md);
}
.color-pack-card__swatch {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 2px solid #fff;
    box-shadow: 0 0 0 1px rgba(0,0,0,0.12);
}
.color-pack-card__items {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--spacing-md);
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
}
.color-pack-card__items li {
    padding: 2px 0;
}
.color-pack-card__pricing {
    display: flex;
    align-items: baseline;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}
.color-pack-card__pack-price {
    font-size: 1.25rem;
    font-weight: var(--font-weight-bold);
    color: var(--color-text-heading);
}
.color-pack-card__original-price {
    font-size: var(--font-size-sm);
    color: var(--color-text-tertiary);
    text-decoration: line-through;
}
.color-pack-card__add-btn {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-primary);
    color: #fff;
    border: none;
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-sm);
    cursor: pointer;
    transition: background 0.2s ease;
}
.color-pack-card__add-btn:hover {
    background: var(--color-primary-hover);
}
.color-pack-card__add-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

@media (max-width: 640px) {
    .color-packs-section {
        padding: var(--spacing-md);
    }
    .color-packs-grid {
        grid-template-columns: 1fr;
    }
}

/* Mobile: tighten the wrapping section-card so inner product grids
   (related-products, shop-products, drilldown codes) use the full viewport
   width instead of being crushed by the large desktop padding. Also lift
   the desktop max-width cap on .product-card so grid tracks fill the row. */
@media (max-width: 600px) {
    .shop-section-card {
        padding: var(--spacing-md) var(--spacing-sm);
        border-radius: var(--radius-lg);
    }

    .shop-section-card .shop-products__grid,
    .shop-section-card .related-products__grid,
    .shop-section-card .color-packs-grid,
    .shop-section-card .ribbon-products-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-sm);
    }

    /* The desktop product-card has max-width: 185px which leaves grid tracks
       half-empty on phones. Inside *grid* parents (shop-section-card,
       related-products), let the card stretch to fill its track. Do NOT
       apply this to flex-row parents like .products-row — that would
       collapse them to a single column on mobile. */
    .shop-section-card .product-card,
    .related-products__grid .product-card,
    .ribbon-products-grid .product-card,
    .product-grid .product-card {
        max-width: none;
        min-width: 0;
        width: 100%;
        flex: 1 1 auto;
    }

    .shop-section-card .color-pack-card {
        min-width: 0;
        padding: var(--spacing-sm);
    }
}


/* =============================================
   ADDRESS AUTOCOMPLETE DROPDOWN
   ============================================= */

.address-autocomplete__wrapper {
    position: relative;
}

.address-autocomplete__dropdown {
    position: absolute;
    top: calc(100% + 2px);
    left: 0;
    right: 0;
    z-index: 200;
    list-style: none;
    margin: 0;
    padding: 0.25rem 0;
    background: #fff;
    border: 1px solid #d1d5db;
    border-radius: 0.5rem;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    max-height: 220px;
    overflow-y: auto;
}

.address-autocomplete__option {
    padding: 0.6rem 0.875rem;
    font-size: 0.9rem;
    cursor: pointer;
    color: #1a1a1a;
    line-height: 1.4;
    border: none;
    background: none;
    width: 100%;
    text-align: left;
}

.address-autocomplete__option:hover,
.address-autocomplete__option--focused {
    background: #f0f7fc;
    color: #267FB5;
}

/* ============================================
   SEO / CRO: Product Page Enhancements
   ============================================ */

/* Trust strip */
.product-trust-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    font-size: var(--text-xs, 0.75rem);
    color: var(--color-success, #16a34a);
    padding: 10px 0;
    border-top: 1px solid var(--color-border, #e5e7eb);
    border-bottom: 1px solid var(--color-border, #e5e7eb);
    margin: 12px 0;
}
.product-trust-strip span {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Stock urgency */
.product-info__urgency {
    font-size: var(--text-sm, 0.875rem);
    color: var(--color-warning, #d97706);
    font-weight: 500;
    margin-top: 4px;
}

/* Compat preview */
.product-info__compat-preview {
    font-size: var(--text-sm, 0.875rem);
    color: var(--color-text-muted, #6b7280);
    margin-top: 6px;
    line-height: 1.5;
}
.product-info__compat-label {
    font-weight: 600;
    margin-right: 4px;
}
.product-info__compat-more {
    margin-left: 6px;
    color: var(--color-primary, #267FB5);
    text-decoration: underline;
}

/* Brand index page */
.brand-index-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 1.5rem;
    margin-top: 2rem;
}
.brand-index-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    padding: 1.5rem 1rem;
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: 8px;
    text-decoration: none;
    color: var(--color-text, #1a1a1a);
    font-weight: 600;
    font-size: 0.9rem;
    transition: border-color 0.2s, box-shadow 0.2s;
    background: #fff;
}
.brand-index-card:hover {
    border-color: var(--color-primary, #267FB5);
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.brand-index-card img {
    max-height: 48px;
    width: auto;
    object-fit: contain;
}

/* ============================================
   ORDER TRACKING — Timeline, Events, Recent Orders
   ============================================ */

/* Status badges (used on track & order detail pages) */
.order-status-badge {
    display: inline-block;
    padding: 0.2em 0.65em;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    white-space: nowrap;
}
.order-status-badge--paid,
.order-status-badge--processing {
    background: #e8f4fd;
    color: #1a6fa3;
}
.order-status-badge--shipped {
    background: #e6f6f0;
    color: #197a50;
}
.order-status-badge--completed {
    background: #d4edda;
    color: #155724;
}
.order-status-badge--cancelled {
    background: #fde8e8;
    color: #9b1c1c;
}
.order-status-badge--pending {
    background: #fef3cd;
    color: #856404;
}

/* Timeline stepper */
.order-timeline {
    display: flex;
    align-items: flex-start;
    gap: 0;
    margin: 1.5rem 0;
    overflow-x: auto;
    padding-bottom: 0.5rem;
}
.timeline-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
    min-width: 80px;
    position: relative;
    text-align: center;
}
.timeline-step + .timeline-step::before {
    content: '';
    position: absolute;
    top: 10px;
    right: 50%;
    width: 100%;
    height: 2px;
    background: #e0e0e0;
    z-index: 0;
}
.timeline-step--completed + .timeline-step--completed::before,
.timeline-step--completed + .timeline-step::before {
    background: var(--color-primary, #267FB5);
}
.timeline-step__dot {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: 2px solid #d0d0d0;
    background: #fff;
    z-index: 1;
    flex-shrink: 0;
}
.timeline-step--completed .timeline-step__dot {
    background: var(--color-primary, #267FB5);
    border-color: var(--color-primary, #267FB5);
}
.timeline-step--cancelled .timeline-step__dot {
    background: #dc3545;
    border-color: #dc3545;
}
.timeline-step--cancelled + .timeline-step--cancelled::before,
.timeline-step--cancelled + .timeline-step::before {
    background: #dc3545;
}
.timeline-step__label {
    font-size: 0.72rem;
    color: #888;
    margin-top: 0.35rem;
    line-height: 1.3;
}
.timeline-step--completed .timeline-step__label {
    color: var(--color-text, #222);
    font-weight: 500;
}
.timeline-step--cancelled .timeline-step__label {
    color: #dc3545;
    font-weight: 500;
}
.timeline-step__date {
    font-size: 0.68rem;
    color: #aaa;
    margin-top: 0.15rem;
}

/* Tracking detail card */
.tracking-detail {
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    padding: 1.5rem;
}
.tracking-detail--error {
    border-color: #fde8e8;
    background: #fffafa;
    color: #9b1c1c;
}
.tracking-detail__header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}
.tracking-detail__order-number {
    font-weight: 700;
    font-size: 1rem;
    color: var(--color-text, #222);
}

/* Tracking info rows */
.tracking-info {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    padding: 1rem 0;
    border-top: 1px solid #f0f0f0;
    border-bottom: 1px solid #f0f0f0;
    margin-bottom: 1rem;
}
.tracking-info-row {
    display: flex;
    gap: 1rem;
    font-size: 0.88rem;
}
.tracking-info-label {
    color: #888;
    min-width: 120px;
    flex-shrink: 0;
}
.tracking-info-value {
    color: var(--color-text, #222);
    font-weight: 500;
}

/* Live tracking events */
.tracking-events {
    margin-top: 1rem;
}
.tracking-events__heading {
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #888;
    margin-bottom: 0.75rem;
}
.tracking-event {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
    margin-bottom: 0.75rem;
    position: relative;
}
.tracking-event + .tracking-event {
    padding-top: 0.75rem;
    border-top: 1px solid #f5f5f5;
}
.tracking-event__dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--color-primary, #267FB5);
    flex-shrink: 0;
    margin-top: 0.25rem;
}
.tracking-event__body {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}
.tracking-event__label {
    font-size: 0.88rem;
    color: var(--color-text, #222);
}
.tracking-event__date {
    font-size: 0.78rem;
    color: #aaa;
}

/* Fallback link */
.tracking-fallback {
    margin-top: 1rem;
    font-size: 0.88rem;
    color: #666;
}
.tracking-fallback a {
    color: var(--color-primary, #267FB5);
    font-weight: 500;
}

/* Recent orders list */
.recent-orders-list {
    margin-top: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    overflow: hidden;
}
.recent-order-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.85rem 1rem;
    background: #fff;
    gap: 1rem;
    flex-wrap: wrap;
}
.recent-order-row + .recent-order-row {
    border-top: 1px solid #f0f0f0;
}
.recent-order-row:hover {
    background: #fafafa;
}
.recent-order-row__main {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex-wrap: wrap;
}
.recent-order-row__number {
    background: none;
    border: none;
    padding: 0;
    font-weight: 600;
    font-size: 0.88rem;
    color: var(--color-primary, #267FB5);
    cursor: pointer;
    text-decoration: underline;
    font-family: inherit;
}
.recent-order-row__number:hover {
    color: var(--color-primary-dark, #1a5c85);
}
.recent-order-row__date {
    font-size: 0.78rem;
    color: #aaa;
}
.recent-order-row__actions {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}
.recent-order-row__total {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--color-text, #222);
}
.btn--sm {
    padding: 0.3rem 0.75rem;
    font-size: 0.8rem;
}

/* Timeline used in order-detail-page */
.order-detail-timeline {
    margin-bottom: 1.5rem;
}

/* =========================================================================
   Loyalty / Stamp Card
   ========================================================================= */
.loyalty-loading {
    padding: var(--spacing-6) 0;
    color: var(--steel-500, #64748b);
}

.loyalty-info-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.5rem 0.9rem;
    background: transparent;
    border: 1px solid var(--steel-200, #e2e8f0);
    border-radius: var(--radius-md, 8px);
    color: var(--steel-600, #475569);
    font-size: 0.875rem;
    cursor: pointer;
    transition: all var(--transition-fast, 0.15s ease);
}
.loyalty-info-btn:hover {
    border-color: var(--color-primary, #2563eb);
    color: var(--color-primary, #2563eb);
}

.loyalty-card {
    background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
    border: 1px solid var(--steel-200, #e2e8f0);
    border-radius: var(--radius-lg, 12px);
    padding: clamp(1.25rem, 3vw, 2rem);
    box-shadow: var(--shadow-sm, 0 1px 2px rgba(0,0,0,0.05));
    margin-bottom: var(--spacing-6, 1.5rem);
}
.loyalty-card__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}
.loyalty-card__title {
    font-size: clamp(1.125rem, 2vw, 1.375rem);
    margin: 0 0 0.25rem;
    color: var(--steel-900, #0f172a);
}
.loyalty-card__meta {
    margin: 0;
    font-size: 0.875rem;
    color: var(--steel-500, #64748b);
}
.loyalty-card__progress {
    display: flex;
    align-items: baseline;
    gap: 0.35rem;
    color: var(--color-primary, #2563eb);
}
.loyalty-progress__num {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
}
.loyalty-progress__den {
    font-size: 0.875rem;
    color: var(--steel-500, #64748b);
    font-weight: 500;
}

.loyalty-stamps {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 0.5rem;
}
.loyalty-stamp {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
    position: relative;
}
.loyalty-stamp__circle {
    width: clamp(44px, 11vw, 72px);
    height: clamp(44px, 11vw, 72px);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px dashed var(--steel-300, #cbd5e1);
    background: #fff;
    color: var(--steel-400, #94a3b8);
    transition: all 0.25s ease;
}
.loyalty-stamp__circle svg {
    width: 52%;
    height: 52%;
}
.loyalty-stamp__num {
    font-weight: 600;
    font-size: 0.9rem;
}
.loyalty-stamp--filled .loyalty-stamp__circle {
    background: var(--color-primary, #2563eb);
    border: 2px solid var(--color-primary, #2563eb);
    color: #fff;
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.25);
}
.loyalty-stamp--reward .loyalty-stamp__circle {
    border-style: solid;
    border-width: 3px;
}
.loyalty-stamp--silver .loyalty-stamp__circle {
    border-color: #94a3b8;
}
.loyalty-stamp--gold .loyalty-stamp__circle {
    border-color: #d4a017;
}
.loyalty-stamp--reward-unlocked.loyalty-stamp--silver .loyalty-stamp__circle {
    background: linear-gradient(135deg, #cbd5e1, #94a3b8);
    color: #fff;
    box-shadow: 0 6px 16px rgba(148, 163, 184, 0.45);
    animation: loyalty-pulse 2.4s ease-in-out infinite;
}
.loyalty-stamp--reward-unlocked.loyalty-stamp--gold .loyalty-stamp__circle {
    background: linear-gradient(135deg, #fde68a, #d4a017);
    color: #fff;
    box-shadow: 0 6px 20px rgba(212, 160, 23, 0.5);
    animation: loyalty-pulse 2.4s ease-in-out infinite;
}
.loyalty-stamp--reward-used .loyalty-stamp__circle,
.loyalty-stamp--reward-expired .loyalty-stamp__circle {
    background: var(--steel-100, #f1f5f9);
    color: var(--steel-400, #94a3b8);
    opacity: 0.7;
}
@keyframes loyalty-pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.04); }
}

.loyalty-stamp__tier {
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--steel-600, #475569);
}
.loyalty-stamp--gold .loyalty-stamp__tier { color: #b8860b; }
.loyalty-stamp--silver .loyalty-stamp__tier { color: #64748b; }
.loyalty-stamp__tier--locked { opacity: 0.5; }

.loyalty-card__next {
    margin: 1.5rem 0 0;
    text-align: center;
    font-size: 0.9rem;
    color: var(--steel-600, #475569);
}

.loyalty-rewards {
    margin-top: var(--spacing-6, 1.5rem);
}
.loyalty-rewards__heading {
    font-size: 1.125rem;
    margin: 0 0 1rem;
    color: var(--steel-900, #0f172a);
}
.loyalty-rewards__list {
    display: grid;
    gap: 1rem;
}
.loyalty-reward {
    background: #fff;
    border: 1px solid var(--steel-200, #e2e8f0);
    border-radius: var(--radius-lg, 12px);
    padding: 1.25rem;
    position: relative;
    overflow: hidden;
}
.loyalty-reward::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
}
.loyalty-reward--silver::before { background: linear-gradient(180deg, #cbd5e1, #94a3b8); }
.loyalty-reward--gold::before { background: linear-gradient(180deg, #fde68a, #d4a017); }
.loyalty-reward--personal::before { background: linear-gradient(180deg, #60a5fa, #2563eb); }
.loyalty-reward--personal .loyalty-reward__tier { color: #1d4ed8; }
.loyalty-reward--used,
.loyalty-reward--expired,
.loyalty-reward--deactivated { opacity: 0.7; }

.loyalty-reward__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
    flex-wrap: wrap;
}
.loyalty-reward__tier {
    font-weight: 700;
    font-size: 0.95rem;
    margin-right: 0.6rem;
}
.loyalty-reward--gold .loyalty-reward__tier { color: #b8860b; }
.loyalty-reward--silver .loyalty-reward__tier { color: #475569; }
.loyalty-reward__cycle {
    font-size: 0.75rem;
    color: var(--steel-500, #64748b);
}
.loyalty-reward__status {
    padding: 0.25rem 0.65rem;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.loyalty-reward__status--active { background: #dcfce7; color: #166534; }
.loyalty-reward__status--used { background: var(--steel-100, #f1f5f9); color: var(--steel-500, #64748b); }
.loyalty-reward__status--expired { background: #fee2e2; color: #991b1b; }
.loyalty-reward__status--deactivated { background: var(--steel-100, #f1f5f9); color: var(--steel-500, #64748b); }
.loyalty-reward__status--personal { background: #dbeafe; color: #1d4ed8; }

.loyalty-reward__code-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
    flex-wrap: wrap;
}
.loyalty-reward__code {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    padding: 0.5rem 0.9rem;
    background: var(--steel-50, #f8fafc);
    border: 1px dashed var(--steel-300, #cbd5e1);
    border-radius: var(--radius-md, 8px);
    color: var(--steel-900, #0f172a);
}
.loyalty-reward__copy {
    padding: 0.45rem 0.9rem;
    font-size: 0.85rem;
}
.loyalty-reward__discount {
    margin: 0 0 0.6rem;
    font-weight: 600;
    color: var(--steel-800, #1e293b);
}
.loyalty-reward__conditions {
    list-style: disc;
    margin: 0;
    padding-left: 1.1rem;
    color: var(--steel-500, #64748b);
    font-size: 0.8125rem;
    display: grid;
    gap: 0.2rem;
}

.loyalty-toast {
    position: fixed;
    bottom: 1.5rem;
    left: 50%;
    transform: translateX(-50%);
    background: var(--steel-900, #0f172a);
    color: #fff;
    padding: 0.7rem 1.2rem;
    border-radius: 999px;
    font-size: 0.875rem;
    box-shadow: 0 10px 30px rgba(0,0,0,0.2);
    z-index: 1000;
}

@media (max-width: 520px) {
    .loyalty-stamps { gap: 0.35rem; }
    .loyalty-stamp__tier { font-size: 0.6rem; }
    .loyalty-card__progress { width: 100%; justify-content: flex-start; }
}

/* ── GMC Compliance: Shipping callouts ── */

.shipping-info-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    margin: 12px 0 20px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: var(--radius-md, 6px);
    font-size: var(--text-sm, 0.875rem);
    color: #166534;
}

.shipping-info-bar svg {
    flex-shrink: 0;
    color: #16a34a;
}

.shipping-info-bar a {
    color: #166534;
    font-weight: 600;
    text-decoration: underline;
}

/* Inline variant: lives inside .drilldown-header__right-group on /shop,
   sits to the right of the breadcrumb so the H1 lifts up. Compact padding
   matches the breadcrumb height; margin is removed because the parent
   .drilldown-header already owns vertical rhythm. */
.shipping-info-bar--inline {
    margin: 0;
    padding: 6px 12px;
    font-size: var(--font-size-xs, 0.8125rem);
    line-height: 1.2;
    white-space: nowrap;
}

.shipping-info-bar--inline svg {
    width: 14px;
    height: 14px;
}

.product-shipping-note {
    margin: 6px 0 4px;
}

.shipping-note {
    display: inline-block;
    font-size: var(--text-sm, 0.875rem);
    color: var(--color-text-muted, #6b7280);
}

.shipping-note a {
    color: inherit;
    text-decoration: underline;
}

.shipping-note--free {
    color: var(--color-success, #16a34a);
    font-weight: 600;
}

/* ── GMC Compliance: Returns summary box ── */

.returns-summary-box {
    margin: 20px 0;
    padding: 18px 20px;
    background: #f8fafc;
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-md, 6px);
}

.returns-summary-box h3 {
    margin: 0 0 12px;
    font-size: var(--text-base, 1rem);
    font-weight: 700;
    color: var(--color-text, #111827);
}

.returns-summary-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm, 0.875rem);
}

.returns-summary-table td {
    padding: 7px 10px;
    border-bottom: 1px solid var(--color-border, #e5e7eb);
    vertical-align: top;
}

.returns-summary-table tr:last-child td {
    border-bottom: none;
}

.returns-summary-table td:first-child {
    font-weight: 600;
    color: var(--color-text, #111827);
    width: 50%;
}

.returns-summary-table td:last-child {
    color: var(--color-text-muted, #6b7280);
}

/* ── Legal table (shipping rates) ── */

.legal-table-wrap {
    overflow-x: auto;
    margin: 12px 0;
}

.legal-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm, 0.875rem);
    min-width: 500px;
}

.legal-table th,
.legal-table td {
    padding: 9px 12px;
    border: 1px solid var(--color-border, #e5e7eb);
    text-align: left;
    vertical-align: top;
}

.legal-table th {
    background: #f1f5f9;
    font-weight: 700;
    color: var(--color-text, #111827);
}

.legal-table tbody tr:nth-child(even) {
    background: #f8fafc;
}

/* ─────────────────────────────────────────────────────────────────────────
   Contact page (/contact) — landing target for the May 2026 OOS
   "Contact us" CTA. Two-column layout: direct-channel card + form card.
   See contact-button-may2026.md.
   ───────────────────────────────────────────────────────────────────────── */

.contact-page {
    padding: var(--spacing-8, 32px) 0 var(--spacing-12, 56px);
}

.contact-page__header {
    max-width: 640px;
    margin: 0 auto var(--spacing-8, 32px);
    text-align: center;
}

.contact-page__title {
    margin: 0 0 8px;
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: 800;
    color: var(--color-text, #111827);
    letter-spacing: -0.01em;
}

.contact-page__lead {
    margin: 0;
    font-size: var(--font-size-md, 1rem);
    color: var(--color-text-muted, #6b7280);
    line-height: 1.55;
}

.contact-page__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
    gap: var(--spacing-6, 24px);
    align-items: start;
}

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

.contact-card,
.contact-form-card {
    background: var(--white-primary, #fff);
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-lg, 12px);
    padding: var(--spacing-6, 24px);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.contact-card__title,
.contact-form-card__title {
    margin: 0 0 var(--spacing-4, 16px);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--color-text, #111827);
}

.contact-card__list {
    list-style: none;
    margin: 0 0 var(--spacing-5, 20px);
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4, 16px);
}

.contact-card__item {
    display: grid;
    grid-template-columns: 36px 1fr;
    gap: 12px;
    align-items: start;
}

.contact-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--cyan-50, #ecfeff);
    color: var(--cyan-primary, #0891b2);
    flex-shrink: 0;
}

.contact-card__label {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-text-muted, #6b7280);
    font-weight: 600;
}

.contact-card__value {
    display: block;
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-text, #111827);
    text-decoration: none;
    margin-top: 2px;
}

.contact-card__value[href]:hover {
    text-decoration: underline;
}

.contact-card__value--address {
    font-style: normal;
    font-weight: 500;
    line-height: 1.45;
}

.contact-card__hint {
    margin-top: 2px;
    font-size: 0.82rem;
    color: var(--color-text-muted, #6b7280);
}

.contact-card__footnote {
    margin: 0;
    padding: var(--spacing-3, 12px) var(--spacing-4, 16px);
    background: var(--cyan-50, #ecfeff);
    border-radius: var(--radius-md, 8px);
    color: var(--color-text, #111827);
    font-size: 0.88rem;
    line-height: 1.5;
}

.contact-form-card__lead {
    margin: 0 0 var(--spacing-5, 20px);
    color: var(--color-text-muted, #6b7280);
    font-size: 0.95rem;
    line-height: 1.5;
}

.contact-form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4, 16px);
}

.contact-form__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-4, 16px);
}

@media (max-width: 540px) {
    .contact-form__row {
        grid-template-columns: 1fr;
    }
}

.contact-form__field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.contact-form__label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-text, #111827);
}

.contact-form__optional {
    font-weight: 400;
    color: var(--color-text-muted, #6b7280);
    font-size: 0.78rem;
    margin-left: 4px;
}

.contact-form .form-input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-border, #d1d5db);
    border-radius: var(--radius-md, 8px);
    font-size: 0.95rem;
    font-family: inherit;
    color: var(--color-text, #111827);
    background: #fff;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.contact-form .form-input:focus {
    outline: none;
    border-color: var(--cyan-primary, #0891b2);
    box-shadow: 0 0 0 3px rgba(8, 145, 178, 0.18);
}

.contact-form .form-input[aria-invalid="true"] {
    border-color: var(--color-error, #ef4444);
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.15);
}

.contact-form textarea.form-input {
    resize: vertical;
    min-height: 140px;
}

.contact-form__turnstile {
    min-height: 65px;
}

.contact-form__actions {
    display: flex;
    justify-content: flex-end;
}

.contact-form__actions .btn {
    min-width: 180px;
}

.contact-form__result {
    margin: 0;
    padding: 12px 14px;
    border-radius: var(--radius-md, 8px);
    font-size: 0.9rem;
    line-height: 1.5;
}

.contact-form__result--success {
    background: #ecfdf5;
    color: #065f46;
    border: 1px solid #6ee7b7;
}

.contact-form__result--error {
    background: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
}

/* ===========================================================================
   LEGAL / POLICY / INFO PAGES (May 2026)
   ---------------------------------------------------------------------------
   Styles shared by /terms, /privacy, /returns, /shipping, /about, /faq.
   Mobile-first: stacked layout, single column. Desktop: 280px sticky TOC
   on the left, fluid prose on the right.
   =========================================================================== */

.legal-page {
    padding: clamp(20px, 4vw, 40px) 0 80px;
}

.legal-page__layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
}

@media (min-width: 960px) {
    .legal-page__layout {
        grid-template-columns: 260px minmax(0, 1fr);
        gap: 56px;
        align-items: start;
    }
}

.legal-page__hero {
    margin-bottom: 28px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--color-border, #e5e7eb);
}

.legal-page__title {
    font-size: clamp(1.6rem, 4vw, 2.4rem);
    font-weight: 700;
    color: var(--color-text, #111827);
    margin: 0 0 10px;
    letter-spacing: -0.02em;
}

.legal-page__lead {
    color: var(--color-text-muted, #4b5563);
    font-size: 1.05rem;
    line-height: 1.6;
    max-width: 70ch;
    margin: 0 0 14px;
}

.legal-page__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 18px;
    font-size: 0.85rem;
    color: var(--color-text-muted, #6b7280);
}

.legal-page__meta strong {
    color: var(--color-text, #111827);
    font-weight: 600;
    margin-right: 4px;
}

/* Table of contents — sticky on desktop, inline on mobile */
.legal-toc {
    display: block;
}

@media (min-width: 960px) {
    .legal-toc {
        position: sticky;
        top: 24px;
        align-self: start;
        max-height: calc(100vh - 48px);
        overflow-y: auto;
    }
}

.legal-toc__nav {
    background: var(--color-surface-alt, #f9fafb);
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-lg, 12px);
    padding: 18px 20px;
}

.legal-toc__heading {
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-muted, #6b7280);
    margin: 0 0 10px;
}

.legal-toc__list {
    list-style: none;
    padding: 0;
    margin: 0;
    counter-reset: legal-toc;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.legal-toc__list li {
    counter-increment: legal-toc;
}

.legal-toc__list a {
    display: block;
    padding: 6px 8px 6px 28px;
    border-radius: var(--radius-sm, 6px);
    text-decoration: none;
    color: var(--color-text, #111827);
    font-size: 0.92rem;
    line-height: 1.4;
    position: relative;
    transition: background 0.12s ease, color 0.12s ease;
}

.legal-toc__list a::before {
    content: counter(legal-toc) ".";
    position: absolute;
    left: 8px;
    top: 6px;
    color: var(--color-text-muted, #9ca3af);
    font-variant-numeric: tabular-nums;
    font-size: 0.85rem;
}

.legal-toc__list a:hover,
.legal-toc__list a:focus-visible {
    background: var(--cyan-50, #ecfeff);
    color: var(--cyan-primary, #0891b2);
    outline: none;
}

/* Policy sections — the prose body */
.legal-page__body {
    min-width: 0;
}

.policy-section {
    padding: 4px 0 18px;
    scroll-margin-top: 24px;
}

.policy-section + .policy-section {
    border-top: 1px solid var(--color-border, #e5e7eb);
    margin-top: 28px;
    padding-top: 28px;
}

.policy-section h2 {
    font-size: clamp(1.2rem, 2.4vw, 1.5rem);
    font-weight: 700;
    color: var(--color-text, #111827);
    margin: 0 0 14px;
    letter-spacing: -0.01em;
    outline: none;
}

.policy-section h3 {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--color-text, #111827);
    margin: 22px 0 8px;
}

.policy-section p,
.policy-section li {
    color: var(--color-text, #111827);
    font-size: 0.98rem;
    line-height: 1.65;
    max-width: 70ch;
}

.policy-section p {
    margin: 0 0 14px;
}

.policy-section ul,
.policy-section ol {
    margin: 0 0 14px;
    padding-left: 22px;
}

.policy-section ul li,
.policy-section ol li {
    margin-bottom: 6px;
}

.policy-section a {
    color: var(--cyan-primary, #0891b2);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.policy-section a:hover { text-decoration-thickness: 2px; }

/* Callout box for emphasised legal/compliance points */
.policy-callout {
    border-left: 3px solid var(--cyan-primary, #0891b2);
    background: var(--cyan-50, #ecfeff);
    padding: 14px 16px;
    border-radius: 0 var(--radius-md, 8px) var(--radius-md, 8px) 0;
    margin: 16px 0 20px;
}

.policy-callout--warn {
    border-left-color: #d97706;
    background: #fffbeb;
}

.policy-callout--ok {
    border-left-color: #059669;
    background: #ecfdf5;
}

.policy-callout__title {
    font-weight: 700;
    margin: 0 0 6px;
    font-size: 0.95rem;
    color: var(--color-text, #111827);
}

.policy-callout p:last-child { margin-bottom: 0; }

/* Tables (data processors, cookies, shipping zones) */
.policy-table-wrap {
    overflow-x: auto;
    margin: 0 0 18px;
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-md, 8px);
}

.policy-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.92rem;
    min-width: 520px;
}

.policy-table thead th {
    text-align: left;
    font-weight: 600;
    background: var(--color-surface-alt, #f9fafb);
    color: var(--color-text, #111827);
    padding: 10px 14px;
    border-bottom: 1px solid var(--color-border, #e5e7eb);
    font-size: 0.85rem;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.policy-table tbody th,
.policy-table tbody td {
    padding: 10px 14px;
    border-bottom: 1px solid var(--color-border-soft, #f3f4f6);
    vertical-align: top;
    color: var(--color-text, #111827);
}

.policy-table tbody th {
    text-align: left;
    font-weight: 600;
    white-space: nowrap;
}

.policy-table tbody tr:last-child th,
.policy-table tbody tr:last-child td { border-bottom: 0; }

/* FAQ — uses native <details>/<summary> */
.faq-list { display: flex; flex-direction: column; gap: 10px; }

.faq-item {
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-md, 8px);
    background: #fff;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.faq-item[open] {
    border-color: var(--cyan-primary, #0891b2);
    box-shadow: 0 1px 4px rgba(8, 145, 178, 0.08);
}

.faq-item > summary {
    list-style: none;
    cursor: pointer;
    padding: 14px 18px;
    font-weight: 600;
    color: var(--color-text, #111827);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    font-size: 1rem;
    line-height: 1.4;
}

.faq-item > summary::-webkit-details-marker { display: none; }

.faq-item > summary::after {
    content: '+';
    font-size: 1.4rem;
    line-height: 1;
    color: var(--cyan-primary, #0891b2);
    transition: transform 0.18s ease;
    flex-shrink: 0;
}

.faq-item[open] > summary::after {
    content: '−';
}

.faq-item__body {
    padding: 0 18px 16px;
    color: var(--color-text, #111827);
    font-size: 0.95rem;
    line-height: 1.65;
}

.faq-item__body p { margin: 0 0 10px; }
.faq-item__body p:last-child { margin-bottom: 0; }

/* About page — value cards + brand story */
.about-hero {
    background: linear-gradient(135deg, var(--cyan-50, #ecfeff) 0%, #ffffff 100%);
    padding: clamp(28px, 5vw, 48px);
    border-radius: var(--radius-lg, 12px);
    margin-bottom: 32px;
}

.about-values {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 18px;
    margin: 24px 0 32px;
}

.about-value {
    background: #fff;
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-md, 8px);
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.about-value__icon {
    width: 36px;
    height: 36px;
    color: var(--cyan-primary, #0891b2);
}

.about-value__title {
    font-size: 1rem;
    font-weight: 700;
    margin: 0;
    color: var(--color-text, #111827);
}

.about-value__body {
    font-size: 0.92rem;
    color: var(--color-text-muted, #4b5563);
    line-height: 1.55;
    margin: 0;
}

/* Map embed (contact + about location) */
.legal-map {
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-md, 8px);
    overflow: hidden;
    margin: 16px 0 8px;
    background: #f3f4f6;
}

.legal-map__frame {
    width: 100%;
    height: 320px;
    border: 0;
    display: block;
}

.legal-map__link {
    display: block;
    text-align: right;
    padding: 8px 12px;
    font-size: 0.85rem;
    color: var(--cyan-primary, #0891b2);
    text-decoration: none;
    background: var(--color-surface-alt, #f9fafb);
    border-top: 1px solid var(--color-border, #e5e7eb);
}

.legal-map__link:hover { text-decoration: underline; }

/* Footer policy nav block — added by footer.js */
.footer-legal-nav {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding: 14px 0;
    margin-top: 8px;
}

.footer-legal-nav ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 6px 18px;
    justify-content: center;
    font-size: 0.85rem;
}

.footer-legal-nav a {
    color: rgba(255, 255, 255, 0.78);
    text-decoration: none;
    transition: color 0.15s ease;
}

.footer-legal-nav a:hover,
.footer-legal-nav a:focus-visible {
    color: #fff;
    text-decoration: underline;
}

.footer-legal-nav__sep {
    color: rgba(255, 255, 255, 0.3);
    user-select: none;
}

