/* =============================================================
 The FloorHaus™. Stylesheet
 Reference DNA: maze.me. Cream / graphite / restrained editorial
 ============================================================= */

:root {
 /* Brand palette */
 --c-cream: #F5F2EB;
 --c-cream-deep: #ECE7DA;
 --c-graphite: #1A1A1A;
 --c-graphite-90: rgba(26,26,26,.9);
 --c-grey: #666666;
 --c-grey-light: #B8B3A6;
 --c-walnut: #6B5B3E;
 --c-sale: #A0432B;
 --c-white: #FFFFFF;

 /* Typography */
 --f-serif: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
 --f-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Helvetica, Arial, sans-serif;

 /* Layout */
 --container: 1280px;
 --container-wide: 1440px;
 --section-py: 96px;
 --section-py-mob: 48px;
 --header-h: 80px;
 --utility-h: 30px;

 /* Motion */
 --ease: cubic-bezier(.22,.61,.36,1);
}

/* ----- Reset / Base ----- */
*, *::before, *::after { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }

body {
 background: var(--c-cream);
 color: var(--c-graphite);
 font-family: var(--f-sans);
 font-size: 16px;
 line-height: 1.6;
 font-weight: 400;
 -webkit-font-smoothing: antialiased;
 -moz-osx-font-smoothing: grayscale;
}

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

a { color: inherit; text-decoration: none; transition: color .2s var(--ease), opacity .2s var(--ease); }
a:hover { color: var(--c-walnut); }

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

ul { list-style: none; padding: 0; margin: 0; }

p { margin: 0 0 1em; }

/* ----- Layout helpers ----- */
.container { max-width: var(--container); margin: 0 auto; padding: 0 32px; }
.container--wide { max-width: var(--container-wide); }

@media (max-width: 768px) {
 .container { padding: 0 20px; }
}

.section {
 padding: var(--section-py) 0;
}
@media (max-width: 768px) {
 .section { padding: var(--section-py-mob) 0; }
}

/* Eyebrows / section heads */
.eyebrow {
 display: inline-block;
 font-family: var(--f-sans);
 font-size: 12px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-graphite);
}
.eyebrow--light { color: var(--c-cream); }

.section-head {
 text-align: center;
 margin: 0 auto 56px;
 max-width: 720px;
}
.section-head--centred { text-align: center; }
.section-head__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 4vw, 40px);
 line-height: 1.15;
 margin: 14px 0 0;
 letter-spacing: 0;
}

.section-foot {
 text-align: center;
 margin-top: 48px;
}

.text-link {
 font-family: var(--f-sans);
 font-size: 13px;
 font-weight: 500;
 letter-spacing: 0.12em;
 text-transform: uppercase;
 color: var(--c-graphite);
 border-bottom: 1px solid currentColor;
 padding-bottom: 4px;
 display: inline-flex;
 align-items: center;
 gap: 8px;
}
.text-link:hover { color: var(--c-walnut); }
.text-link--small { font-size: 11px; letter-spacing: 0.14em; border-bottom: 0; }

/* Buttons */
.btn {
 display: inline-flex;
 align-items: center;
 justify-content: center;
 font-family: var(--f-sans);
 font-size: 12px;
 font-weight: 500;
 letter-spacing: 0.14em;
 text-transform: uppercase;
 padding: 16px 28px;
 border-radius: 0;
 border: 1px solid transparent;
 cursor: pointer;
 transition: background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease);
 min-height: 48px;
}
.btn--primary { background: var(--c-graphite); color: var(--c-cream); }
.btn--primary:hover { background: var(--c-walnut); color: var(--c-cream); }
.btn--ghost-light { background: transparent; color: var(--c-cream); border-color: var(--c-cream); }
.btn--ghost-light:hover { background: var(--c-cream); color: var(--c-graphite); }
.btn--full { width: 100%; }

/* =================================================================
 UTILITY BAR
 ================================================================= */
.utility-bar {
 background: var(--c-graphite);
 color: var(--c-cream);
 height: var(--utility-h);
 display: flex;
 align-items: center;
 justify-content: center;
 position: sticky;
 top: 0;
 z-index: 60;
 font-size: 12px;
 letter-spacing: 0.04em;
}
.utility-bar__inner {
 display: flex;
 align-items: center;
 gap: 18px;
 padding: 0 16px;
 max-width: 800px;
 width: 100%;
 justify-content: center;
}
.utility-bar__messages {
 position: relative;
 height: var(--utility-h);
 flex: 1;
 display: flex;
 align-items: center;
 justify-content: center;
 text-align: center;
 overflow: hidden;
}
.utility-bar__message {
 position: absolute;
 inset: 0;
 display: flex;
 align-items: center;
 justify-content: center;
 opacity: 0;
 transform: translateY(8px);
 transition: opacity .5s var(--ease), transform .5s var(--ease);
 pointer-events: none;
 white-space: nowrap;
 padding: 0 8px;
}
.utility-bar__message.is-active {
 opacity: 1;
 transform: translateY(0);
}
.utility-bar__nav {
 width: 24px;
 height: 24px;
 border-radius: 50%;
 color: var(--c-cream);
 font-size: 18px;
 line-height: 1;
 display: inline-flex;
 align-items: center;
 justify-content: center;
 transition: opacity .2s var(--ease);
 opacity: .7;
}
.utility-bar__nav:hover { opacity: 1; }

/* =================================================================
 HEADER
 ================================================================= */
.site-header {
 background: var(--c-cream);
 position: sticky;
 top: var(--utility-h);
 z-index: 50;
 transition: box-shadow .25s var(--ease), background .25s var(--ease);
}
.site-header.is-stuck {
 box-shadow: 0 1px 0 rgba(26,26,26,.06);
}

.site-header__inner {
 height: var(--header-h);
 max-width: var(--container);
 margin: 0 auto;
 padding: 0 32px;
 display: grid;
 grid-template-columns: auto 1fr auto;
 align-items: center;
 gap: 32px;
}
@media (max-width: 1024px) {
 .site-header__inner { padding: 0 20px; gap: 16px; }
}

.logo { display: inline-flex; align-items: center; color: var(--c-graphite); }
.logo__mark { height: 48px; width: auto; max-width: none; display: block; flex-shrink: 0; }

@media (max-width: 480px) {
 .logo__mark { height: 40px; }
}

/* Primary nav */
.primary-nav { justify-self: center; }
.primary-nav__list {
 display: flex;
 align-items: center;
 gap: 26px;
}
.primary-nav__link {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-graphite);
 padding: 8px 0;
 position: relative;
 white-space: nowrap;
}
.primary-nav__link::after {
 content: '';
 position: absolute;
 left: 0; right: 0; bottom: 2px;
 height: 1px;
 background: currentColor;
 transform: scaleX(0);
 transform-origin: left;
 transition: transform .25s var(--ease);
}
.primary-nav__link:hover::after,
.primary-nav__item--has-mega:hover .primary-nav__link::after { transform: scaleX(1); }

@media (max-width: 1180px) {
 .primary-nav__list { gap: 18px; }
 .primary-nav__link { font-size: 10px; letter-spacing: 0.14em; }
}
@media (max-width: 1024px) {
 .primary-nav { display: none; }
}

/* Mega menu */
.primary-nav__item--has-mega { position: static; }
.mega-menu {
 position: absolute;
 left: 0; right: 0;
 top: 100%;
 background: var(--c-cream);
 box-shadow: 0 12px 24px -16px rgba(26,26,26,.18);
 visibility: hidden;
 opacity: 0;
 transform: translateY(-4px);
 transition: opacity .2s var(--ease), transform .2s var(--ease), visibility .2s var(--ease);
 z-index: 40;
 border-top: 1px solid rgba(26,26,26,.06);
}
.primary-nav__item--has-mega:hover .mega-menu,
.mega-menu:hover,
.mega-menu.is-open {
 visibility: visible; opacity: 1; transform: translateY(0);
}
.mega-menu__inner {
 max-width: var(--container);
 margin: 0 auto;
 padding: 48px 32px;
 display: grid;
 grid-template-columns: 1fr 1fr;
 gap: 80px;
}
.mega-menu__col { display: flex; flex-direction: column; gap: 16px; }
.mega-menu__label {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-grey);
 margin-bottom: 8px;
}
.mega-menu__link {
 font-family: var(--f-sans);
 font-size: 12px;
 font-weight: 500;
 letter-spacing: 0.14em;
 text-transform: uppercase;
 color: var(--c-graphite);
 display: inline-flex;
 align-items: center;
 gap: 10px;
 text-align: left;
}
.mega-menu__link--toggle { color: var(--c-graphite); }
.mega-menu__sub { position: relative; }
.mega-menu__sublist {
 display: flex;
 flex-direction: column;
 gap: 10px;
 margin: 12px 0 0 0;
 padding-left: 16px;
 border-left: 1px solid rgba(26,26,26,.1);
}
.mega-menu__sublist a {
 font-family: var(--f-sans);
 font-size: 13px;
 color: var(--c-grey);
}
.mega-menu__sublist a:hover { color: var(--c-graphite); }
.mega-menu__chev { font-size: 14px; }

.mega-menu__collection {
 font-family: var(--f-serif);
 font-size: 32px;
 line-height: 1.1;
 color: var(--c-graphite);
 font-weight: 400;
 transition: color .2s var(--ease), transform .2s var(--ease);
 display: inline-block;
}
.mega-menu__collection:hover { color: var(--c-walnut); transform: translateX(4px); }

/* Products list (replaces collections list in main nav) */
.mega-menu__col--products { gap: 4px; }
.mega-menu__product {
 display: flex;
 align-items: center;
 gap: 16px;
 padding: 12px 0;
 border-bottom: 1px solid rgba(26,26,26,.08);
 transition: padding .25s var(--ease), border-color .2s var(--ease);
}
.mega-menu__product:last-child { border-bottom: 0; }
.mega-menu__product:hover { padding-left: 6px; border-bottom-color: var(--c-walnut); }
.mega-menu__product-thumb {
 flex-shrink: 0;
 width: 64px;
 height: 64px;
 overflow: hidden;
 background: var(--c-cream-deep);
}
.mega-menu__product-thumb img {
 width: 100%;
 height: 100%;
 object-fit: cover;
 transition: transform .4s var(--ease);
}
.mega-menu__product:hover .mega-menu__product-thumb img { transform: scale(1.06); }
.mega-menu__product-text { flex: 1; }
.mega-menu__product-name {
 display: block;
 font-family: var(--f-sans);
 font-size: 14px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 color: var(--c-graphite);
 margin-bottom: 4px;
}
.mega-menu__product-desc {
 display: block;
 font-family: var(--f-sans);
 font-size: 13px;
 color: var(--c-grey);
 letter-spacing: 0;
 text-transform: none;
 font-weight: 400;
}
.mega-menu__product:hover .mega-menu__product-name { color: var(--c-walnut); }

