/* ==========================================================================
   Salty Hair — Site Stylesheet
   Single-pass design system. All colour comes from brand tokens.
   Sections:
     1.  Tokens
     2.  Reset & base
     3.  Typography
     4.  Layout helpers
     5.  Buttons / forms / chips / badges
     6.  Announcement bar
     7.  Site header (nav, mega menu, drawers)
     8.  Hero
     9.  Category tile grid
     10. Bestsellers toolbar & filter chips
     11. Filter drawer (mobile)
     12. Product grid & card
     13. Quick add
     14. Editorial moment
     15. Secondary product strip
     16. Trust strip
     17. Newsletter
     18. Footer
     19. Cart page
     20. Checkout page
     21. Product detail page
     22. Collections page
     23. Policy / account / bookings
     24. Toast
     25. Responsive breakpoints
   ========================================================================== */

/* ---------------------------------------------------------------- 1. Tokens */
:root {
    /* Brand palette */
    --color-background: #FAF7F4;
    --color-background-secondary: #EFEAE6;
    --color-surface: #FFFFFF;
    --color-surface-warm: #F6F0EC;

    --color-text-primary: #2F2A28;
    --color-text-secondary: #6F625D;
    --color-text-muted: #9A8C86;
    --color-text-on-dark: #FAF7F4;
    --color-text-on-dark-muted: #D8CDC8;

    --color-border: #E3DAD5;
    --color-border-strong: #CDBFBA;

    --color-accent: #F7D9D7;
    --color-accent-soft: #FBEDEC;
    --color-accent-hover: #DCA7A3;
    --color-accent-deep: #A66E69;

    --color-primary-button: #4A3D39;
    --color-primary-button-hover: #352C29;
    --color-primary-button-text: #FFFFFF;

    --color-secondary-button: #F7D9D7;
    --color-secondary-button-hover: #EEC4C1;
    --color-secondary-button-text: #4A3D39;

    --color-highlight-neutral: #E8D8C8;

    --color-success: #7D8A75;
    --color-warning: #B98A4A;
    --color-error: #A85F56;

    /* Type */
    --font-serif: "Cormorant Garamond", "Playfair Display", Georgia, "Times New Roman", serif;
    --font-sans: "Inter", "Helvetica Neue", Arial, system-ui, -apple-system, sans-serif;

    /* Layout */
    --container-max: 1360px;
    --container-pad: clamp(20px, 4vw, 48px);
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 16px;

    /* Elevation */
    --shadow-card: 0 1px 2px rgba(47, 42, 40, 0.04);
    --shadow-card-hover: 0 8px 24px rgba(47, 42, 40, 0.08);
    --shadow-drawer: 0 20px 40px rgba(47, 42, 40, 0.16);

    /* Motion */
    --easing: cubic-bezier(0.22, 0.61, 0.36, 1);
    --transition-fast: 140ms var(--easing);
    --transition-base: 220ms var(--easing);
    --transition-slow: 380ms var(--easing);

    /* Component sizing */
    --header-height: 88px;
    --announcement-height: 36px;
}

/* ---------------------------------------------------------- 2. Reset & base */
*,
*::before,
*::after {
    box-sizing: border-box;
}

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

body {
    margin: 0;
    background: var(--color-background);
    color: var(--color-text-primary);
    font-family: var(--font-sans);
    font-size: 16px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: clip;
}

body.is-modal-open {
    overflow: hidden;
}

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

figure { margin: 0; }

button {
    font: inherit;
    color: inherit;
    cursor: pointer;
    border: none;
    background: transparent;
}

a {
    color: var(--color-text-primary);
    text-decoration: none;
    transition: color var(--transition-fast);
}

a:hover,
a:focus-visible {
    color: var(--color-accent-deep);
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: 2px solid var(--color-accent-hover);
    outline-offset: 3px;
    border-radius: 2px;
}

hr {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: 32px 0;
}

::selection {
    background: var(--color-accent);
    color: var(--color-text-primary);
}

/* ----------------------------------------------------------- 3. Typography */
h1, h2, h3, h4, h5, h6 {
    margin: 0 0 0.4em;
    font-family: var(--font-serif);
    font-weight: 400;
    color: var(--color-text-primary);
    letter-spacing: 0.005em;
    line-height: 1.15;
}

h1 { font-size: clamp(2rem, 4vw, 3.4rem); }
h2 { font-size: clamp(1.6rem, 2.6vw, 2.2rem); }
h3 { font-size: clamp(1.2rem, 1.6vw, 1.5rem); }
h4 { font-size: 1.1rem; }

p { margin: 0 0 1em; }
p:last-child { margin-bottom: 0; }

.eyebrow {
    display: inline-block;
    font-family: var(--font-sans);
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
    margin: 0 0 12px;
}

.section-heading {
    font-family: var(--font-serif);
    font-size: clamp(1.6rem, 2.4vw, 2.1rem);
    margin: 0 0 8px;
    color: var(--color-text-primary);
}

.section-heading--center {
    text-align: center;
}

.section-subheading {
    font-size: 0.95rem;
    color: var(--color-text-secondary);
    max-width: 56ch;
    margin: 0 0 28px;
}

/* ------------------------------------------------------- 4. Layout helpers */
.container {
    width: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding-left: var(--container-pad);
    padding-right: var(--container-pad);
}

.container--wide { max-width: 1560px; }

main.container { padding-top: 0; padding-bottom: 0; }

.section { padding: clamp(48px, 7vw, 96px) 0; }
.section--tight { padding: clamp(28px, 4vw, 48px) 0; }
.section--surface { background: var(--color-background-secondary); }
.section--warm { background: var(--color-highlight-neutral); }

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

.section-header__copy { max-width: 56ch; }

.section-header--center {
    justify-content: center;
    text-align: center;
}

.section-header--center .section-header__copy {
    max-width: none;
}

.section-header__link {
    font-size: 0.85rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
    border-bottom: 1px solid var(--color-border);
    padding-bottom: 2px;
    transition: color var(--transition-fast), border-color var(--transition-fast);
}

.section-header__link:hover {
    color: var(--color-accent-deep);
    border-color: var(--color-accent-hover);
}

.skip-link {
    position: absolute;
    top: -100px;
    left: 16px;
    z-index: 1000;
    background: var(--color-primary-button);
    color: var(--color-primary-button-text);
    padding: 10px 16px;
    border-radius: var(--radius-sm);
    font-size: 0.9rem;
    transition: top var(--transition-fast);
}

.skip-link:focus { top: 12px; color: var(--color-primary-button-text); }

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