/* Header utils */
.header-utils {
 display: flex;
 align-items: center;
 gap: 8px;
 justify-self: end;
 color: var(--c-graphite);
}
.header-utils__btn {
 width: 40px; height: 40px;
 display: inline-flex; align-items: center; justify-content: center;
 border-radius: 50%;
 transition: background .2s var(--ease);
}
.header-utils__btn:hover { background: rgba(26,26,26,.06); }
.header-utils__btn--whatsapp { color: #25D366; }
.header-utils__btn--mobile { display: none; }

@media (max-width: 1024px) {
 .header-utils__btn--mobile { display: inline-flex; }
}

/* Mobile drawer */
.mobile-drawer {
 position: fixed;
 inset: calc(var(--utility-h) + var(--header-h)) 0 0 0;
 background: var(--c-cream);
 padding: 32px 20px;
 z-index: 45;
 overflow-y: auto;
}
.mobile-drawer__list {
 display: flex; flex-direction: column;
 gap: 4px;
}
.mobile-drawer__list a {
 display: block;
 padding: 16px 4px;
 font-family: var(--f-sans);
 font-size: 14px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 border-bottom: 1px solid rgba(26,26,26,.08);
}

/* =================================================================
 HERO
 ================================================================= */
.hero {
 position: relative;
 background: var(--c-cream-deep);
}
.hero__carousel {
 position: relative;
 height: calc(100vh - var(--utility-h) - var(--header-h));
 min-height: 560px;
 max-height: 820px;
 overflow: hidden;
}
.hero__slide {
 position: absolute;
 inset: 0;
 opacity: 0;
 transition: opacity .9s var(--ease);
 pointer-events: none;
}
.hero__slide.is-active { opacity: 1; pointer-events: auto; }
.hero__image {
 width: 100%; height: 100%;
 object-fit: cover;
 object-position: center;
}
.hero__overlay {
 position: absolute;
 inset: 0;
 background: linear-gradient(180deg, rgba(26,26,26,0) 40%, rgba(26,26,26,.45) 100%);
}
.hero__content {
 position: absolute;
 left: 0; right: 0; bottom: 12%;
 padding: 0 32px;
 text-align: center;
 color: var(--c-cream);
 text-shadow: 0 1px 12px rgba(26,26,26,.4);
}
@media (max-width: 768px) {
 .hero__content { bottom: 10%; padding: 0 20px; }
}
.hero__rule {
 display: block;
 width: 40px;
 height: 2px;
 background: var(--c-cream);
 margin: 0 auto 20px;
}
.hero__headline {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(36px, 6vw, 72px);
 line-height: 1.05;
 letter-spacing: 0;
 margin: 0 0 18px;
 color: #fff;
}
.hero__sub {
 font-family: var(--f-sans);
 font-size: clamp(15px, 1.4vw, 18px);
 line-height: 1.55;
 margin: 0 auto 28px;
 max-width: 560px;
 font-weight: 400;
}
.hero__cta {
 display: inline-flex;
 align-items: center;
 gap: 10px;
 font-family: var(--f-sans);
 font-size: 12px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 color: var(--c-cream);
 border-bottom: 1px solid currentColor;
 padding-bottom: 4px;
}
.hero__cta:hover { color: #fff; }

/* Dots */
.hero__dots {
 position: absolute;
 bottom: 32px; left: 0; right: 0;
 display: flex;
 justify-content: center;
 gap: 10px;
}
.hero__dot {
 width: 8px; height: 8px;
 border-radius: 50%;
 background: rgba(245,242,235,.4);
 transition: background .2s var(--ease), transform .2s var(--ease);
}
.hero__dot.is-active { background: var(--c-cream); transform: scale(1.2); }

/* =================================================================
 CARD GRID
 ================================================================= */
.card-grid {
 display: grid;
 gap: 32px;
}
.card-grid--4 { grid-template-columns: repeat(4, 1fr); }
.card-grid--3 { grid-template-columns: repeat(3, 1fr); }

@media (max-width: 1024px) {
 .card-grid--4 { grid-template-columns: repeat(2, 1fr); gap: 24px; }
 .card-grid--3 { grid-template-columns: repeat(2, 1fr); gap: 24px; }
}
@media (max-width: 540px) {
 .card-grid--4 { grid-template-columns: repeat(1, 1fr); }
 .card-grid--3 { grid-template-columns: repeat(1, 1fr); }
}

/* Collection card (1:1) */
.collection-card { display: block; color: var(--c-graphite); }
.collection-card__media {
 position: relative;
 aspect-ratio: 1 / 1;
 background: var(--c-cream-deep);
 overflow: hidden;
}
.collection-card__media img {
 width: 100%; height: 100%;
 object-fit: cover;
 transition: transform .8s var(--ease);
}
.collection-card:hover .collection-card__media img { transform: scale(1.04); }
.collection-card__title {
 font-family: var(--f-sans);
 font-size: 12px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 margin: 18px 0 6px;
}
.collection-card__sub {
 font-size: 14px;
 color: var(--c-grey);
 margin: 0;
}

/* Material card (3:4) */
.material-card { display: block; color: var(--c-graphite); }
.material-card__media {
 position: relative;
 aspect-ratio: 3 / 4;
 background: var(--c-cream-deep);
 overflow: hidden;
}
.material-card__media img {
 width: 100%; height: 100%;
 object-fit: cover;
 transition: transform .8s var(--ease);
}
.material-card:hover .material-card__media img { transform: scale(1.04); }
.material-card__title {
 font-family: var(--f-sans);
 font-size: 13px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 margin: 20px 0 8px;
}
.material-card__price {
 font-family: var(--f-sans);
 font-size: 14px;
 color: var(--c-grey);
 margin: 0 0 14px;
}
.material-card__price strong {
 color: var(--c-graphite);
 font-weight: 500;
}

/* Room card (3:4 with hover overlay) */
.room-card {
 position: relative;
 display: block;
 color: var(--c-cream);
 overflow: hidden;
}
.room-card__media {
 position: relative;
 aspect-ratio: 3 / 4;
 overflow: hidden;
 background: var(--c-cream-deep);
}
.room-card__media::after {
 content: '';
 position: absolute;
 inset: 0;
 background: linear-gradient(180deg, rgba(26,26,26,0) 50%, rgba(26,26,26,.55) 100%);
 transition: background .35s var(--ease);
}
.room-card:hover .room-card__media::after {
 background: linear-gradient(180deg, rgba(26,26,26,.1) 0%, rgba(26,26,26,.65) 100%);
}
.room-card__media img {
 width: 100%; height: 100%; object-fit: cover;
 transition: transform .8s var(--ease);
}
.room-card:hover .room-card__media img { transform: scale(1.05); }
.room-card__label {
 position: absolute;
 left: 24px; bottom: 24px;
 font-family: var(--f-sans);
 font-size: 12px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 color: #fff;
 z-index: 2;
 transition: transform .35s var(--ease), opacity .35s var(--ease);
}
.room-card__hover {
 position: absolute;
 left: 24px; bottom: 24px;
 font-family: var(--f-sans);
 font-size: 12px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: #fff;
 z-index: 3;
 display: inline-flex;
 align-items: center;
 gap: 8px;
 opacity: 0;
 transform: translateY(8px);
 transition: opacity .35s var(--ease), transform .35s var(--ease);
 border-bottom: 1px solid currentColor;
 padding-bottom: 4px;
}
.room-card:hover .room-card__label { opacity: 0; transform: translateY(-8px); }
.room-card:hover .room-card__hover { opacity: 1; transform: translateY(0); }

/* =================================================================
 VISUALISER (Beta room photo upload + colour picker)
 ================================================================= */
.section--visualiser {
 background: var(--c-cream-deep);
 padding: var(--section-py) 0;
}
.section--visualiser .section-head { margin-bottom: 56px; }
.section-head__lede {
 max-width: 640px;
 margin: 18px auto 0;
 font-size: 17px;
 line-height: 1.55;
 color: var(--c-grey);
}
.eyebrow--badge {
 display: inline-block;
 padding: 6px 14px;
 border: 1px solid rgba(26,26,26,.2);
 border-radius: 999px;
 background: var(--c-cream);
 color: var(--c-graphite);
}

.visualiser {
 max-width: 1100px;
 margin: 0 auto;
}

.visualiser__steps {
 display: flex;
 justify-content: center;
 gap: 48px;
 list-style: none;
 padding: 0;
 margin: 0 0 40px;
 flex-wrap: wrap;
}
.visualiser__step {
 display: inline-flex;
 align-items: center;
 gap: 12px;
 font-family: var(--f-sans);
 font-size: 13px;
 color: var(--c-grey);
 letter-spacing: 0.02em;
}
.visualiser__step-num {
 font-family: var(--f-serif);
 font-size: 22px;
 font-style: italic;
 color: var(--c-walnut);
 line-height: 1;
}

.visualiser__panel {
 display: grid;
 grid-template-columns: 1fr 1fr;
 gap: 24px;
 margin-bottom: 32px;
}
@media (max-width: 860px) {
 .visualiser__panel { grid-template-columns: 1fr; }
}

.visualiser__col {
 background: var(--c-white);
 border: 1px solid rgba(26,26,26,.06);
 border-radius: 10px;
 padding: 28px;
 display: flex;
 flex-direction: column;
}
.visualiser__col-label {
 font-family: var(--f-sans);
 font-size: 11px;
 letter-spacing: 0.22em;
 text-transform: uppercase;
 color: var(--c-grey);
 margin-bottom: 18px;
}

/* Dropzone */
.dropzone {
 position: relative;
 display: flex;
 flex: 1;
 min-height: 280px;
 border: 1.5px dashed rgba(26,26,26,.2);
 border-radius: 8px;
 cursor: pointer;
 transition: border-color .25s var(--ease), background .25s var(--ease);
 background: var(--c-cream);
 overflow: hidden;
}
.dropzone:hover,
.dropzone.is-dragover {
 border-color: var(--c-walnut);
 background: rgba(107,91,62,.04);
}
.dropzone__placeholder {
 flex: 1;
 display: flex;
 flex-direction: column;
 align-items: center;
 justify-content: center;
 text-align: center;
 padding: 24px;
 color: var(--c-graphite);
}
.dropzone__placeholder[hidden],
.dropzone__preview[hidden] { display: none; }
.dropzone__placeholder svg { color: var(--c-walnut); margin-bottom: 14px; }
.dropzone__title {
 font-family: var(--f-serif);
 font-size: 22px;
 font-weight: 500;
 margin: 0 0 6px;
}
.dropzone__sub {
 font-size: 14px;
 color: var(--c-grey);
 margin: 0 0 14px;
}
.dropzone__meta {
 font-size: 12px;
 color: var(--c-grey-light);
 letter-spacing: 0.04em;
 margin: 0;
}
.dropzone__preview {
 position: relative;
 flex: 1;
 display: flex;
 align-items: center;
 justify-content: center;
 padding: 0;
}
.dropzone__preview img {
 width: 100%;
 height: 100%;
 object-fit: cover;
 display: block;
}
.dropzone__remove {
 position: absolute;
 bottom: 12px;
 right: 12px;
 background: rgba(26,26,26,.85);
 color: var(--c-cream);
 border: none;
 padding: 8px 14px;
 font-family: var(--f-sans);
 font-size: 11px;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 cursor: pointer;
 border-radius: 4px;
 transition: background .2s var(--ease);
}
.dropzone__remove:hover { background: var(--c-graphite); }

.dropzone__working {
 position: absolute;
 inset: 0;
 display: flex;
 flex-direction: column;
 align-items: center;
 justify-content: center;
 background: rgba(245, 242, 235, 0.92);
 backdrop-filter: blur(2px);
 -webkit-backdrop-filter: blur(2px);
 gap: 14px;
}
.dropzone__working[hidden] { display: none; }
.dropzone__spinner {
 width: 36px;
 height: 36px;
 border-radius: 50%;
 border: 2.5px solid rgba(26,26,26,.18);
 border-top-color: var(--c-walnut);
 animation: viz-spin 0.9s linear infinite;
}
@keyframes viz-spin { to { transform: rotate(360deg); } }
.dropzone__working-text {
 font-family: var(--f-sans);
 font-size: 13px;
 color: var(--c-grey);
 letter-spacing: 0.04em;
 margin: 0;
}
.dropzone__error {
 position: absolute;
 left: 12px; right: 12px; bottom: 12px;
 background: var(--c-sale);
 color: var(--c-cream);
 padding: 8px 14px;
 border-radius: 6px;
 font-size: 12px;
 letter-spacing: 0.02em;
 margin: 0;
 box-shadow: 0 4px 12px rgba(0,0,0,.12);
}
.dropzone__error[hidden] { display: none; }

/* Viz picker */
.viz-picker { margin-bottom: 22px; flex: 1; }
.viz-picker__label,
.viz-style__label {
 display: block;
 font-family: var(--f-sans);
 font-size: 13px;
 font-weight: 500;
 color: var(--c-graphite);
 margin-bottom: 12px;
}
.viz-picker__swatches {
 display: grid;
 grid-template-columns: repeat(4, 1fr);
 gap: 8px;
}
.viz-picker__loading {
 grid-column: 1 / -1;
 text-align: center;
 color: var(--c-grey);
 font-size: 13px;
 margin: 0;
 padding: 24px 0;
}
.viz-swatch {
 position: relative;
 aspect-ratio: 1;
 padding: 0;
 border: none;
 background: none;
 cursor: pointer;
 border-radius: 4px;
 overflow: hidden;
 outline: 2px solid transparent;
 outline-offset: 2px;
 transition: outline-color .2s var(--ease), transform .25s var(--ease);
}
.viz-swatch__img {
 width: 100%;
 height: 100%;
 object-fit: cover;
 display: block;
}
.viz-swatch__name {
 position: absolute;
 left: 0; right: 0; bottom: 0;
 padding: 4px 6px;
 background: linear-gradient(180deg, rgba(26,26,26,0) 0%, rgba(26,26,26,.75) 100%);
 color: var(--c-cream);
 font-size: 10px;
 letter-spacing: 0.06em;
 text-transform: uppercase;
 font-weight: 500;
 opacity: 0;
 transition: opacity .2s var(--ease);
}
.viz-swatch:hover { transform: translateY(-1px); }
.viz-swatch:hover .viz-swatch__name { opacity: 1; }
.viz-swatch.is-active {
 outline-color: var(--c-graphite);
}
.viz-swatch.is-active .viz-swatch__name { opacity: 1; }

/* Viz style toggle */
.viz-style__options {
 display: inline-flex;
 background: var(--c-cream);
 padding: 4px;
 border-radius: 999px;
 gap: 2px;
}
.viz-style__opt {
 padding: 8px 18px;
 border: none;
 background: transparent;
 color: var(--c-graphite);
 font-family: var(--f-sans);
 font-size: 13px;
 font-weight: 500;
 border-radius: 999px;
 cursor: pointer;
 transition: background .2s var(--ease), color .2s var(--ease);
}
.viz-style__opt:hover { color: var(--c-walnut); }
.viz-style__opt.is-active {
 background: var(--c-graphite);
 color: var(--c-cream);
}
.viz-style__opt.is-active:hover { color: var(--c-cream); }

/* CTA block */
.visualiser__cta {
 text-align: center;
 padding-top: 8px;
}
.visualiser__summary {
 font-family: var(--f-serif);
 font-style: italic;
 font-size: 18px;
 color: var(--c-graphite);
 margin: 0 0 18px;
 min-height: 28px;
}
.visualiser__beta-note {
 font-size: 12px;
 color: var(--c-grey);
 letter-spacing: 0.02em;
 margin: 16px auto 0;
 max-width: 520px;
}

.btn--lg {
 padding: 16px 36px;
 font-size: 14px;
 letter-spacing: 0.18em;
}
.btn--primary[disabled] {
 opacity: 0.4;
 cursor: not-allowed;
}

/* =================================================================
 TRUST STRIP
 ================================================================= */
.trust-strip {
 background: var(--c-cream);
 padding: 36px 0;
 border-top: 1px solid rgba(26,26,26,.08);
 border-bottom: 1px solid rgba(26,26,26,.08);
}
.trust-strip__list {
 display: grid;
 grid-template-columns: repeat(4, 1fr);
 gap: 32px;
 align-items: center;
}
.trust-item {
 display: flex;
 align-items: center;
 gap: 14px;
}
.trust-item__icon {
 width: 28px; height: 28px;
 flex-shrink: 0;
 color: var(--c-graphite);
}
.trust-item strong {
 display: block;
 font-family: var(--f-sans);
 font-size: 13px;
 font-weight: 500;
 letter-spacing: 0.1em;
 text-transform: uppercase;
 color: var(--c-graphite);
 margin-bottom: 2px;
}
.trust-item span {
 font-size: 13px;
 color: var(--c-grey);
}
@media (max-width: 768px) {
 .trust-strip__list { grid-template-columns: 1fr; gap: 18px; }
}

/* Trust item as CTA (used by Request a Sample) */
.trust-item--cta { padding: 0; }
.trust-item__btn {
 display: flex;
 align-items: center;
 gap: 14px;
 padding: 12px 14px;
 margin: -12px -14px;
 border-radius: 0;
 text-align: left;
 cursor: pointer;
 transition: background .2s var(--ease), color .2s var(--ease);
 font: inherit;
 color: inherit;
 background: transparent;
 border: 0;
}
.trust-item__btn:hover { background: var(--c-cream-deep); color: var(--c-walnut); }
.trust-item__btn:hover .trust-item__icon { color: var(--c-walnut); }
.trust-item__text { display: block; }

/* Btn variants */
.btn--ghost-dark {
 background: transparent;
 color: var(--c-graphite);
 border-color: var(--c-graphite);
}
.btn--ghost-dark:hover {
 background: var(--c-graphite);
 color: var(--c-cream);
 border-color: var(--c-graphite);
}

/* Wider modal for sample picker */
.modal__panel--wide {
 max-width: 720px;
 padding: 36px 36px;
}
@media (max-width: 540px) {
 .modal__panel--wide { padding: 28px 20px; }
}

/* ============== SAMPLE PICKER ============== */
.sample-form { display: flex; flex-direction: column; gap: 18px; }
.sample-form__colours {
 border: 0;
 padding: 0;
 margin: 0;
}
.sample-form__legend {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-graphite);
 margin-bottom: 12px;
 padding: 0;
}
.sample-picker {
 display: grid;
 grid-template-columns: repeat(6, 1fr);
 gap: 8px;
}
@media (max-width: 640px) {
 .sample-picker { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 420px) {
 .sample-picker { grid-template-columns: repeat(3, 1fr); }
}
.sample-picker__loading {
 grid-column: 1 / -1;
 text-align: center;
 font-size: 13px;
 color: var(--c-grey);
 padding: 24px 0;
 margin: 0;
}
.sample-chip {
 display: block;
 position: relative;
 cursor: pointer;
 text-align: center;
}
.sample-chip input {
 position: absolute;
 opacity: 0;
 pointer-events: none;
}
.sample-chip__media {
 display: block;
 width: 100%;
 aspect-ratio: 1 / 1;
 background-size: cover;
 background-position: center;
 background-color: var(--c-cream-deep);
 border: 2px solid transparent;
 outline-offset: 1px;
 transition: border-color .2s var(--ease), transform .2s var(--ease);
 position: relative;
}
.sample-chip__media::after {
 content: "";
 position: absolute;
 inset: 0;
 background: rgba(26,26,26,0);
 transition: background .2s var(--ease);
}
.sample-chip:hover .sample-chip__media { transform: scale(1.02); }
.sample-chip input:checked + .sample-chip__media {
 border-color: var(--c-graphite);
}
.sample-chip input:checked + .sample-chip__media::after {
 background: rgba(26,26,26,.18);
}
.sample-chip__check {
 position: absolute;
 top: 6px; right: 6px;
 width: 22px; height: 22px;
 border-radius: 50%;
 background: var(--c-graphite);
 color: var(--c-cream);
 display: flex;
 align-items: center;
 justify-content: center;
 font-size: 14px;
 line-height: 1;
 opacity: 0;
 transform: scale(.7);
 transition: opacity .2s var(--ease), transform .2s var(--ease);
 z-index: 1;
}
.sample-chip input:checked ~ .sample-chip__check {
 opacity: 1;
 transform: scale(1);
}
.sample-chip__name {
 display: block;
 font-family: var(--f-sans);
 font-size: 10px;
 font-weight: 500;
 letter-spacing: 0.14em;
 text-transform: uppercase;
 color: var(--c-graphite);
 margin-top: 6px;
 line-height: 1.3;
}
.sample-form__count {
 font-size: 12px;
 color: var(--c-grey);
 margin: 12px 0 0;
}
.sample-form__count.is-active { color: var(--c-graphite); font-weight: 500; }
.sample-form__actions {
 display: flex;
 flex-direction: column;
 gap: 8px;
 padding-top: 4px;
}
.sample-form__or {
 text-align: center;
 font-size: 11px;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-grey);
 margin: 4px 0;
 position: relative;
}
.sample-form__or span {
 background: var(--c-cream);
 padding: 0 12px;
 position: relative;
 z-index: 1;
}
.sample-form__or::before {
 content: "";
 position: absolute;
 left: 0; right: 0; top: 50%;
 height: 1px;
 background: rgba(26,26,26,.12);
}

/* =================================================================
 EDITORIAL / FOUNDERS
 ================================================================= */
.editorial {
 display: grid;
 grid-template-columns: 1fr 1fr;
 gap: 80px;
 align-items: center;
}
.editorial__media {
 aspect-ratio: 4 / 5;
 overflow: hidden;
 background: var(--c-cream-deep);
}
.editorial__media img { width: 100%; height: 100%; object-fit: cover; }
.editorial__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 3.4vw, 44px);
 line-height: 1.15;
 margin: 12px 0 24px;
}
.editorial__text {
 font-size: 17px;
 line-height: 1.7;
 color: var(--c-graphite);
 margin-bottom: 28px;
 max-width: 520px;
}
@media (max-width: 1024px) {
 .editorial { grid-template-columns: 1fr; gap: 32px; }
}