/* -------------------------------------- 5. Buttons / forms / chips / badges */
.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    height: 48px;
    padding: 0 28px;
    font-family: var(--font-sans);
    font-size: 0.85rem;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    border: 1px solid transparent;
    border-radius: var(--radius-sm);
    background: var(--color-primary-button);
    color: var(--color-primary-button-text);
    cursor: pointer;
    transition: background var(--transition-fast), color var(--transition-fast),
                border-color var(--transition-fast), transform var(--transition-fast);
    white-space: nowrap;
}

.button:hover:not(:disabled),
.button:focus-visible:not(:disabled) {
    background: var(--color-primary-button-hover);
    color: var(--color-primary-button-text);
}

.button:active:not(:disabled) { transform: translateY(1px); }

.button:disabled {
    background: var(--color-border);
    color: var(--color-text-muted);
    cursor: not-allowed;
}

.button--ghost {
    background: transparent;
    color: var(--color-text-primary);
    border-color: var(--color-border-strong);
}

.button--ghost:hover:not(:disabled),
.button--ghost:focus-visible:not(:disabled) {
    background: var(--color-surface-warm);
    color: var(--color-text-primary);
    border-color: var(--color-text-secondary);
}

.button--accent {
    background: var(--color-secondary-button);
    color: var(--color-secondary-button-text);
    border-color: var(--color-accent-hover);
}

.button--accent:hover:not(:disabled),
.button--accent:focus-visible:not(:disabled) {
    background: var(--color-secondary-button-hover);
    color: var(--color-secondary-button-text);
}

.button--small { height: 40px; padding: 0 18px; font-size: 0.78rem; }
.button--block { width: 100%; }

/* Form fields */
.field { display: block; margin-bottom: 14px; }

.field label,
.field__label {
    display: block;
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
    margin-bottom: 6px;
}

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="search"],
input[type="number"],
input[type="password"],
select,
textarea {
    width: 100%;
    height: 44px;
    padding: 10px 14px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-family: var(--font-sans);
    font-size: 0.95rem;
    color: var(--color-text-primary);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

textarea { height: auto; min-height: 110px; resize: vertical; }

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

input:focus,
select:focus,
textarea:focus {
    outline: none;
    border-color: var(--color-accent-hover);
    box-shadow: 0 0 0 3px var(--color-accent-soft);
}

.chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    height: 30px;
    padding: 0 12px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 999px;
    font-size: 0.78rem;
    color: var(--color-text-primary);
    cursor: pointer;
    transition: background var(--transition-fast), border-color var(--transition-fast);
}

.chip:hover { background: var(--color-accent-soft); border-color: var(--color-accent-hover); }

.chip__remove {
    width: 14px;
    height: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-secondary);
    font-size: 14px;
    line-height: 1;
}

.badge {
    display: inline-flex;
    align-items: center;
    height: 22px;
    padding: 0 10px;
    border-radius: 999px;
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    background: var(--color-accent);
    color: var(--color-secondary-button-text);
}

.badge--neutral { background: var(--color-highlight-neutral); color: var(--color-text-primary); }
.badge--success { background: rgba(125, 138, 117, 0.15); color: var(--color-success); }
.badge--warning { background: rgba(185, 138, 74, 0.15); color: var(--color-warning); }
.badge--error { background: rgba(168, 95, 86, 0.12); color: var(--color-error); }

/* ----------------------------------------------------- 6. Announcement bar */
.announcement-bar {
    background: var(--color-primary-button);
    color: var(--color-text-on-dark);
    text-align: center;
    font-size: 0.78rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    padding: 10px var(--container-pad);
    min-height: var(--announcement-height);
    position: relative;
    z-index: 90;
}

/* --------------------------------------------------------- 7. Site header */
.site-header {
    background: var(--color-background);
    border-bottom: 1px solid var(--color-border);
    position: sticky;
    top: 0;
    z-index: 80;
}

.site-header__inner {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 18px 0;
    min-height: var(--header-height);
}

.site-header__mobile-toggle { display: flex; align-items: center; }

.site-header__actions { display: flex; align-items: center; gap: 8px; }
.site-header__actions--right { justify-content: flex-end; }

.site-logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-primary);
    font-family: var(--font-serif);
    font-size: 1.6rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.site-logo:hover { color: var(--color-text-primary); }

.site-logo__wordmark { font-weight: 400; }

.site-nav--desktop {
    display: flex;
    align-items: center;
    gap: 28px;
    white-space: nowrap;
}

.site-nav--desktop-left {
    margin-left: var(--header-gutter, clamp(18px, 2.8vw, 42px));
}

.icon-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    height: 40px;
    padding: 0 10px;
    color: var(--color-text-primary);
    font-size: 0.85rem;
    border-radius: var(--radius-sm);
    transition: background var(--transition-fast), color var(--transition-fast);
}

.icon-link:hover,
.icon-link:focus-visible {
    background: var(--color-accent-soft);
    color: var(--color-text-primary);
}

.icon-link__icon {
    width: 20px;
    height: 20px;
    stroke: currentColor;
    fill: none;
    stroke-width: 1.6;
    flex: none;
}

.icon-link__label { font-size: 0.78rem; letter-spacing: 0.1em; }

.icon-link__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    background: var(--color-primary-button);
    color: var(--color-primary-button-text);
    border-radius: 999px;
    font-size: 0.65rem;
    font-weight: 600;
}

.icon-link__count.is-empty {
    display: none;
}

/* Cart-page minimal header */
.site-header--cart .site-header--cart__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 0;
    min-height: 72px;
}

.site-logo--cart { font-size: 1.4rem; }

.site-header__cart-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--color-text-primary);
}

.site-header__cart-icon { width: 22px; height: 22px; stroke: currentColor; }

.site-nav--desktop > a,
.site-nav--desktop > .nav-item > a {
    position: relative;
    padding: 8px 2px;
    font-size: 0.82rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-text-primary);
}

.site-nav--desktop > a::after,
.site-nav--desktop > .nav-item > a::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    background: var(--color-accent-hover);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform var(--transition-base);
}

.site-nav--desktop > a:hover::after,
.site-nav--desktop > .nav-item:hover > a::after,
.site-nav--desktop > .nav-item--open > a::after { transform: scaleX(1); }

/* Mega menu */
.nav-item { position: relative; }

.nav-item__caret {
    margin-left: 4px;
    font-size: 0.6rem;
    transition: transform var(--transition-fast);
}

.nav-item:hover .nav-item__caret,
.nav-item--open .nav-item__caret { transform: rotate(180deg); }

.mega-menu {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    transform: translateY(8px);
    width: min(960px, calc(100vw - (var(--header-gutter, 0px) * 2)));
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-drawer);
    padding: 28px 32px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity var(--transition-base), transform var(--transition-base), visibility var(--transition-base);
    z-index: 90;
}

.nav-item:hover .mega-menu,
.nav-item:focus-within .mega-menu,
.nav-item--open .mega-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
}

.mega-menu__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 28px;
}