/* =================================================================
 SERVICES (Installation + Wrapping)
 ================================================================= */
.services-block {
 display: grid;
 grid-template-columns: 1fr auto 1fr;
 gap: 48px;
 align-items: center;
 padding: 56px 0;
 border-top: 1px solid var(--c-walnut);
 border-bottom: 1px solid var(--c-walnut);
}
.services-block__col {
 text-align: center;
 max-width: 460px;
 margin: 0 auto;
}
.services-block__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(26px, 3vw, 36px);
 line-height: 1.15;
 margin: 0 0 16px;
}
.services-block__body {
 font-size: 16px;
 color: var(--c-graphite);
 margin-bottom: 24px;
 line-height: 1.6;
}
.services-block__divider {
 width: 1px;
 height: 100px;
 background: var(--c-walnut);
 opacity: .4;
}
@media (max-width: 768px) {
 .services-block { grid-template-columns: 1fr; gap: 32px; }
 .services-block__divider { display: none; }
}
.services-block__actions,
.trade-block__actions {
 display: inline-flex;
 align-items: center;
 gap: 12px;
 flex-wrap: wrap;
 justify-content: center;
}
.btn--whatsapp {
 display: inline-flex;
 align-items: center;
 gap: 8px;
 background: #25D366;
 color: #FFFFFF;
 border: none;
 padding: 14px 22px;
 font-family: var(--f-sans);
 font-size: 13px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 text-decoration: none;
 cursor: pointer;
 transition: background .2s var(--ease), transform .2s var(--ease);
}
.btn--whatsapp:hover { background: #1FB855; transform: translateY(-1px); }
.btn--whatsapp svg { flex-shrink: 0; }

/* Colour detail pre-order banner */
.colour-preorder {
 background: var(--c-graphite);
 color: var(--c-cream);
 padding: 72px 0;
}
.colour-preorder__inner {
 display: grid;
 grid-template-columns: 1.2fr 1fr;
 gap: 48px;
 align-items: center;
}
.colour-preorder .eyebrow--light { color: rgba(245,242,235,.8); }
.colour-preorder__title {
 font-family: var(--f-serif);
 font-size: 40px;
 font-weight: 500;
 line-height: 1.1;
 margin: 14px 0 16px;
 color: var(--c-cream);
}
.colour-preorder__sub {
 font-size: 16px;
 line-height: 1.6;
 color: rgba(245,242,235,.85);
 margin: 0;
 max-width: 540px;
}
.colour-preorder__actions {
 display: flex;
 flex-direction: column;
 gap: 14px;
 align-items: flex-start;
}
.colour-preorder__actions .btn { width: 100%; max-width: 380px; justify-content: center; text-align: center; }
.colour-preorder .btn--primary { background: var(--c-cream); color: var(--c-graphite); }
.colour-preorder .btn--primary:hover { background: var(--c-walnut); color: var(--c-cream); }
@media (max-width: 768px) {
 .colour-preorder__inner { grid-template-columns: 1fr; gap: 28px; }
 .colour-preorder__title { font-size: 32px; }
 .colour-preorder { padding: 56px 0; }
}

/* Header CTA: Request a Quote button next to WhatsApp */
.header-utils__cta {
 display: inline-flex;
 align-items: center;
 padding: 10px 18px;
 background: var(--c-graphite);
 color: var(--c-cream);
 border: none;
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 cursor: pointer;
 white-space: nowrap;
 transition: background .2s var(--ease), transform .2s var(--ease);
 margin: 0 4px;
}
.header-utils__cta:hover { background: var(--c-walnut); transform: translateY(-1px); }
@media (max-width: 980px) {
 .header-utils__cta { display: none; }
}

/* About page closing tagline */
.closing-line {
 padding: 80px 0 96px;
 text-align: center;
 background: var(--c-cream);
}
.closing-line__brand {
 font-family: var(--f-serif);
 font-size: 28px;
 font-weight: 500;
 color: var(--c-graphite);
 margin: 0 0 6px;
}
.closing-line__tag {
 font-family: var(--f-serif);
 font-style: italic;
 font-size: 22px;
 color: var(--c-walnut);
 margin: 0;
}

/* About page intro alt-band */
.material-intro--alt { background: var(--c-cream-deep); }

/* =================================================================
 TRADE + CONTRACT (dark)
 ================================================================= */
.section--trade { background: var(--c-graphite); color: var(--c-cream); padding: 80px 0; }
.trade-block {
 display: grid;
 grid-template-columns: 1fr 1fr;
 gap: 80px;
}
.trade-block__col {
 border-left: 1px solid rgba(245,242,235,.18);
 padding-left: 32px;
}
.trade-block__col:first-child { border-left: 0; padding-left: 0; }
.trade-block__body {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(22px, 2.4vw, 30px);
 line-height: 1.25;
 color: var(--c-cream);
 margin: 18px 0 28px;
 max-width: 460px;
}
@media (max-width: 768px) {
 .trade-block { grid-template-columns: 1fr; gap: 40px; }
 .trade-block__col { border-left: 0; padding-left: 0; padding-top: 32px; border-top: 1px solid rgba(245,242,235,.18); }
 .trade-block__col:first-child { border-top: 0; padding-top: 0; }
}

/* =================================================================
 VISIT US
 ================================================================= */
.visit {
 display: grid;
 grid-template-columns: 1.2fr 1fr;
 gap: 64px;
 align-items: center;
}
.visit__media {
 position: relative;
 aspect-ratio: 4 / 3;
 overflow: hidden;
 background: var(--c-cream-deep);
 display: block;
 color: var(--c-cream);
}
.visit__media img { width: 100%; height: 100%; object-fit: cover; }
.visit__media--map iframe { width: 100%; height: 100%; border: 0; display: block; }
.visit__pin {
 position: absolute;
 inset: auto auto 24px 24px;
 background: var(--c-graphite);
 color: var(--c-cream);
 padding: 12px 18px;
 font-family: var(--f-sans);
 font-size: 12px;
 font-weight: 500;
 letter-spacing: 0.14em;
 text-transform: uppercase;
 text-decoration: none;
 z-index: 2;
 transition: background .2s var(--ease);
}
.visit__pin:hover { background: var(--c-walnut); }
.visit__address, .visit__hours, .visit__contact {
 font-size: 16px;
 line-height: 1.7;
 color: var(--c-graphite);
 margin-bottom: 18px;
}
.visit__address strong, .visit__hours strong {
 font-family: var(--f-sans);
 font-size: 12px;
 font-weight: 500;
 letter-spacing: 0.14em;
 text-transform: uppercase;
 color: var(--c-graphite);
 display: inline-block;
 margin-bottom: 6px;
}
.visit__contact a {
 color: var(--c-graphite);
 border-bottom: 1px solid var(--c-walnut);
}
@media (max-width: 1024px) {
 .visit { grid-template-columns: 1fr; gap: 32px; }
}

/* =================================================================
 FOOTER
 ================================================================= */
.site-footer {
 background: var(--c-cream);
 border-top: 1px solid rgba(26,26,26,.1);
 padding: 80px 0 24px;
}
.site-footer__grid {
 display: grid;
 grid-template-columns: 1.4fr repeat(5, 1fr);
 gap: 40px;
 margin-bottom: 56px;
}
.site-footer__heading {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 color: var(--c-graphite);
 margin: 0 0 18px;
}
.site-footer__col ul { display: flex; flex-direction: column; gap: 10px; }
.site-footer__col ul a {
 font-size: 14px;
 color: var(--c-grey);
}
.site-footer__col ul a:hover { color: var(--c-graphite); }
.site-footer__col .logo__mark { height: 80px; width: auto; max-width: none; }
.site-footer__tag {
 font-family: var(--f-serif);
 font-style: italic;
 font-size: 16px;
 color: var(--c-graphite);
 margin: 12px 0 20px;
}
.site-footer__address {
 font-style: normal;
 font-size: 14px;
 line-height: 1.7;
 color: var(--c-grey);
}
.site-footer__address a { color: var(--c-grey); }
.site-footer__address a:hover { color: var(--c-graphite); }

.newsletter { margin-top: 16px; }
.newsletter__label {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 display: block;
 margin-bottom: 10px;
 color: var(--c-graphite);
}
.newsletter__row {
 display: flex;
 align-items: center;
 border-bottom: 1px solid var(--c-graphite);
}
.newsletter__input {
 flex: 1;
 border: 0;
 background: transparent;
 padding: 10px 0;
 font: inherit;
 color: var(--c-graphite);
}
.newsletter__input:focus { outline: 0; }
.newsletter__btn {
 width: 32px;
 text-align: right;
 font-size: 18px;
}

.site-footer__bottom {
 display: flex;
 justify-content: space-between;
 align-items: center;
 padding-top: 24px;
 border-top: 1px solid rgba(26,26,26,.08);
 font-size: 12px;
 color: var(--c-grey);
 letter-spacing: 0.04em;
}
.site-footer__legal { display: inline-flex; gap: 12px; align-items: center; }

@media (max-width: 1024px) {
 .site-footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 540px) {
 .site-footer__grid { grid-template-columns: 1fr; gap: 32px; }
 .site-footer__bottom { flex-direction: column; gap: 12px; align-items: flex-start; }
}

/* =================================================================
 FLOATING STICKY CLUSTER
 ================================================================= */
.floating-cluster {
 position: fixed;
 right: 20px;
 bottom: 20px;
 display: flex;
 flex-direction: column;
 gap: 12px;
 z-index: 70;
}
.floating-cluster__btn {
 width: 56px; height: 56px;
 border-radius: 50%;
 display: inline-flex;
 align-items: center; justify-content: center;
 color: #fff;
 box-shadow: 0 6px 18px rgba(26,26,26,.18), 0 1px 4px rgba(26,26,26,.12);
 transition: transform .2s var(--ease), box-shadow .2s var(--ease);
}
.floating-cluster__btn:hover {
 transform: translateY(-2px);
 box-shadow: 0 10px 24px rgba(26,26,26,.22), 0 2px 6px rgba(26,26,26,.14);
}
.floating-cluster__btn--whatsapp { background: #25D366; }
.floating-cluster__btn--call { background: var(--c-graphite); }

@media (max-width: 768px) {
 .floating-cluster { right: 14px; bottom: 14px; }
 .floating-cluster__btn { width: 50px; height: 50px; }
}

/* =================================================================
 MODAL
 ================================================================= */
.modal {
 position: fixed;
 inset: 0;
 z-index: 100;
 display: flex;
 align-items: center;
 justify-content: center;
 padding: 24px;
}
.modal[hidden] { display: none; }
.modal__backdrop {
 position: absolute;
 inset: 0;
 background: rgba(26,26,26,.55);
 backdrop-filter: blur(4px);
}
.modal__panel {
 position: relative;
 background: var(--c-cream);
 width: 100%;
 max-width: 600px;
 padding: 44px 40px;
 z-index: 1;
 max-height: calc(100vh - 48px);
 overflow-y: auto;
 box-shadow: 0 20px 60px -10px rgba(26,26,26,.3);
}
.modal__close {
 position: absolute;
 top: 12px; right: 16px;
 font-size: 28px;
 width: 36px; height: 36px;
 display: inline-flex; align-items: center; justify-content: center;
 color: var(--c-graphite);
 line-height: 1;
}
.modal__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: 32px;
 line-height: 1.15;
 margin: 0 0 8px;
}
.modal__sub {
 color: var(--c-grey);
 font-size: 15px;
 margin-bottom: 24px;
}

/* Form */
.enquiry-form { display: flex; flex-direction: column; gap: 14px; }
.enquiry-form label {
 display: flex;
 flex-direction: column;
 gap: 6px;
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.14em;
 text-transform: uppercase;
 color: var(--c-graphite);
}
.enquiry-form .req { color: var(--c-sale); margin-left: 2px; }
.enquiry-form input[type="text"],
.enquiry-form input[type="email"],
.enquiry-form input[type="tel"],
.enquiry-form input[type="number"],
.enquiry-form select,
.enquiry-form textarea {
 font: inherit;
 background: transparent;
 border: 0;
 border-bottom: 1px solid var(--c-graphite);
 padding: 10px 0;
 color: var(--c-graphite);
 text-transform: none;
 letter-spacing: 0;
 font-weight: 400;
 font-size: 15px;
 border-radius: 0;
}
.enquiry-form input:focus, .enquiry-form select:focus, .enquiry-form textarea:focus {
 outline: 0;
 border-bottom-color: var(--c-walnut);
}
.enquiry-form__row {
 display: grid;
 grid-template-columns: 1fr 1fr;
 gap: 18px;
}
.enquiry-form__toggle {
 flex-direction: row;
 align-items: center;
 gap: 10px;
 letter-spacing: 0.08em;
 font-size: 12px;
 align-self: end;
 padding-bottom: 10px;
}
.enquiry-form__toggle input { width: 16px; height: 16px; }
.enquiry-form__success {
 background: var(--c-cream-deep);
 padding: 16px;
 font-size: 14px;
 color: var(--c-graphite);
 margin-top: 8px;
}
@media (max-width: 540px) {
 .enquiry-form__row { grid-template-columns: 1fr; }
 .modal__panel { padding: 32px 22px; }
}

/* =================================================================
 ACCESSIBILITY
 ================================================================= */
:focus-visible {
 outline: 2px solid var(--c-walnut);
 outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
 *, *::before, *::after {
 transition-duration: .01ms !important;
 animation-duration: .01ms !important;
 }
}

/* =================================================================
 PRODUCT INDEX PAGE - /products.html
 ================================================================= */
.page-hero {
 padding: 80px 0 56px;
 text-align: center;
 background: var(--c-cream);
}
@media (max-width: 768px) {
 .page-hero { padding: 56px 0 36px; }
}
.page-hero__rule {
 display: inline-block;
 width: 40px; height: 2px;
 background: var(--c-graphite);
 margin-bottom: 24px;
}
.page-hero__eyebrow {
 font-family: var(--f-sans);
 font-size: 12px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 color: var(--c-grey);
 display: block;
 margin-bottom: 14px;
}
.page-hero__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(36px, 5vw, 56px);
 line-height: 1.1;
 margin: 0 0 20px;
 letter-spacing: 0;
}
.page-hero__sub {
 font-family: var(--f-sans);
 font-size: 16px;
 line-height: 1.7;
 color: var(--c-grey);
 max-width: 560px;
 margin: 0 auto;
}

/* Sold-out / advisory banner */
.advisory-banner {
 background: var(--c-cream-deep);
 border-top: 1px solid rgba(26,26,26,.08);
 border-bottom: 1px solid rgba(26,26,26,.08);
}
.advisory-banner--prominent {
 background: var(--c-graphite);
 color: var(--c-cream);
 border: 0;
 padding: 8px 0;
}
.advisory-banner--prominent .advisory-banner__icon {
 color: var(--c-cream);
}
.advisory-banner--prominent .advisory-banner__text {
 color: var(--c-cream);
}
.advisory-banner--prominent a {
 color: var(--c-cream);
 border-bottom-color: var(--c-cream);
}
.advisory-banner--prominent a:hover {
 color: var(--c-cream);
 opacity: .8;
}

/* Sold-out hero treatments */
.material-hero__badge {
 display: inline-block;
 font-family: var(--f-sans);
 font-size: 10px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 padding: 6px 12px;
 margin-bottom: 16px;
 background: var(--c-sale);
 color: var(--c-cream);
}
.advisory-banner__inner {
 display: flex;
 align-items: center;
 gap: 16px;
 padding: 16px 0;
 font-size: 14px;
 color: var(--c-graphite);
}
.advisory-banner__icon {
 flex-shrink: 0;
 width: 20px; height: 20px;
 color: var(--c-walnut);
}
.advisory-banner__text { flex: 1; }
.advisory-banner__text strong {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 display: inline-block;
 margin-right: 12px;
}
.advisory-banner a {
 color: var(--c-graphite);
 border-bottom: 1px solid var(--c-walnut);
 padding-bottom: 1px;
 white-space: nowrap;
}
.advisory-banner a:hover { color: var(--c-walnut); }