.mega-menu__group { min-width: 0; }

.mega-menu__heading {
    font-family: var(--font-sans);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
    margin: 0 0 12px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--color-border);
}

.mega-menu__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.mega-menu__list a {
    display: block;
    padding: 4px 0;
    font-size: 0.88rem;
    letter-spacing: 0.02em;
    text-transform: none;
    color: var(--color-text-primary);
}

.mega-menu__list a:hover { color: var(--color-accent-deep); }

.mega-menu__feature {
    display: flex;
    flex-direction: column;
    gap: 12px;
    background: var(--color-surface-warm);
    border-radius: var(--radius-md);
    padding: 16px;
}

.mega-menu__feature-image {
    aspect-ratio: 4 / 5;
    background: var(--color-background-secondary) center/cover no-repeat;
    border-radius: var(--radius-sm);
}

.mega-menu__feature-label {
    font-size: 0.78rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
}

/* Search drawer */
.search-drawer {
    border-top: 1px solid var(--color-border);
    background: var(--color-background);
    padding: 18px 0;
}

.search-form { display: flex; gap: 10px; align-items: center; }

.search-form input[type="search"] {
    flex: 1;
    height: 48px;
    background: var(--color-surface);
}

/* Mobile menu drawer */
.menu-drawer {
    position: fixed;
    inset: 0;
    background: rgba(47, 42, 40, 0.4);
    z-index: 95;
    display: flex;
    justify-content: flex-start;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition-base), visibility var(--transition-base);
}

.menu-drawer:not([hidden]) { opacity: 1; visibility: visible; }

.menu-drawer__panel {
    width: min(380px, 88vw);
    height: 100%;
    background: var(--color-background);
    padding: 28px 24px 32px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    overflow-y: auto;
    box-shadow: var(--shadow-drawer);
    transform: translateX(-100%);
    transition: transform var(--transition-base);
}

.menu-drawer:not([hidden]) .menu-drawer__panel { transform: translateX(0); }

.menu-drawer__close {
    align-self: flex-end;
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-primary);
    border-radius: 999px;
}

.menu-drawer__close:hover { background: var(--color-accent-soft); }

.menu-drawer details {
    border-bottom: 1px solid var(--color-border);
    padding: 4px 0;
}

.menu-drawer summary {
    list-style: none;
    cursor: pointer;
    padding: 12px 0;
    font-size: 0.95rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--color-text-primary);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.menu-drawer summary::-webkit-details-marker { display: none; }

.menu-drawer summary::after {
    content: "+";
    font-size: 1.2rem;
    color: var(--color-text-secondary);
    transition: transform var(--transition-fast);
}

.menu-drawer details[open] summary::after { transform: rotate(45deg); }

.menu-drawer__sublist {
    list-style: none;
    margin: 0 0 12px;
    padding: 4px 0 12px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.menu-drawer__sublist a {
    padding: 8px 0;
    font-size: 0.9rem;
    color: var(--color-text-secondary);
}

.menu-drawer__sublist a:hover { color: var(--color-accent-deep); }

.menu-drawer__top-link {
    padding: 14px 0;
    font-size: 0.95rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--color-text-primary);
    border-bottom: 1px solid var(--color-border);
}

.menu-drawer__footer {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--color-border);
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* ----------------------------------------------------------------- 8. Hero */
.home-hero {
    position: relative;
    background: transparent;
    overflow: clip;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}

.home-hero__inner {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: clamp(720px, 92vh, 1040px);
    padding-top: clamp(120px, 16vw, 220px);
    padding-bottom: clamp(56px, 8vw, 110px);
}

.home-hero__media {
    position: absolute;
    inset: 0;
    background: var(--color-highlight-neutral) center/cover no-repeat;
}

.home-hero__media::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(27, 22, 19, 0.28) 0%, rgba(27, 22, 19, 0.16) 18%, rgba(27, 22, 19, 0.26) 100%),
        radial-gradient(circle at center, rgba(250, 247, 244, 0.04) 0%, rgba(27, 22, 19, 0.18) 72%);
}

.home-hero__copy {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    max-width: 880px;
    padding: 0 24px;
    text-align: center;
}

.home-hero__eyebrow {
    font-size: 0.78rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(250, 247, 244, 0.9);
    margin-bottom: 18px;
}

.home-hero__heading {
    font-family: var(--font-serif);
    font-size: clamp(3.2rem, 7vw, 6.4rem);
    line-height: 1.05;
    margin: 0 0 24px;
    color: var(--color-text-on-dark);
    letter-spacing: 0.03em;
}

.home-hero__copy p {
    color: rgba(250, 247, 244, 0.88);
    max-width: 52ch;
    margin-bottom: 34px;
    font-size: 1.02rem;
}

.home-hero__actions { display: flex; gap: 12px; flex-wrap: wrap; }
.home-hero__actions { justify-content: center; }

.home-hero .button {
    background: rgba(255, 255, 255, 0.08);
    color: var(--color-text-on-dark);
    border-color: rgba(255, 255, 255, 0.7);
}

.home-hero .button:hover:not(:disabled),
.home-hero .button:focus-visible:not(:disabled) {
    background: rgba(255, 255, 255, 0.18);
    color: var(--color-text-on-dark);
    border-color: rgba(255, 255, 255, 0.95);
}

.home-hero .button--ghost {
    background: transparent;
    color: rgba(250, 247, 244, 0.88);
    border-color: rgba(255, 255, 255, 0.34);
}

/* ---------------------------------------------------- 9. Category tile grid */
.category-tile-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: clamp(14px, 1.6vw, 22px);
}

.category-tile {
    position: relative;
    display: block;
    overflow: hidden;
    border-radius: var(--radius-md);
    background: var(--color-background-secondary);
    aspect-ratio: 4 / 5;
    color: var(--color-text-primary);
    transition: transform var(--transition-base);
}

.category-tile:hover { transform: translateY(-2px); color: var(--color-text-primary); }

.category-tile__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.category-tile:hover .category-tile__image { transform: scale(1.03); }

.category-tile__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(47, 42, 40, 0) 50%, rgba(47, 42, 40, 0.45) 100%);
}

.category-tile__copy {
    position: absolute;
    left: 24px;
    bottom: 24px;
    right: 24px;
    color: var(--color-text-on-dark);
}

.category-tile__label {
    font-family: var(--font-serif);
    font-size: clamp(1.2rem, 1.6vw, 1.5rem);
    margin: 0 0 4px;
    color: inherit;
}

.category-tile__cta {
    font-size: 0.72rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-text-on-dark-muted);
}

/* -------------------------------------- 10. Bestsellers toolbar / chips bar */
.collection-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
    padding: 20px 0;
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    margin-bottom: 28px;
}