@media (max-width: 640px) {
 .advisory-banner__inner { flex-wrap: wrap; gap: 12px; padding: 14px 0; }
 .advisory-banner__text strong { display: block; margin-bottom: 4px; }
}

/* Filter bar */
.filter-bar {
 position: sticky;
 top: calc(var(--utility-h) + var(--header-h));
 z-index: 30;
 background: var(--c-cream);
 border-top: 1px solid rgba(26,26,26,.08);
 border-bottom: 1px solid rgba(26,26,26,.08);
 padding: 18px 0;
}
.filter-bar__inner {
 display: flex;
 align-items: center;
 gap: 32px;
 flex-wrap: wrap;
}
.filter-group {
 display: flex;
 align-items: center;
 gap: 12px;
 flex-wrap: wrap;
}
.filter-group__label {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-grey);
 margin-right: 4px;
}
.filter-chip {
 display: inline-flex;
 align-items: center;
 gap: 6px;
 font-family: var(--f-sans);
 font-size: 12px;
 font-weight: 500;
 letter-spacing: 0.08em;
 text-transform: uppercase;
 padding: 8px 14px;
 background: transparent;
 border: 1px solid rgba(26,26,26,.18);
 color: var(--c-graphite);
 cursor: pointer;
 transition: background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease);
 white-space: nowrap;
}
.filter-chip:hover { border-color: var(--c-graphite); }
.filter-chip.is-active {
 background: var(--c-graphite);
 color: var(--c-cream);
 border-color: var(--c-graphite);
}
.filter-chip__count {
 font-size: 10px;
 opacity: .7;
}
.filter-bar__count {
 font-size: 13px;
 color: var(--c-grey);
 margin-left: auto;
}
.filter-group--sort {
 /* Pushes count to far right with sort just before it */
}
.filter-sort {
 font: inherit;
 font-family: var(--f-sans);
 font-size: 12px;
 font-weight: 500;
 letter-spacing: 0.08em;
 text-transform: uppercase;
 background: transparent;
 border: 1px solid rgba(26,26,26,.18);
 color: var(--c-graphite);
 padding: 8px 30px 8px 14px;
 cursor: pointer;
 appearance: none;
 background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'><path d='M1 1L5 5L9 1' stroke='%231A1A1A' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");
 background-repeat: no-repeat;
 background-position: calc(100% - 12px) center;
 background-size: 10px 6px;
 transition: border-color .2s var(--ease);
}
.filter-sort:hover, .filter-sort:focus { border-color: var(--c-graphite); outline: 0; }
@media (max-width: 768px) {
 .filter-bar { padding: 14px 0; }
 .filter-bar__inner { gap: 16px; }
 .filter-group { gap: 8px; }
 .filter-bar__count { width: 100%; margin-left: 0; }
}

/* Stock badge on product cards */
.collection-card { position: relative; }
.collection-card__badge {
 position: absolute;
 top: 12px; left: 12px;
 font-family: var(--f-sans);
 font-size: 10px;
 font-weight: 500;
 letter-spacing: 0.14em;
 text-transform: uppercase;
 padding: 5px 9px;
 background: var(--c-cream);
 color: var(--c-graphite);
 z-index: 2;
}
.collection-card__badge--stocked {
 background: var(--c-graphite);
 color: var(--c-cream);
}
.collection-card__badge--order {
 background: var(--c-cream);
 color: var(--c-graphite);
 border: 1px solid var(--c-graphite);
}
.collection-card__badge--soldout {
 background: var(--c-sale);
 color: var(--c-cream);
}
.collection-card__badge--preorder {
 background: var(--c-walnut);
 color: var(--c-cream);
}
.collection-card__badge--service {
 background: var(--c-cream);
 color: var(--c-graphite);
 border: 1px solid var(--c-graphite);
}
.collection-card__placeholder {
 position: absolute;
 top: 12px; right: 12px;
 font-family: var(--f-sans);
 font-size: 9px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 padding: 4px 8px;
 background: rgba(245,242,235,.92);
 color: var(--c-grey);
 z-index: 2;
 backdrop-filter: blur(2px);
}
.collection-card__sku {
 display: block;
 font-family: var(--f-sans);
 font-size: 11px;
 letter-spacing: 0.04em;
 color: var(--c-grey-light);
 margin-top: 4px;
}

/* Empty state when filters yield no results */
.product-grid__empty {
 grid-column: 1 / -1;
 text-align: center;
 padding: 80px 24px;
 color: var(--c-grey);
}
.product-grid__empty p { margin: 0 0 16px; font-size: 16px; }

/* Card hidden by filter */
.collection-card[hidden] { display: none !important; }

/* Bottom CTA strip on products page */
.products-cta {
 background: var(--c-cream-deep);
 text-align: center;
 padding: 80px 24px;
}
.products-cta__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 3.4vw, 40px);
 line-height: 1.2;
 margin: 0 0 16px;
}
.products-cta__sub {
 font-size: 16px;
 color: var(--c-grey);
 margin: 0 0 28px;
 max-width: 540px;
 margin-left: auto;
 margin-right: auto;
}
.products-cta__buttons {
 display: inline-flex;
 gap: 14px;
 flex-wrap: wrap;
 justify-content: center;
}

/* =================================================================
 COLOUR DETAIL PAGE - /products/{slug}.html
 ================================================================= */
.colour-hero {
 position: relative;
 background: var(--c-cream-deep);
 min-height: 480px;
 height: 60vh;
 max-height: 720px;
 overflow: hidden;
}
.colour-hero__image {
 position: absolute; inset: 0;
 background-size: cover;
 background-position: center;
 background-color: var(--c-cream-deep);
}
.colour-hero__overlay {
 position: absolute; inset: 0;
 background: linear-gradient(180deg, rgba(26,26,26,0) 30%, rgba(26,26,26,.5) 100%);
}
.colour-hero__content {
 position: absolute;
 left: 0; right: 0; bottom: 8%;
 padding: 0 32px;
 text-align: center;
 color: var(--c-cream);
 text-shadow: 0 1px 12px rgba(26,26,26,.4);
}
.colour-hero__eyebrow {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 display: block;
 margin-bottom: 14px;
 color: var(--c-cream);
}
.colour-hero__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(48px, 7vw, 88px);
 line-height: 1.05;
 margin: 0 0 16px;
 color: #fff;
}
.colour-hero__sub {
 font-family: var(--f-sans);
 font-style: italic;
 font-size: clamp(15px, 1.4vw, 19px);
 line-height: 1.5;
 margin: 0 auto;
 max-width: 540px;
 color: var(--c-cream);
}
.colour-hero__badge {
 display: inline-block;
 font-family: var(--f-sans);
 font-size: 10px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 padding: 5px 12px;
 margin-bottom: 16px;
 background: rgba(245,242,235,.18);
 border: 1px solid rgba(245,242,235,.45);
 backdrop-filter: blur(4px);
 color: var(--c-cream);
}
.colour-hero__badge--stocked {
 background: var(--c-cream);
 color: var(--c-graphite);
 border-color: var(--c-cream);
}

/* Breadcrumb */
.breadcrumb {
 padding: 24px 0 0;
 font-family: var(--f-sans);
 font-size: 12px;
 letter-spacing: 0.06em;
 color: var(--c-grey);
}
.breadcrumb a { color: var(--c-grey); }
.breadcrumb a:hover { color: var(--c-graphite); }
.breadcrumb__sep { margin: 0 8px; opacity: .5; }
.breadcrumb__current { color: var(--c-graphite); }

/* Two-column intro: swatch + specs */
.colour-overview {
 padding: 80px 0;
}
@media (max-width: 768px) {
 .colour-overview { padding: 48px 0; }
}
.colour-overview__grid {
 display: grid;
 grid-template-columns: 1fr 1fr;
 gap: 64px;
 align-items: start;
}
@media (max-width: 1024px) {
 .colour-overview__grid { grid-template-columns: 1fr; gap: 32px; }
}
.colour-overview__swatch {
 position: relative;
 aspect-ratio: 4 / 3;
 background-size: cover;
 background-position: center;
 background-color: var(--c-cream-deep);
 overflow: hidden;
}
.colour-overview__swatch-label {
 position: absolute;
 bottom: 16px; left: 16px;
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-cream);
 background: rgba(26,26,26,.85);
 padding: 6px 10px;
}
.colour-overview__body {
 padding-top: 8px;
}
.colour-overview__sku {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 color: var(--c-grey);
 margin-bottom: 8px;
 display: block;
}
.colour-overview__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(36px, 4vw, 48px);
 line-height: 1.1;
 margin: 0 0 20px;
 letter-spacing: 0;
}
.colour-overview__body p {
 font-size: 16px;
 line-height: 1.7;
 color: var(--c-graphite);
 margin: 0 0 24px;
}
.colour-overview__cta {
 display: flex;
 gap: 12px;
 flex-wrap: wrap;
 margin-top: 12px;
}

/* Specs table */
.specs {
 background: var(--c-cream-deep);
 padding: 64px 0;
}
@media (max-width: 768px) { .specs { padding: 40px 0; } }
.specs__head {
 text-align: center;
 margin-bottom: 40px;
}
.specs__head .eyebrow { color: var(--c-graphite); }
.specs__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 3vw, 36px);
 line-height: 1.2;
 margin: 12px 0 0;
}
.specs__list {
 display: grid;
 grid-template-columns: repeat(2, 1fr);
 gap: 0;
 max-width: 880px;
 margin: 0 auto;
 border-top: 1px solid rgba(26,26,26,.12);
}
.specs__row {
 display: grid;
 grid-template-columns: 200px 1fr;
 padding: 18px 0;
 border-bottom: 1px solid rgba(26,26,26,.12);
 font-size: 14px;
 line-height: 1.6;
}
.specs__row dt {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-grey);
 padding-right: 16px;
}
.specs__row dd {
 margin: 0;
 color: var(--c-graphite);
}
@media (max-width: 768px) {
 .specs__list { grid-template-columns: 1fr; }
 .specs__row { grid-template-columns: 140px 1fr; padding: 14px 0; font-size: 13px; }
 .specs__row dt { font-size: 10px; padding-right: 12px; }
}

/* Related colours */
.related-colours {
 padding: 80px 0;
}
@media (max-width: 768px) { .related-colours { padding: 48px 0; } }
.related-colours .card-grid { gap: 24px; }
.related-colours__head {
 text-align: center;
 margin-bottom: 40px;
}

/* =================================================================
 MATERIAL PAGE - /spc.html, /lvt.html, /engineered-wood.html
 ================================================================= */
.material-hero {
 position: relative;
 background: var(--c-cream-deep);
 min-height: 520px;
 height: 65vh;
 max-height: 760px;
 overflow: hidden;
}
.material-hero__image {
 position: absolute; inset: 0;
 background-size: cover;
 background-position: center;
 background-color: var(--c-cream-deep);
}
.material-hero__overlay {
 position: absolute; inset: 0;
 background: linear-gradient(180deg, rgba(26,26,26,0) 30%, rgba(26,26,26,.55) 100%);
}
.material-hero__content {
 position: absolute;
 left: 0; right: 0; bottom: 8%;
 padding: 0 32px;
 text-align: center;
 color: var(--c-cream);
 text-shadow: 0 1px 12px rgba(26,26,26,.4);
}
.material-hero__eyebrow {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 display: block;
 margin-bottom: 14px;
 color: var(--c-cream);
}
.material-hero__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(56px, 9vw, 120px);
 line-height: 0.95;
 margin: 0 0 16px;
 color: #fff;
 letter-spacing: 0;
}
.material-hero__sub {
 font-family: var(--f-serif);
 font-style: italic;
 font-size: clamp(18px, 1.8vw, 24px);
 line-height: 1.4;
 margin: 0 auto 28px;
 max-width: 620px;
 color: var(--c-cream);
}
.material-hero__cta {
 display: inline-flex;
 gap: 12px;
 flex-wrap: wrap;
 justify-content: center;
}

/* What-is intro */
.material-intro {
 padding: 96px 0;
}
@media (max-width:768px){ .material-intro{ padding: 56px 0; } }
.material-intro__grid {
 display: grid;
 grid-template-columns: 1fr 1.4fr;
 gap: 80px;
 align-items: start;
 max-width: 1100px;
 margin: 0 auto;
}
@media (max-width:1024px){ .material-intro__grid{ grid-template-columns: 1fr; gap: 24px; } }
.material-intro__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(32px, 4vw, 48px);
 line-height: 1.1;
 margin: 8px 0 0;
}
.material-intro__body p {
 font-size: 17px;
 line-height: 1.75;
 color: var(--c-graphite);
 margin: 0 0 1.2em;
}

/* Construction cross-section */
.construction {
 background: var(--c-cream-deep);
 padding: 96px 0;
}
@media (max-width:768px){ .construction{ padding: 56px 0; } }
.construction__head {
 text-align: center;
 margin-bottom: 48px;
}
.construction__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 3.4vw, 40px);
 line-height: 1.15;
 margin: 12px 0 0;
}
.construction__diagram {
 max-width: 900px;
 margin: 0 auto;
 display: grid;
 grid-template-columns: 1fr 1.2fr;
 gap: 56px;
 align-items: center;
}
@media (max-width: 768px) {
 .construction__diagram { grid-template-columns: 1fr; gap: 32px; }
}
.construction__svg-wrap {
 width: 100%;
 aspect-ratio: 4 / 3;
 background: var(--c-cream);
 display: flex;
 align-items: center;
 justify-content: center;
 padding: 28px;
 box-shadow: inset 0 0 0 1px rgba(26,26,26,.06);
}
.construction__svg { width: 100%; height: 100%; }
.construction__legend {
 list-style: none;
 padding: 0;
 margin: 0;
 display: flex;
 flex-direction: column;
 gap: 16px;
}
.construction__legend-item {
 display: grid;
 grid-template-columns: 24px 1fr;
 gap: 14px;
 align-items: start;
 padding: 12px 0;
 border-bottom: 1px solid rgba(26,26,26,.1);
}
.construction__legend-item:last-child { border-bottom: 0; }
.construction__legend-num {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.12em;
 color: var(--c-walnut);
 padding-top: 2px;
}
.construction__legend-name {
 display: block;
 font-family: var(--f-sans);
 font-size: 13px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-graphite);
 margin-bottom: 4px;
}
.construction__legend-desc {
 font-size: 14px;
 line-height: 1.55;
 color: var(--c-grey);
}

/* Feature grid (Why SPC for the Gulf) */
.feature-grid-section {
 padding: 96px 0;
}
@media (max-width:768px){ .feature-grid-section{ padding: 56px 0; } }
.feature-grid {
 display: grid;
 grid-template-columns: repeat(3, 1fr);
 gap: 48px 48px;
 margin-top: 48px;
}
@media (max-width: 1024px){ .feature-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px){ .feature-grid{ grid-template-columns: 1fr; gap: 32px; } }
.feature {
 display: block;
}
.feature__icon {
 width: 32px; height: 32px;
 color: var(--c-graphite);
 margin-bottom: 16px;
}
.feature__title {
 font-family: var(--f-sans);
 font-size: 13px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-graphite);
 margin: 0 0 10px;
}
.feature__body {
 font-size: 15px;
 line-height: 1.65;
 color: var(--c-grey);
 margin: 0;
}

/* Where it works */
.where {
 background: var(--c-cream-deep);
 padding: 80px 0;
}
@media (max-width:768px){ .where{ padding: 56px 0; } }
.where__inner {
 max-width: 800px;
 margin: 0 auto;
 text-align: center;
}
.where__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 3vw, 36px);
 line-height: 1.2;
 margin: 12px 0 24px;
}
.where__body {
 font-size: 17px;
 line-height: 1.75;
 color: var(--c-graphite);
 margin: 0 0 24px;
}
.where__tags {
 display: flex;
 flex-wrap: wrap;
 gap: 8px;
 justify-content: center;
 margin-top: 16px;
}
.where__tag {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.14em;
 text-transform: uppercase;
 padding: 8px 14px;
 background: var(--c-cream);
 color: var(--c-graphite);
 border: 1px solid rgba(26,26,26,.12);
}

/* Embedded colour grid section */
.embedded-colours {
 padding: 96px 0;
}
@media (max-width:768px){ .embedded-colours{ padding: 56px 0; } }
.embedded-colours .card-grid {
 margin-bottom: 40px;
}
.embedded-colours__foot {
 text-align: center;
}