.collection-toolbar__left,
.collection-toolbar__right {
    display: flex;
    align-items: center;
    gap: 14px;
}

.collection-count {
    font-size: 0.78rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
}

.toolbar-button {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    height: 38px;
    padding: 0 14px;
    background: transparent;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    color: var(--color-text-primary);
    font-size: 0.82rem;
    letter-spacing: 0.06em;
    cursor: pointer;
    transition: background var(--transition-fast), border-color var(--transition-fast);
}

.toolbar-button:hover { background: var(--color-surface-warm); border-color: var(--color-border-strong); }

.toolbar-button__icon { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 1.6; }

.sort-select {
    appearance: none;
    -webkit-appearance: none;
    height: 38px;
    padding: 0 36px 0 14px;
    background: transparent url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%236F625D' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>") no-repeat right 14px center;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    color: var(--color-text-primary);
    font-size: 0.82rem;
    letter-spacing: 0.06em;
}

.sort-select:hover { border-color: var(--color-border-strong); }

.active-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 24px;
}

.active-filters__clear {
    height: 30px;
    padding: 0 12px;
    background: transparent;
    color: var(--color-text-secondary);
    font-size: 0.78rem;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.active-filters__clear:hover { color: var(--color-accent-deep); }

/* ----------------------------------------------------- 11. Filter drawer */
.filter-drawer {
    position: fixed;
    inset: 0;
    background: rgba(47, 42, 40, 0.4);
    z-index: 95;
    display: flex;
    justify-content: flex-end;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition-base), visibility var(--transition-base);
}

.filter-drawer:not([hidden]) { opacity: 1; visibility: visible; }

.filter-drawer__panel {
    width: min(420px, 92vw);
    height: 100%;
    background: var(--color-background);
    padding: 24px;
    overflow-y: auto;
    box-shadow: var(--shadow-drawer);
    transform: translateX(100%);
    transition: transform var(--transition-base);
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.filter-drawer:not([hidden]) .filter-drawer__panel { transform: translateX(0); }

.filter-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid var(--color-border);
    padding-bottom: 12px;
}

.filter-drawer__title {
    font-family: var(--font-serif);
    font-size: 1.4rem;
    margin: 0;
}

.filter-drawer__group {
    border-bottom: 1px solid var(--color-border);
    padding: 8px 0 16px;
}

.filter-drawer__group summary {
    list-style: none;
    cursor: pointer;
    padding: 8px 0;
    font-size: 0.85rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-text-primary);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.filter-drawer__group summary::-webkit-details-marker { display: none; }
.filter-drawer__group summary::after { content: "+"; color: var(--color-text-secondary); font-size: 1.1rem; transition: transform var(--transition-fast); }
.filter-drawer__group[open] summary::after { transform: rotate(45deg); }

.filter-option {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 0;
    font-size: 0.92rem;
    color: var(--color-text-primary);
    cursor: pointer;
}

.filter-option input { width: 16px; height: 16px; accent-color: var(--color-accent-deep); }

.filter-drawer__footer {
    margin-top: auto;
    display: flex;
    gap: 10px;
    padding-top: 16px;
    border-top: 1px solid var(--color-border);
}

.filter-drawer__footer .button { flex: 1; }

/* ------------------------------------------------- 12. Product grid & card */
.product-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: clamp(16px, 2vw, 28px);
}

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

.product-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.product-card:hover {
    border-color: var(--color-border-strong);
    box-shadow: var(--shadow-card-hover);
}

.product-card__media {
    position: relative;
    aspect-ratio: 4 / 5;
    background: var(--color-background-secondary);
    overflow: hidden;
}

.product-card__image,
.product-card__image-secondary {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: opacity var(--transition-slow), transform var(--transition-slow);
}

.product-card__image-secondary { opacity: 0; }

.product-card:hover .product-card__image-secondary { opacity: 1; }
.product-card:hover .product-card__image { opacity: 0; }

.product-card__badges {
    position: absolute;
    top: 12px;
    left: 12px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    z-index: 2;
}

.product-card__wishlist {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(250, 247, 244, 0.85);
    backdrop-filter: blur(2px);
    border-radius: 999px;
    color: var(--color-text-primary);
    z-index: 2;
}

.product-card__wishlist:hover { background: var(--color-surface); color: var(--color-accent-deep); }

.product-card__body {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 14px 16px 16px;
    flex: 1;
}

.product-card__type {
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
}

.product-card__title {
    font-family: var(--font-serif);
    font-size: 1.05rem;
    margin: 0;
    color: var(--color-text-primary);
    line-height: 1.25;
}

.product-card__title a { color: inherit; }
.product-card__title a:hover { color: var(--color-accent-deep); }

.product-card__price {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.95rem;
    color: var(--color-primary-button);
    font-weight: 500;
}

.product-card__price-compare {
    color: var(--color-text-muted);
    text-decoration: line-through;
    font-weight: 400;
    font-size: 0.85rem;
}

.product-card__price-sale { color: var(--color-accent-deep); }

.product-card__variants {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 4px;
}

.product-card__swatch {
    width: 14px;
    height: 14px;
    border-radius: 999px;
    border: 1px solid var(--color-border);
    background: var(--color-highlight-neutral);
}

.product-card__variants-label {
    font-size: 0.72rem;
    color: var(--color-text-secondary);
}

.product-card__stock {
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
}

.product-card__stock--low { color: var(--color-warning); }
.product-card__stock--out { color: var(--color-error); }

/* ---------------------------------------------------------- 13. Quick add */
.product-card__quickadd {
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 12px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 10px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    opacity: 0;
    transform: translateY(8px);
    pointer-events: none;
    transition: opacity var(--transition-base), transform var(--transition-base);
    z-index: 3;
}