/* Process steps */
.process {
 background: var(--c-cream-deep);
 padding: 96px 0;
}
@media (max-width:768px){ .process{ padding: 56px 0; } }
.process__head {
 text-align: center;
 margin-bottom: 56px;
}
.process__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 3.4vw, 42px);
 line-height: 1.15;
 margin: 12px 0 0;
}
.process__steps {
 display: grid;
 grid-template-columns: repeat(4, 1fr);
 gap: 32px;
 position: relative;
}
@media (max-width: 1024px){ .process__steps{ grid-template-columns: repeat(2, 1fr); gap: 40px 24px; } }
@media (max-width: 540px){ .process__steps{ grid-template-columns: 1fr; gap: 24px; } }
.process-step {
 text-align: left;
 position: relative;
}
.process-step__num {
 font-family: var(--f-serif);
 font-size: 56px;
 line-height: 1;
 color: var(--c-walnut);
 display: block;
 margin-bottom: 16px;
 font-weight: 400;
}
.process-step__title {
 font-family: var(--f-sans);
 font-size: 13px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-graphite);
 margin: 0 0 12px;
}
.process-step__body {
 font-size: 14px;
 line-height: 1.65;
 color: var(--c-grey);
 margin: 0;
}

/* Bottom CTA strip. Material page */
.material-cta {
 padding: 80px 0;
 text-align: center;
}
.material-cta__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 3.4vw, 44px);
 line-height: 1.15;
 margin: 0 0 20px;
}
.material-cta__sub {
 font-size: 16px;
 color: var(--c-grey);
 max-width: 520px;
 margin: 0 auto 28px;
}
.material-cta__buttons {
 display: inline-flex;
 gap: 12px;
 flex-wrap: wrap;
 justify-content: center;
}

/* Related materials cross-link */
.related-materials {
 background: var(--c-graphite);
 color: var(--c-cream);
 padding: 80px 0;
}
.related-materials__head {
 text-align: center;
 margin-bottom: 40px;
}
.related-materials__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 3vw, 36px);
 line-height: 1.2;
 margin: 12px 0 0;
 color: var(--c-cream);
}
.related-materials .eyebrow { color: var(--c-cream); opacity: .7; }
.related-materials__grid {
 display: grid;
 grid-template-columns: repeat(3, 1fr);
 gap: 24px;
}
@media (max-width:768px){ .related-materials__grid{ grid-template-columns: 1fr; } }
.related-mat {
 display: block;
 padding: 32px;
 background: rgba(245,242,235,.04);
 border: 1px solid rgba(245,242,235,.18);
 transition: background .25s var(--ease), transform .25s var(--ease);
 color: var(--c-cream);
}
.related-mat:hover { background: rgba(245,242,235,.1); transform: translateY(-2px); color: var(--c-cream); }
.related-mat__name {
 font-family: var(--f-serif);
 font-size: 28px;
 line-height: 1.1;
 font-weight: 400;
 margin: 0 0 8px;
}
.related-mat__sub {
 font-family: var(--f-sans);
 font-size: 13px;
 letter-spacing: 0.06em;
 color: rgba(245,242,235,.7);
 margin: 0 0 16px;
}
.related-mat__cta {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 border-bottom: 1px solid var(--c-cream);
 padding-bottom: 2px;
}

/* =================================================================
 INSTALLATION SERVICE PAGE. Checklist, pricing, coverage
 ================================================================= */

/* What's Included. Two-column checklist */
.checklist-section {
 background: var(--c-cream-deep);
 padding: 96px 0;
}
@media (max-width:768px){ .checklist-section{ padding: 56px 0; } }
.checklist-section__head {
 text-align: center;
 margin-bottom: 48px;
}
.checklist-section__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 3.4vw, 40px);
 line-height: 1.15;
 margin: 12px 0 0;
}
.checklist {
 display: grid;
 grid-template-columns: repeat(2, 1fr);
 gap: 0 48px;
 max-width: 920px;
 margin: 0 auto;
 list-style: none;
 padding: 0;
}
@media (max-width: 768px) {
 .checklist { grid-template-columns: 1fr; }
}
.checklist__item {
 display: grid;
 grid-template-columns: 28px 1fr;
 gap: 16px;
 align-items: start;
 padding: 18px 0;
 border-bottom: 1px solid rgba(26,26,26,.1);
}
.checklist__icon {
 width: 20px; height: 20px;
 margin-top: 2px;
 color: var(--c-walnut);
 flex-shrink: 0;
}
.checklist__text {
 font-family: var(--f-sans);
 font-size: 15px;
 line-height: 1.6;
 color: var(--c-graphite);
}
.checklist__text strong {
 display: block;
 font-size: 13px;
 font-weight: 500;
 letter-spacing: 0.14em;
 text-transform: uppercase;
 color: var(--c-graphite);
 margin-bottom: 4px;
}
.checklist__text span {
 color: var(--c-grey);
 font-size: 14px;
}

/* Pricing breakdown */
.pricing-section {
 padding: 96px 0;
}
@media (max-width:768px){ .pricing-section{ padding: 56px 0; } }
.pricing-section__head {
 text-align: center;
 margin-bottom: 48px;
}
.pricing-grid {
 display: grid;
 grid-template-columns: repeat(3, 1fr);
 gap: 24px;
 max-width: 1100px;
 margin: 0 auto 40px;
}
@media (max-width: 1024px) { .pricing-grid { grid-template-columns: 1fr; gap: 16px; max-width: 540px; } }
.pricing-card {
 background: var(--c-cream);
 border: 1px solid rgba(26,26,26,.12);
 padding: 32px 28px;
 text-align: left;
 display: flex;
 flex-direction: column;
}
.pricing-card--featured {
 background: var(--c-graphite);
 color: var(--c-cream);
 border-color: var(--c-graphite);
}
.pricing-card--featured .pricing-card__rate,
.pricing-card--featured .pricing-card__name,
.pricing-card--featured .pricing-card__list { color: var(--c-cream); }
.pricing-card--featured .pricing-card__list span { color: rgba(245,242,235,.7); }

.pricing-card__name {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-grey);
 margin: 0 0 12px;
}
.pricing-card__rate {
 font-family: var(--f-serif);
 font-size: clamp(36px, 4vw, 48px);
 line-height: 1.05;
 font-weight: 400;
 color: var(--c-graphite);
 margin: 0 0 8px;
}
.pricing-card__rate-unit {
 font-family: var(--f-sans);
 font-size: 14px;
 letter-spacing: 0;
 text-transform: none;
 font-weight: 400;
 color: var(--c-grey);
 margin-left: 4px;
}
.pricing-card--featured .pricing-card__rate-unit { color: rgba(245,242,235,.7); }
.pricing-card__sub {
 font-size: 14px;
 color: var(--c-grey);
 margin: 0 0 24px;
 line-height: 1.55;
}
.pricing-card--featured .pricing-card__sub { color: rgba(245,242,235,.75); }
.pricing-card__list {
 list-style: none;
 padding: 0;
 margin: 0;
 display: flex;
 flex-direction: column;
 gap: 10px;
 font-size: 13px;
 line-height: 1.55;
 color: var(--c-graphite);
}
.pricing-card__list li {
 padding-left: 18px;
 position: relative;
}
.pricing-card__list li::before {
 content: "+";
 position: absolute;
 left: 0;
 color: var(--c-walnut);
 font-weight: 600;
}
.pricing-card--featured .pricing-card__list li::before { color: var(--c-cream); opacity: .8; }

.pricing-section__note {
 text-align: center;
 font-size: 14px;
 color: var(--c-grey);
 margin: 24px auto 0;
 max-width: 640px;
 line-height: 1.6;
}

/* Coverage Strip */
.coverage {
 background: var(--c-cream-deep);
 padding: 64px 0;
}
.coverage__head {
 text-align: center;
 margin-bottom: 32px;
}
.coverage__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 3vw, 36px);
 line-height: 1.2;
 margin: 12px 0 0;
}
.coverage__list {
 display: grid;
 grid-template-columns: repeat(4, 1fr);
 gap: 16px;
 max-width: 880px;
 margin: 0 auto;
 list-style: none;
 padding: 0;
}
@media (max-width: 768px){ .coverage__list { grid-template-columns: repeat(2, 1fr); } }
.coverage__item {
 text-align: center;
 padding: 24px 12px;
 background: var(--c-cream);
 border: 1px solid rgba(26,26,26,.08);
}
.coverage__item-name {
 font-family: var(--f-sans);
 font-size: 13px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-graphite);
 display: block;
 margin-bottom: 4px;
}
.coverage__item-note {
 font-size: 12px;
 color: var(--c-grey);
}
.coverage__foot {
 text-align: center;
 font-size: 14px;
 color: var(--c-grey);
 margin-top: 24px;
}

/* =================================================================
 TRADE PAGE. Audience split + on-page application form
 ================================================================= */
.audience-split {
 padding: 96px 0;
}
@media (max-width:768px){ .audience-split{ padding: 56px 0; } }
.audience-split__head {
 text-align: center;
 margin-bottom: 56px;
}
.audience-split__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 3.4vw, 40px);
 line-height: 1.15;
 margin: 12px 0 0;
}
.audience-split__grid {
 display: grid;
 grid-template-columns: 1fr 1fr;
 gap: 24px;
 max-width: 1100px;
 margin: 0 auto;
}
@media (max-width: 768px) {
 .audience-split__grid { grid-template-columns: 1fr; }
}
.audience-card {
 background: var(--c-cream-deep);
 padding: 40px 36px;
 border-left: 3px solid var(--c-walnut);
}
.audience-card--dark {
 background: var(--c-graphite);
 color: var(--c-cream);
 border-left-color: var(--c-cream);
}
.audience-card--dark .audience-card__list,
.audience-card--dark .audience-card__lede,
.audience-card--dark .audience-card__title { color: var(--c-cream); }
.audience-card--dark .audience-card__list li::before { color: var(--c-cream); }
.audience-card__eyebrow {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 color: var(--c-grey);
 display: block;
 margin-bottom: 8px;
}
.audience-card--dark .audience-card__eyebrow { color: rgba(245,242,235,.7); }
.audience-card__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(26px, 2.8vw, 34px);
 line-height: 1.15;
 margin: 0 0 16px;
}
.audience-card__lede {
 font-size: 16px;
 line-height: 1.65;
 color: var(--c-graphite);
 margin: 0 0 20px;
}
.audience-card__list {
 list-style: none;
 padding: 0;
 margin: 0 0 24px;
 display: flex;
 flex-direction: column;
 gap: 8px;
}
.audience-card__list li {
 position: relative;
 padding-left: 18px;
 font-size: 14px;
 line-height: 1.6;
 color: var(--c-graphite);
}
.audience-card__list li::before {
 content: "+";
 position: absolute;
 left: 0;
 color: var(--c-walnut);
 font-weight: 600;
}