.product-card:hover .product-card__quickadd,
.product-card:focus-within .product-card__quickadd {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.product-card__quickadd-label {
    font-size: 0.72rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
}

.product-card__amounts { display: flex; flex-wrap: wrap; gap: 6px; }

.product-card__amount {
    height: 28px;
    padding: 0 10px;
    background: transparent;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    font-size: 0.78rem;
    color: var(--color-text-primary);
    cursor: pointer;
    transition: background var(--transition-fast), border-color var(--transition-fast),
                color var(--transition-fast);
}

.product-card__amount:hover { background: var(--color-accent-soft); border-color: var(--color-accent-hover); }

.product-card__amount.is-active,
.product-card__amount[aria-pressed="true"] {
    background: var(--color-primary-button);
    border-color: var(--color-primary-button);
    color: var(--color-primary-button-text);
}

.product-card__amount[disabled] { opacity: 0.4; cursor: not-allowed; }

.product-card__add-button {
    height: 38px;
    background: var(--color-primary-button);
    color: var(--color-primary-button-text);
    border-radius: var(--radius-sm);
    font-size: 0.78rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.product-card__add-button:hover:not(:disabled) { background: var(--color-primary-button-hover); }

.product-card__add-button:disabled {
    background: var(--color-border);
    color: var(--color-text-muted);
    cursor: not-allowed;
}

/* ------------------------------------------------ 12.5 Home carousels */
.home-carousel-section {
    padding-top: clamp(12px, 2vw, 24px);
}

.home-carousel-section__header {
    margin-bottom: 24px;
}

.home-carousel {
    display: flex;
    flex-direction: column;
    gap: 22px;
}

.home-carousel__track {
    display: flex;
    gap: clamp(16px, 2vw, 28px);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    padding-bottom: 6px;
    scrollbar-width: none;
}

.home-carousel__track::-webkit-scrollbar { display: none; }

.home-carousel__track .product-card {
    flex: 0 0 clamp(230px, 24vw, 320px);
    scroll-snap-align: start;
}

.home-carousel__controls {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
}

.home-carousel__arrows {
    display: flex;
    align-items: center;
    gap: 28px;
    justify-content: center;
}

.home-carousel__arrow {
    width: 54px;
    height: 54px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    background: var(--color-surface);
    color: var(--color-text-primary);
    transition: background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
}

.home-carousel__arrow:hover {
    background: var(--color-accent-soft);
    border-color: var(--color-accent-hover);
    transform: translateY(-1px);
}

.home-carousel__arrow svg {
    width: 26px;
    height: 26px;
}

/* ------------------------------------------------ 12.6 Instagram feed */
.instagram-section {
    margin-top: clamp(14px, 2vw, 28px);
    padding-top: clamp(28px, 5vw, 56px);
    padding-bottom: clamp(32px, 5vw, 64px);
    background: linear-gradient(180deg, rgba(235, 225, 212, 0.9), rgba(244, 237, 228, 0.98));
    border-top: 1px solid rgba(79, 65, 57, 0.08);
    border-bottom: 1px solid rgba(79, 65, 57, 0.08);
}

.instagram-section__header {
    margin-bottom: 14px;
}

.instagram-section__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 24px;
    color: var(--color-text-secondary);
    font-size: 0.95rem;
}

.instagram-section__meta p {
    margin: 0;
    max-width: 60ch;
}

.instagram-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 14px;
}

.instagram-grid__item {
    position: relative;
    display: block;
    aspect-ratio: 1;
    overflow: hidden;
    border-radius: var(--radius-sm);
    background: var(--color-surface);
    border: 1px solid rgba(79, 65, 57, 0.08);
}

.instagram-grid__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow), filter var(--transition-slow);
}

.instagram-grid__overlay {
    position: absolute;
    inset: auto 0 0 0;
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
    min-height: 44%;
    padding: 14px;
    color: var(--color-text-on-dark);
    background: linear-gradient(180deg, rgba(47, 42, 40, 0) 0%, rgba(47, 42, 40, 0.5) 100%);
    opacity: 0;
    transition: opacity var(--transition-base);
}

.instagram-grid__overlay span {
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.instagram-grid__item:hover img { transform: scale(1.03); filter: saturate(1.02); }
.instagram-grid__item:hover .instagram-grid__overlay { opacity: 1; }

@media (hover: none) {
    .product-card__quickadd {
        position: static;
        opacity: 1;
        transform: none;
        pointer-events: auto;
        margin: 12px 16px 16px;
    }
    .product-card__image-secondary { display: none; }
}

/* ----------------------------------------------------- 14. Editorial moment */
.editorial-moment {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: clamp(20px, 4vw, 56px);
    align-items: center;
}

.editorial-moment--reverse { grid-template-columns: 1fr 1.1fr; }
.editorial-moment--reverse .editorial-moment__media { order: 2; }

.editorial-moment__media {
    aspect-ratio: 4 / 5;
    background: var(--color-background-secondary) center/cover no-repeat;
    border-radius: var(--radius-md);
    overflow: hidden;
}

.editorial-moment__copy { padding: 0 clamp(0px, 2vw, 24px); }

.editorial-moment__copy h2 {
    font-size: clamp(1.6rem, 2.4vw, 2.4rem);
    margin-bottom: 16px;
}

.editorial-moment__copy p {
    color: var(--color-text-secondary);
    margin-bottom: 24px;
    max-width: 56ch;
}

/* -------------------------------------------------- 16. Trust strip */
.trust-strip {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    padding: clamp(28px, 4vw, 48px) 0;
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
}

.trust-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 8px;
    padding: 8px;
}

.trust-item__icon {
    width: 32px;
    height: 32px;
    color: var(--color-text-secondary);
    stroke: currentColor;
    fill: none;
    stroke-width: 1.4;
}

.trust-item__title {
    font-size: 0.92rem;
    font-weight: 500;
    margin: 0;
    color: var(--color-text-primary);
}

.trust-item__copy {
    font-size: 0.82rem;
    color: var(--color-text-secondary);
    margin: 0;
}

/* ------------------------------------------------------ 17. Newsletter */
.newsletter-signup {
    background: var(--color-highlight-neutral);
    padding: clamp(40px, 6vw, 72px) clamp(24px, 5vw, 48px);
    border-radius: var(--radius-md);
    text-align: center;
}

.newsletter-signup__inner { max-width: 540px; margin: 0 auto; }

.newsletter-signup h2 {
    font-size: clamp(1.6rem, 2.4vw, 2.2rem);
    margin-bottom: 8px;
}

.newsletter-signup p {
    color: var(--color-text-secondary);
    margin-bottom: 24px;
}

.newsletter-signup__form {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: center;
}

.newsletter-signup__form input[type="email"] {
    flex: 1;
    min-width: 220px;
    background: var(--color-surface);
}

.newsletter-signup__success {
    margin-top: 12px;
    color: var(--color-success);
    font-size: 0.9rem;
}

/* ---------------------------------------------------------- 18. Footer */
.site-footer {
    background: var(--color-primary-button);
    color: var(--color-text-on-dark);
    padding: clamp(48px, 6vw, 80px) 0 32px;
    margin-top: clamp(48px, 7vw, 96px);
}

.footer-grid {
    display: grid;
    grid-template-columns: 1.4fr repeat(3, 1fr) 1.2fr;
    gap: clamp(20px, 3vw, 48px);
}

.footer-title {
    font-family: var(--font-serif);
    font-size: 1.6rem;
    color: var(--color-text-on-dark);
    margin-bottom: 12px;
}

.site-footer p { color: var(--color-text-on-dark-muted); }

.footer-heading {
    font-family: var(--font-sans);
    font-size: 0.78rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-text-on-dark);
    margin-bottom: 16px;
}

.site-footer a {
    color: var(--color-text-on-dark-muted);
    transition: color var(--transition-fast);
}

.site-footer a:hover { color: var(--color-accent); }

.footer-newsletter input[type="email"] {
    background: rgba(250, 247, 244, 0.08);
    border-color: rgba(250, 247, 244, 0.18);
    color: var(--color-text-on-dark);
}

.footer-newsletter input[type="email"]::placeholder { color: var(--color-text-on-dark-muted); }

.footer-newsletter input[type="email"]:focus {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(247, 217, 215, 0.18);
}

.footer-newsletter .button {
    background: var(--color-accent);
    color: var(--color-text-primary);
    border-color: var(--color-accent);
}

.footer-newsletter .button:hover {
    background: var(--color-accent-hover);
    border-color: var(--color-accent-hover);
    color: var(--color-text-primary);
}

.footer-social {
    display: flex;
    gap: 8px;
    margin-top: 16px;
}

.footer-social a {
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(250, 247, 244, 0.2);
    border-radius: 999px;
    color: var(--color-text-on-dark-muted);
}

.footer-social a:hover { border-color: var(--color-accent); color: var(--color-accent); }

.footer-bottom {
    margin-top: 48px;
    padding-top: 24px;
    border-top: 1px solid rgba(250, 247, 244, 0.12);
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    justify-content: space-between;
    align-items: center;
    font-size: 0.78rem;
    color: var(--color-text-on-dark-muted);
}

.footer-note { font-size: 0.78rem; color: var(--color-text-on-dark-muted); }

/* --------------------------------------------------------- 19. Cart page */
.cart-page {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: clamp(24px, 4vw, 56px);
    padding: clamp(32px, 5vw, 72px) 0;
}

.cart-page__items { display: flex; flex-direction: column; gap: 20px; }

.cart-item {
    display: grid;
    grid-template-columns: 110px 1fr auto;
    gap: 16px;
    padding: 16px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    align-items: flex-start;
}

.cart-item__image {
    width: 100%;
    aspect-ratio: 4 / 5;
    background: var(--color-background-secondary) center/cover no-repeat;
    border-radius: var(--radius-sm);
}

.cart-item__copy { display: flex; flex-direction: column; gap: 4px; }

.cart-item__title { font-family: var(--font-serif); font-size: 1.05rem; margin: 0; }

.cart-item__meta { font-size: 0.82rem; color: var(--color-text-secondary); }

.cart-item__quantity {
    display: inline-flex;
    align-items: center;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    overflow: hidden;
    margin-top: 8px;
}

.cart-item__quantity button {
    width: 32px;
    height: 32px;
    color: var(--color-text-secondary);
}

.cart-item__quantity button:hover { background: var(--color-accent-soft); color: var(--color-text-primary); }

.cart-item__quantity-value { min-width: 32px; text-align: center; font-size: 0.9rem; }

.cart-item__price {
    text-align: right;
    font-weight: 500;
    color: var(--color-primary-button);
}

.cart-item__remove {
    margin-top: 6px;
    font-size: 0.78rem;
    color: var(--color-text-secondary);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-align: right;
    background: transparent;
}

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

.cart-page__summary {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 24px;
    height: fit-content;
    position: sticky;
    top: calc(var(--header-height) + 16px);
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.cart-page__summary h2 { font-size: 1.2rem; margin: 0; }

.cart-page__total {
    display: flex;
    justify-content: space-between;
    padding-top: 12px;
    border-top: 1px solid var(--color-border);
    font-size: 1.1rem;
    font-weight: 500;
}

.cart-page__actions { display: flex; flex-direction: column; gap: 8px; }

.cart-page__empty {
    text-align: center;
    padding: 80px 24px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}

/* ------------------------------------------------------- 20. Checkout page */
.checkout-page {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    gap: clamp(24px, 4vw, 56px);
    padding: clamp(32px, 5vw, 72px) 0;
}

.checkout-page__left,
.checkout-page__right {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.checkout-section {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 24px;
}

.checkout-section__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.checkout-section__head h2 { font-size: 1.2rem; margin: 0; }

.checkout-kicker {
    font-size: 0.72rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
    margin-bottom: 4px;
}

.checkout-form { display: flex; flex-direction: column; gap: 12px; }

.checkout-grid { display: grid; gap: 12px; }
.checkout-grid--two { grid-template-columns: 1fr 1fr; }
.checkout-grid--three { grid-template-columns: repeat(3, 1fr); }

.checkout-field { display: flex; flex-direction: column; gap: 6px; }

.checkout-field label,
.checkout-field__label {
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
}

.checkout-divider {
    border-top: 1px solid var(--color-border);
    margin: 8px 0;
}

.checkout-toggle,
.checkout-delivery-toggle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-size: 0.85rem;
}

.checkout-check,
.checkout-check--compact {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.88rem;
}

.checkout-check input[type="checkbox"] { accent-color: var(--color-accent-deep); }

.checkout-shipping-fields,
.checkout-billing-fields { display: flex; flex-direction: column; gap: 12px; }

.checkout-shipping-methods { display: flex; flex-direction: column; gap: 8px; }

.checkout-shipping-method {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 16px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: border-color var(--transition-fast), background var(--transition-fast);
}

.checkout-shipping-method:hover { background: var(--color-surface-warm); }

.checkout-shipping-method--active {
    border-color: var(--color-accent-hover);
    background: var(--color-accent-soft);
}

.checkout-shipping-method__copy { display: flex; flex-direction: column; gap: 2px; }

.checkout-pickup-location {
    padding: 12px 14px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-surface-warm);
}

.checkout-pickup-location__head {
    display: flex;
    justify-content: space-between;
    font-size: 0.9rem;
}

.checkout-pickup-location__eta { font-size: 0.78rem; color: var(--color-text-secondary); }

.checkout-payments { display: flex; flex-direction: column; gap: 8px; }

.checkout-payment {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 14px 16px;
    cursor: pointer;
    transition: border-color var(--transition-fast), background var(--transition-fast);
}

.checkout-payment--active {
    border-color: var(--color-accent-hover);
    background: var(--color-accent-soft);
}

.checkout-payment__title {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.9rem;
    margin: 0;
}

.checkout-payment__brands {
    display: flex;
    gap: 6px;
    align-items: center;
    color: var(--color-text-secondary);
    font-size: 0.75rem;
}

.checkout-payment__hint {
    font-size: 0.82rem;
    color: var(--color-text-secondary);
    margin-top: 6px;
}

.checkout-stripe-element,
.checkout-paypal-element { margin-top: 12px; }

.checkout-stripe-element__frame,
.checkout-paypal-element__frame {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 12px;
    background: var(--color-surface);
    min-height: 60px;
}

.checkout-express { display: flex; flex-direction: column; gap: 10px; }

.checkout-express__buttons {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
}