/* On-page form (trade application + contact form) */
.application-section {
 background: var(--c-cream-deep);
 padding: 96px 0;
}
@media (max-width:768px){ .application-section{ padding: 56px 0; } }
.application-section__head {
 text-align: center;
 margin-bottom: 40px;
}
.application-form {
 max-width: 720px;
 margin: 0 auto;
 background: var(--c-cream);
 padding: 40px 40px;
 border: 1px solid rgba(26,26,26,.08);
}
@media (max-width: 540px) {
 .application-form { padding: 28px 22px; }
}
.application-form > * + * { margin-top: 18px; }
.application-form label {
 display: flex;
 flex-direction: column;
 gap: 6px;
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.14em;
 text-transform: uppercase;
 color: var(--c-graphite);
}
.application-form .req { color: var(--c-sale); margin-left: 2px; }
.application-form input[type="text"],
.application-form input[type="email"],
.application-form input[type="tel"],
.application-form input[type="number"],
.application-form select,
.application-form textarea {
 font: inherit;
 background: transparent;
 border: 0;
 border-bottom: 1px solid var(--c-graphite);
 padding: 10px 0;
 color: var(--c-graphite);
 text-transform: none;
 letter-spacing: 0;
 font-weight: 400;
 font-size: 15px;
 border-radius: 0;
}
.application-form input:focus,
.application-form select:focus,
.application-form textarea:focus {
 outline: 0;
 border-bottom-color: var(--c-walnut);
}
.application-form__row {
 display: grid;
 grid-template-columns: 1fr 1fr;
 gap: 18px;
}
@media (max-width: 540px) {
 .application-form__row { grid-template-columns: 1fr; }
}
.application-form__success {
 background: var(--c-cream-deep);
 padding: 18px;
 font-size: 14px;
 color: var(--c-graphite);
 margin-top: 8px;
 line-height: 1.6;
}
.application-form__success a { border-bottom: 1px solid var(--c-walnut); padding-bottom: 1px; }
.application-form__hint {
 font-size: 12px;
 color: var(--c-grey);
 margin-top: 4px;
 text-transform: none;
 letter-spacing: 0;
 font-weight: 400;
}

/* =================================================================
 CONTACT PAGE. Showroom split + map + contact methods
 ================================================================= */
.showroom-split {
 padding: 96px 0;
}
@media (max-width:768px){ .showroom-split{ padding: 56px 0; } }
.showroom-split__grid {
 display: grid;
 grid-template-columns: 1.2fr 1fr;
 gap: 64px;
 align-items: start;
 max-width: 1100px;
 margin: 0 auto;
}
@media (max-width: 1024px) {
 .showroom-split__grid { grid-template-columns: 1fr; gap: 32px; }
}
.showroom-image {
 aspect-ratio: 4 / 3;
 background-size: cover;
 background-position: center;
 background-color: var(--c-cream-deep);
}
.showroom-info__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 3vw, 36px);
 line-height: 1.15;
 margin: 8px 0 24px;
}
.showroom-info__address {
 font-size: 16px;
 line-height: 1.7;
 color: var(--c-graphite);
 margin: 0 0 28px;
 font-style: normal;
}
.showroom-info__address strong {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-graphite);
 display: inline-block;
 margin-bottom: 6px;
}
.showroom-info__hours {
 font-size: 14px;
 line-height: 1.65;
 color: var(--c-grey);
 margin: 0 0 28px;
 padding: 18px 0;
 border-top: 1px solid rgba(26,26,26,.08);
 border-bottom: 1px solid rgba(26,26,26,.08);
}
.showroom-info__hours strong {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-graphite);
 display: block;
 margin-bottom: 6px;
}
.showroom-info__buttons {
 display: flex;
 flex-wrap: wrap;
 gap: 10px;
}

/* Three contact methods strip */
.contact-methods {
 background: var(--c-cream-deep);
 padding: 64px 0;
}
.contact-methods__grid {
 display: grid;
 grid-template-columns: repeat(3, 1fr);
 gap: 16px;
 max-width: 1000px;
 margin: 0 auto;
}
@media (max-width: 768px) {
 .contact-methods__grid { grid-template-columns: 1fr; }
}
.contact-method {
 display: block;
 padding: 32px 28px;
 background: var(--c-cream);
 border: 1px solid rgba(26,26,26,.08);
 text-align: center;
 transition: transform .25s var(--ease), border-color .2s var(--ease);
 color: var(--c-graphite);
}
.contact-method:hover {
 transform: translateY(-2px);
 border-color: var(--c-graphite);
 color: var(--c-graphite);
}
.contact-method__icon {
 width: 28px; height: 28px;
 color: var(--c-walnut);
 margin-bottom: 14px;
}
.contact-method__name {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.16em;
 text-transform: uppercase;
 color: var(--c-graphite);
 margin: 0 0 8px;
}
.contact-method__value {
 font-family: var(--f-serif);
 font-size: 22px;
 line-height: 1.2;
 margin: 0 0 4px;
 color: var(--c-graphite);
}
.contact-method__value--small { font-size: 18px; }
.contact-method__sub {
 font-size: 13px;
 color: var(--c-grey);
 margin: 0;
}

/* Map embed */
.map-section {
 padding: 0;
 height: 480px;
 background: var(--c-cream-deep);
}
@media (max-width:768px){ .map-section{ height: 360px; } }
.map-section iframe {
 width: 100%;
 height: 100%;
 border: 0;
 display: block;
 filter: grayscale(20%) contrast(95%);
}

/* =================================================================
 ABOUT PAGE. Founder cards, values, manifesto
 ================================================================= */
.founders-section {
 padding: 96px 0;
}
@media (max-width:768px){ .founders-section{ padding: 56px 0; } }
.founders-section__head {
 text-align: center;
 margin-bottom: 56px;
}
.founders-section__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 3.4vw, 42px);
 line-height: 1.15;
 margin: 12px 0 0;
}
.founders {
 display: grid;
 grid-template-columns: 1fr 1fr;
 gap: 56px;
 max-width: 980px;
 margin: 0 auto;
}
@media (max-width: 768px) {
 .founders { grid-template-columns: 1fr; gap: 40px; }
}
.founder {
 text-align: center;
}
.founder__portrait {
 aspect-ratio: 1 / 1;
 background: var(--c-cream-deep);
 background-size: cover;
 background-position: center;
 margin: 0 auto 24px;
 max-width: 320px;
 position: relative;
 display: flex;
 align-items: center;
 justify-content: center;
}
.founder__portrait::before {
 content: "";
 position: absolute;
 inset: 0;
 background: var(--c-cream-deep);
}
.founder__portrait[style*="background-image"]::before { content: none; }
.founder__initial {
 position: relative;
 font-family: var(--f-serif);
 font-size: 96px;
 line-height: 1;
 color: var(--c-walnut);
 z-index: 1;
 font-weight: 400;
}
.founder__name {
 font-family: var(--f-serif);
 font-size: 28px;
 line-height: 1.15;
 font-weight: 400;
 margin: 0 0 6px;
}
.founder__role {
 font-family: var(--f-sans);
 font-size: 11px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 color: var(--c-grey);
 margin: 0 0 16px;
}
.founder__bio {
 font-size: 14px;
 line-height: 1.7;
 color: var(--c-graphite);
 margin: 0 auto;
 max-width: 360px;
}

/* Values grid (3-up) */
.values-section {
 background: var(--c-cream-deep);
 padding: 96px 0;
}
@media (max-width:768px){ .values-section{ padding: 56px 0; } }
.values-section__head {
 text-align: center;
 margin-bottom: 56px;
}
.values-grid {
 display: grid;
 grid-template-columns: repeat(3, 1fr);
 gap: 32px;
 max-width: 1100px;
 margin: 0 auto;
}
@media (max-width: 768px) {
 .values-grid { grid-template-columns: 1fr; gap: 24px; }
}
.value-card {
 background: var(--c-cream);
 padding: 36px 32px;
 border-left: 3px solid var(--c-walnut);
}
.value-card__icon {
 width: 32px; height: 32px;
 color: var(--c-walnut);
 margin-bottom: 16px;
}
.value-card__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: 24px;
 line-height: 1.2;
 margin: 0 0 12px;
}
.value-card__body {
 font-size: 15px;
 line-height: 1.7;
 color: var(--c-graphite);
 margin: 0;
}

/* Manifesto / sustainability long-form */
.manifesto {
 padding: 96px 0;
}
@media (max-width:768px){ .manifesto{ padding: 56px 0; } }
.manifesto__inner {
 max-width: 760px;
 margin: 0 auto;
 text-align: center;
}
.manifesto__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(32px, 4vw, 48px);
 line-height: 1.15;
 margin: 12px 0 32px;
}
.manifesto__body p {
 font-size: 17px;
 line-height: 1.8;
 color: var(--c-graphite);
 margin: 0 0 1.4em;
 text-align: left;
}
.manifesto__list {
 list-style: none;
 padding: 0;
 margin: 24px 0 0;
 text-align: left;
 display: grid;
 grid-template-columns: 1fr 1fr;
 gap: 12px 32px;
}
@media (max-width: 640px){ .manifesto__list { grid-template-columns: 1fr; } }
.manifesto__list li {
 position: relative;
 padding-left: 22px;
 font-size: 14px;
 line-height: 1.65;
 color: var(--c-graphite);
}
.manifesto__list li::before {
 content: "";
 position: absolute;
 left: 0; top: 8px;
 width: 12px; height: 1px;
 background: var(--c-walnut);
}

/* Showroom invite strip */
.showroom-invite {
 background: var(--c-graphite);
 color: var(--c-cream);
 padding: 80px 0;
 text-align: center;
}
.showroom-invite__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(28px, 3.4vw, 42px);
 line-height: 1.15;
 margin: 0 0 16px;
 color: var(--c-cream);
}
.showroom-invite__sub {
 font-size: 16px;
 line-height: 1.7;
 color: rgba(245,242,235,.8);
 max-width: 560px;
 margin: 0 auto 28px;
}
.showroom-invite__buttons {
 display: inline-flex;
 gap: 12px;
 flex-wrap: wrap;
 justify-content: center;
}

/* =================================================================
 COMING SOON (placeholder routes)
 ================================================================= */
.coming-soon {
 min-height: calc(100vh - var(--utility-h) - var(--header-h) - 360px);
 display: flex;
 align-items: center;
 justify-content: center;
 padding: 120px 32px;
 text-align: center;
}
.coming-soon__inner { max-width: 640px; }
.coming-soon__rule {
 display: inline-block;
 width: 40px; height: 2px;
 background: var(--c-graphite);
 margin-bottom: 28px;
}
.coming-soon__title {
 font-family: var(--f-serif);
 font-weight: 400;
 font-size: clamp(40px, 6vw, 72px);
 line-height: 1.05;
 margin: 0 0 24px;
}
.coming-soon__eyebrow {
 font-family: var(--f-sans);
 font-size: 12px;
 font-weight: 500;
 letter-spacing: 0.18em;
 text-transform: uppercase;
 color: var(--c-grey);
 margin-bottom: 12px;
 display: block;
}
.coming-soon__body {
 font-size: 17px;
 line-height: 1.7;
 color: var(--c-grey);
 margin: 0 0 36px;
}