.checkout-express__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    height: 44px;
    background: var(--color-text-primary);
    color: var(--color-text-on-dark);
    border-radius: var(--radius-sm);
    font-size: 0.78rem;
    letter-spacing: 0.04em;
}

.checkout-express__button:hover {
    background: var(--color-primary-button-hover);
    color: var(--color-text-on-dark);
}

.checkout-express__button--apple-pay { background: #000; color: #fff; }
.checkout-express__button--google-pay { background: #fff; color: #000; border: 1px solid var(--color-border); }
.checkout-express__button--paypal { background: #ffc439; color: #003087; }

.checkout-summary {
    position: sticky;
    top: calc(var(--header-height) + 16px);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    height: fit-content;
}

.checkout-summary__head { display: flex; justify-content: space-between; align-items: center; }

.checkout-summary__items { display: flex; flex-direction: column; gap: 12px; }

.checkout-summary-item {
    display: grid;
    grid-template-columns: 64px 1fr auto;
    gap: 12px;
    align-items: center;
}

.checkout-summary-item img {
    width: 64px;
    height: 80px;
    object-fit: cover;
    border-radius: var(--radius-sm);
}

.checkout-summary__rows { display: flex; flex-direction: column; gap: 6px; font-size: 0.9rem; }
.checkout-summary__rows > div { display: flex; justify-content: space-between; }

.checkout-summary__total {
    display: flex;
    justify-content: space-between;
    padding-top: 12px;
    border-top: 1px solid var(--color-border);
    font-size: 1.1rem;
    font-weight: 500;
}

.checkout-summary__note { font-size: 0.78rem; color: var(--color-text-secondary); }

.checkout-submit { width: 100%; }

.checkout-empty,
.checkout-success {
    text-align: center;
    padding: 60px 24px;
    color: var(--color-text-secondary);
}

/* --------------------------------------------------- 21. Product detail */
.product-detail {
    padding: clamp(20px, 4vw, 48px) 0 clamp(40px, 6vw, 80px);
}

.product-detail__breadcrumbs {
    font-size: 0.78rem;
    color: var(--color-text-secondary);
    margin-bottom: 20px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.product-detail__breadcrumbs a { color: var(--color-text-secondary); }
.product-detail__breadcrumbs a:hover { color: var(--color-accent-deep); }

.product-hero {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: clamp(24px, 4vw, 64px);
    align-items: flex-start;
}

.product-gallery { display: flex; flex-direction: column; gap: 12px; }

.product-gallery__main {
    aspect-ratio: 4 / 5;
    background: var(--color-background-secondary);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.product-gallery__main-button {
    width: 100%;
    height: 100%;
    padding: 0;
    background: transparent;
    cursor: zoom-in;
}

.product-gallery__main-button img { width: 100%; height: 100%; object-fit: cover; }

.product-gallery__thumbs { display: flex; gap: 8px; flex-wrap: wrap; }

.product-gallery__thumb {
    width: 72px;
    height: 90px;
    background: var(--color-background-secondary);
    border-radius: var(--radius-sm);
    overflow: hidden;
    border: 1px solid var(--color-border);
    padding: 0;
    cursor: pointer;
    transition: border-color var(--transition-fast);
}

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

.product-gallery__thumb.is-active,
.product-gallery__thumb[aria-pressed="true"] { border-color: var(--color-accent-hover); }

.product-meta { display: flex; flex-direction: column; gap: 14px; }
.product-meta--compact { gap: 8px; }

.product-meta h1 {
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    margin: 0;
}

.product-price {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 1.1rem;
    color: var(--color-primary-button);
    font-weight: 500;
}

.product-price--large { font-size: 1.4rem; }

.product-price__compare {
    color: var(--color-text-muted);
    text-decoration: line-through;
    font-weight: 400;
}

.product-unit { font-size: 0.85rem; color: var(--color-text-secondary); }

.product-description {
    color: var(--color-text-secondary);
    line-height: 1.65;
    font-size: 0.95rem;
}

.section-block { margin: clamp(28px, 4vw, 56px) 0; }

.stat-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 16px 20px;
}

.stat-card__label {
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
    margin-bottom: 6px;
}

.gallery-viewer {
    position: fixed;
    inset: 0;
    z-index: 200;
    display: flex;
    align-items: center;
    justify-content: center;
}

.gallery-viewer__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(47, 42, 40, 0.78);
}

.gallery-viewer__panel {
    position: relative;
    z-index: 1;
    max-width: 90vw;
    max-height: 90vh;
    background: transparent;
}

.gallery-viewer__image {
    max-width: 90vw;
    max-height: 90vh;
    object-fit: contain;
    border-radius: var(--radius-sm);
}

.gallery-viewer__close {
    position: absolute;
    top: 24px;
    right: 24px;
    width: 40px;
    height: 40px;
    background: var(--color-surface);
    border-radius: 999px;
    color: var(--color-text-primary);
    z-index: 2;
}

.gallery-viewer__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    background: var(--color-surface);
    border-radius: 999px;
    z-index: 2;
}

.gallery-viewer__nav--prev { left: 24px; }
.gallery-viewer__nav--next { right: 24px; }

/* --------------------------------------------------- 22. Collections page */
.collection-hero {
    padding: clamp(32px, 5vw, 64px) 0 clamp(20px, 3vw, 32px);
    background: var(--color-background-secondary);
    border-bottom: 1px solid var(--color-border);
}

.collection-hero__copy { max-width: 720px; }

.collection-hero h1 { font-size: clamp(1.8rem, 3vw, 2.6rem); margin: 0 0 12px; }

.collection-hero__stats { font-size: 0.85rem; color: var(--color-text-secondary); }

.collection-hero__search {
    display: flex;
    gap: 8px;
    margin-top: 20px;
    max-width: 480px;
}

.collection-layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: clamp(20px, 3vw, 40px);
    padding: clamp(32px, 4vw, 56px) 0;
}

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

.collection-filters {
    display: flex;
    flex-direction: column;
    gap: 16px;
    position: sticky;
    top: calc(var(--header-height) + 16px);
    height: fit-content;
}

.collection-filters__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--color-border);
    padding-bottom: 8px;
}

.collection-filters__header h2 { font-size: 1rem; margin: 0; letter-spacing: 0.06em; }

.collection-filters__clear {
    font-size: 0.78rem;
    color: var(--color-text-secondary);
    text-decoration: underline;
    text-underline-offset: 3px;
    background: transparent;
}

.collection-filters__clear:hover { color: var(--color-accent-deep); }

.collection-filters__note { font-size: 0.78rem; color: var(--color-text-muted); }

.collection-filter-form { display: flex; flex-direction: column; gap: 16px; }

.collection-filter-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--color-border);
}

.collection-filter-group h3 {
    font-size: 0.78rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
    margin: 0 0 6px;
}

.collection-filter-check {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.88rem;
    cursor: pointer;
}

.collection-filter-check input[type="checkbox"] { accent-color: var(--color-accent-deep); }

.collection-filter-submit { display: flex; gap: 8px; flex-wrap: wrap; }

.collection-results { display: flex; flex-direction: column; gap: 24px; }

.collection-results__empty {
    padding: 60px 24px;
    text-align: center;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    color: var(--color-text-secondary);
}

/* --------------------------------------------------- 23. Policy / account */
.policy-page,
.account-page,
.bookings-page {
    padding: clamp(32px, 5vw, 72px) 0;
    max-width: 880px;
    margin: 0 auto;
}

.policy-page__summary {
    color: var(--color-text-secondary);
    margin-bottom: 24px;
    font-size: 0.95rem;
}

.policy-section {
    padding: 16px 0;
    border-bottom: 1px solid var(--color-border);
}

.policy-section:last-child { border-bottom: none; }

.policy-section h2 { font-size: 1.2rem; margin-bottom: 8px; }

.card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 24px;
}

/* ------------------------------------------------------------ 24. Toast */
.site-toast {
    position: fixed;
    bottom: 24px;
    right: 24px;
    background: var(--color-text-primary);
    color: var(--color-text-on-dark);
    padding: 12px 18px;
    border-radius: var(--radius-sm);
    font-size: 0.9rem;
    z-index: 300;
    opacity: 0;
    transform: translateY(8px);
    pointer-events: none;
    transition: opacity var(--transition-base), transform var(--transition-base);
    box-shadow: var(--shadow-drawer);
}

.site-toast.is-visible {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

/* -------------------------------------------- 25. Responsive breakpoints */
@media (max-width: 1100px) {
    .product-grid { grid-template-columns: repeat(3, 1fr); }
    .category-tile-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-grid { grid-template-columns: 1fr 1fr 1fr; }
    .footer-grid > section:first-child { grid-column: 1 / -1; }
    .instagram-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 980px) {
    .site-nav--desktop { display: none; }
    .site-header__mobile-toggle { display: flex; }
    .site-header__actions--right { margin-left: auto; }

    .home-hero__inner {
        min-height: 560px;
        padding-top: 72px;
        padding-bottom: 40px;
    }

    .editorial-moment,
    .editorial-moment--reverse { grid-template-columns: 1fr; }
    .editorial-moment--reverse .editorial-moment__media { order: 0; }

    .trust-strip { grid-template-columns: 1fr 1fr; }

    .checkout-page,
    .cart-page { grid-template-columns: 1fr; }

    .cart-page__summary,
    .checkout-summary { position: static; }

    .product-hero { grid-template-columns: 1fr; }

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

    .collection-filters { display: none; }

    .collection-filters.is-mobile-open {
        display: flex;
        position: fixed;
        inset: 0;
        z-index: 95;
        background: var(--color-background);
        padding: 24px;
        overflow-y: auto;
    }

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

@media (max-width: 720px) {
    .product-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
    .home-carousel__track .product-card { flex-basis: min(76vw, 320px); }
    .instagram-section__meta { flex-direction: column; align-items: flex-start; }
    .instagram-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .category-tile-grid { gap: 10px; }
    .trust-strip { grid-template-columns: 1fr; padding: 24px 0; gap: 24px; }
    .footer-grid { grid-template-columns: 1fr; gap: 24px; }
    .footer-grid > section:first-child { grid-column: auto; }

    .product-card__body { padding: 12px; }
    .product-card__title { font-size: 0.95rem; }

    .checkout-grid--two,
    .checkout-grid--three { grid-template-columns: 1fr; }
    .checkout-express__buttons { grid-template-columns: 1fr; }

    .cart-item { grid-template-columns: 80px 1fr; }
    .cart-item__price { grid-column: 1 / -1; text-align: left; }

    .home-hero__copy { padding: 0 20px; }
    .home-hero__heading { font-size: clamp(2.5rem, 12vw, 4rem); }
    .home-hero__actions .button { flex: 1; }
}

@media (max-width: 540px) {
    .product-card__quickadd-label { display: none; }

    .icon-link__label { display: none; }
    .icon-link { padding: 0 8px; }

    .site-header__inner { padding: 14px 0; }
    .site-logo { font-size: 1.3rem; letter-spacing: 0.16em; }
}

@media (min-width: 981px) {
    .site-header__inner {
        --header-gutter: clamp(18px, 2.8vw, 42px);
        display: grid;
        grid-template-columns: 1fr auto 1fr;
        align-items: center;
        gap: 28px;
        min-height: 92px;
        padding: 18px 0 16px;
        position: relative;
    }

    .site-header__mobile-toggle { display: none; }

    .site-header__actions--right {
        justify-self: end;
        gap: 10px;
        margin-right: var(--header-gutter);
    }

    body.is-homepage .site-header {
        position: absolute;
        top: var(--announcement-height);
        left: 0;
        right: 0;
        background: transparent;
        border-bottom: none;
        z-index: 85;
    }

    body.is-homepage .site-header__inner {
        border-bottom: none;
    }

    body.is-homepage .site-header__inner::after {
        content: "";
        position: absolute;
        left: var(--header-gutter);
        right: var(--header-gutter);
        bottom: 0;
        height: 1px;
        background: rgba(255, 255, 255, 0.24);
    }

    body.is-homepage .site-logo,
    body.is-homepage .site-nav--desktop > a,
    body.is-homepage .site-nav--desktop > .nav-item > a,
    body.is-homepage .icon-link {
        color: var(--color-text-on-dark);
    }

    body.is-homepage .site-logo:hover,
    body.is-homepage .site-nav--desktop > a:hover,
    body.is-homepage .site-nav--desktop > .nav-item > a:hover,
    body.is-homepage .icon-link:hover,
    body.is-homepage .icon-link:focus-visible {
        color: var(--color-text-on-dark);
        background: transparent;
    }

    body.is-homepage .site-nav--desktop > a::after,
    body.is-homepage .site-nav--desktop > .nav-item > a::after {
        background: rgba(255, 255, 255, 0.75);
    }

    body.is-homepage .icon-link__count {
        background: rgba(255, 255, 255, 0.18);
        color: var(--color-text-on-dark);
        border: 1px solid rgba(255, 255, 255, 0.24);
    }

    body.is-homepage .home-hero__inner {
        padding-top: clamp(170px, 20vw, 260px);
    }

    body.is-homepage .container.home-hero__inner {
        max-width: none;
        padding-left: 0;
        padding-right: 0;
    }
}

@media print {
    .site-header,
    .site-footer,
    .announcement-bar,
    .menu-drawer,
    .filter-drawer,
    .search-drawer,
    .site-toast { display: none !important; }
    body { background: #fff; color: #000; }
}
