/* =====================================================================
   SEQUIUM HD — MERCH STOREFRONT
   Represent-style: pure white, jet black, uppercase grotesque, full-bleed.
   Everything is namespaced under .smd-merch so it cannot leak into SMD.
   Enqueued only on /merch + merch product pages (functions.php).
   ===================================================================== */

.smd-merch,
.smd-merch * { box-sizing: border-box; }

.smd-merch {
	margin: 0;
	background: #fff;
	color: #0a0a0a;
	font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
	font-size: 15px;
	line-height: 1.5;
	-webkit-font-smoothing: antialiased;
	letter-spacing: .01em;
}
.smd-merch img { max-width: 100%; height: auto; display: block; }
.smd-merch a { color: inherit; text-decoration: none; }
.smd-merch h1, .smd-merch h2, .smd-merch h3 { margin: 0; font-weight: 700; }
/* Force Helvetica everywhere — the Tripgo/Elementor theme applies a serif heading
   font + dark heading colours that would otherwise leak into the merch chrome. */
.smd-merch h1, .smd-merch h2, .smd-merch h3, .smd-merch h4, .smd-merch h5, .smd-merch h6,
.smd-merch p, .smd-merch a, .smd-merch span, .smd-merch button,
.smd-merch input, .smd-merch select, .smd-merch label, .smd-merch summary, .smd-merch li {
	font-family: "Helvetica Neue", Helvetica, Arial, sans-serif !important;
}
.smd-merch h1, .smd-merch h2, .smd-merch h3, .smd-merch h4 { color: inherit; }
/* The Tripgo theme sets overflow-x:hidden on html/body at mobile widths, which
   breaks the sticky header (it scrolls off instead of pinning + turning black).
   overflow-x:clip stops horizontal scroll WITHOUT creating a scroll container. */
html:has(body.smd-merch) { overflow-x: clip !important; }
body.smd-merch { overflow-x: clip !important; }

.smd-merch .merch-btn {
	display: inline-block; padding: 15px 34px; font-size: 12px; font-weight: 700;
	letter-spacing: .18em; text-transform: uppercase; border: 1.5px solid #0a0a0a;
	background: #0a0a0a; color: #fff; cursor: pointer; transition: background .18s, color .18s;
}
.smd-merch .merch-btn:hover { background: #fff; color: #0a0a0a; }
.smd-merch .merch-btn--light { background: #fff; color: #0a0a0a; border-color: #fff; }
.smd-merch .merch-btn--light:hover { background: transparent; color: #fff; border-color: #fff; }

/* ---------- Announcement bar ---------- */
.merch-announce {
	background: #0a0a0a; color: #fff; text-align: center;
	font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
	padding: 9px 16px; overflow: hidden;
}

/* ---------- Header (dark; white logo) ---------- */
.merch-header {
	position: sticky; top: 0; z-index: 60; background: #0a0a0a; color: #fff;
	border-bottom: 1px solid rgba(255,255,255,.12);
	transition: background .3s ease, border-color .3s ease;
}
.merch-header a, .merch-header .merch-wordmark, .merch-header .merch-icon { color: #fff; }
/* Home: transparent over the hero, turning solid black once scrolled. */
.smd-merch-home .merch-header { background: transparent; border-color: transparent; }
.smd-merch-home .merch-header.is-scrolled { background: #0a0a0a; border-color: rgba(255,255,255,.12); }
.merch-header__inner {
	display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
	gap: 16px; max-width: 1680px; margin: 0 auto; padding: 18px 28px;
}
.merch-header__left { display: flex; align-items: center; }
.merch-header__right { display: flex; align-items: center; justify-content: flex-end; gap: 16px; }
.merch-nav { display: flex; gap: 26px; }
.merch-nav a {
	font-size: 12px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
	padding: 4px 0; border-bottom: 1.5px solid transparent; transition: border-color .15s;
}
.merch-nav a:hover { border-color: #0a0a0a; }

.merch-logo { justify-self: center; display: flex; align-items: center; }
/* Logo rendered as a CSS mask filled with currentColor (white in header). Vector-
   crisp at any DPR; avoids the masked-SVG-as-<img> flatten/blur glitches. */
.merch-logo-mark {
	display: inline-block; width: 46px; height: 46px; background-color: currentColor;
	-webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
	-webkit-mask-position: center; mask-position: center;
	-webkit-mask-size: contain; mask-size: contain;
}
/* Inline-SVG logo: vector-crisp, no load flash, recoloured via currentColor. */
.merch-logo-mark--svg { background-color: transparent; -webkit-mask: none; mask: none; }
.merch-logo-mark--svg svg { width: 100%; height: 100%; display: block; fill: currentColor; }
.merch-logo-mark--svg svg path, .merch-logo-mark--svg svg rect,
.merch-logo-mark--svg svg circle, .merch-logo-mark--svg svg polygon { fill: currentColor; }

/* Bundled SMD logo asset (raster-in-SVG): force WHITE in the dark header and BLACK
   in the white footer with CSS filters, so one black asset serves both contexts. */
.merch-logo-img { width: 46px; height: 46px; object-fit: contain; display: block; }
.merch-header .merch-logo-img { filter: none; }                          /* source is already white */
.merch-footer__logo .merch-logo-img { width: 54px; height: 54px; filter: brightness(0); } /* white -> black on the light footer */
.merch-logo .merch-wordmark {
	font-size: 22px; font-weight: 800; letter-spacing: .26em; text-transform: uppercase;
}

.merch-icon {
	background: none; border: 0; padding: 0; cursor: pointer; color: #0a0a0a;
	display: inline-flex; position: relative;
}
.merch-icon svg { width: 22px; height: 22px; }
.merch-cart__count {
	position: absolute; top: -7px; right: -9px; min-width: 16px; height: 16px;
	background: #fff; color: #0a0a0a; border-radius: 9px; font-size: 10px; font-weight: 700;
	display: none; align-items: center; justify-content: center; padding: 0 4px;
}
.merch-cart__count.is-on { display: inline-flex; }

.merch-burger { display: none; background: none; border: 0; cursor: pointer; flex-direction: column; gap: 4px; padding: 6px; }
.merch-burger span { width: 22px; height: 2px; background: #fff; display: block; }

/* ---------- Mobile drawer ---------- */
.merch-drawer { position: fixed; inset: 0; z-index: 100; visibility: hidden; }
.merch-drawer.is-open { visibility: visible; }
.merch-drawer__scrim { position: absolute; inset: 0; background: rgba(0,0,0,.45); opacity: 0; transition: opacity .25s; }
.merch-drawer.is-open .merch-drawer__scrim { opacity: 1; }
.merch-drawer__panel {
	position: absolute; top: 0; left: 0; height: 100%; width: min(82vw, 340px);
	background: #fff; padding: 76px 28px 28px; transform: translateX(-100%); transition: transform .28s ease;
	display: flex; flex-direction: column; gap: 4px; z-index: 2;
}
.merch-drawer.is-open .merch-drawer__panel { transform: translateX(0); }
.merch-drawer__panel a {
	font-size: 15px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
	padding: 14px 0; border-bottom: 1px solid #eee;
}
.merch-drawer__close { position: absolute; top: 20px; right: 22px; font-size: 30px; line-height: 1; background: none; border: 0; cursor: pointer; }

/* ---------- Hero banner ---------- */
.merch-hero {
	position: relative; width: 100%; min-height: clamp(420px, 56vw, 760px);
	background-size: cover; background-position: center; display: flex; align-items: flex-end;
}
.merch-hero.is-placeholder {
	background: linear-gradient(135deg, #d9d9d9 0%, #bdbdbd 45%, #9c9c9c 100%);
}
/* Real banner: show the full image (no crop), full-bleed. */
.merch-hero.has-banner { display: block; min-height: 0; }
.merch-hero__img { width: 100%; height: auto; display: block; }
/* Subtle top scrim so the white logo/nav stay legible over a light banner. */
.merch-hero.has-banner::before {
	content: ""; position: absolute; top: 0; left: 0; right: 0; height: 200px; z-index: 1;
	background: linear-gradient(rgba(0,0,0,.55), rgba(0,0,0,0)); pointer-events: none;
}
.merch-hero__overlay {
	width: 100%; padding: 0 28px 56px; text-align: center; color: #fff;
	display: flex; flex-direction: column; align-items: center; gap: 14px;
	text-shadow: 0 2px 18px rgba(0,0,0,.35);
}
.merch-hero__title { font-size: clamp(34px, 6vw, 76px); font-weight: 800; letter-spacing: .04em; text-transform: uppercase; }
.merch-hero__sub { font-size: 13px; letter-spacing: .24em; text-transform: uppercase; margin: 0; }

/* ---------- Product rail ---------- */
.merch-rail-wrap { max-width: 1680px; margin: 0 auto; padding: 64px 0 72px; }
.merch-rail-head {
	display: flex; align-items: center; justify-content: space-between;
	padding: 0 28px 22px;
}
.merch-rail-title { font-size: 13px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; }
.merch-rail-arrows { display: flex; gap: 8px; }
.merch-rail-arrow {
	width: 40px; height: 40px; border: 1.5px solid #d8d8d8; background: #fff; cursor: pointer;
	font-size: 16px; line-height: 1; transition: border-color .15s, background .15s, color .15s;
}
.merch-rail-arrow:hover { border-color: #0a0a0a; }

.merch-rail {
	display: flex; gap: 18px; overflow-x: auto; scroll-snap-type: x mandatory;
	/* overflow-x:auto forces overflow-y to clip too, so reserve bottom slack or the
	   colour dots (and their tap/hover ring) at the card's base get shaved off. */
	padding: 2px 28px 16px; scroll-behavior: smooth; scrollbar-width: none;
}
.merch-rail::-webkit-scrollbar { display: none; }
.merch-rail-empty { padding: 0 28px; color: #777; letter-spacing: .1em; text-transform: uppercase; font-size: 13px; }

.merch-card { flex: 0 0 clamp(240px, 25vw, 320px); scroll-snap-align: start; }
.merch-card__media { background: #fff; aspect-ratio: 3/4; overflow: hidden; }
.merch-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.merch-card:hover .merch-card__media img { transform: scale(1.04); }
.merch-card__info { padding: 14px 2px 4px; display: flex; flex-direction: column; gap: 4px; }
.merch-card__name { font-size: 13px; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; }
.merch-card__price { font-size: 13px; color: #111; }
.merch-card__price del { color: #aaa; margin-right: 6px; }
.merch-card__colours { font-size: 11px; color: #999; letter-spacing: .08em; text-transform: uppercase; }
/* Colour dots on shop cards (hover/tap swaps the card image to that colour). */
.merch-card__swatches { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 6px; }
.merch-card__dot {
	width: 16px; height: 16px; border-radius: 50%; cursor: pointer; display: inline-block;
	border: 1px solid rgba(0,0,0,.2); background-clip: padding-box;
	box-shadow: 0 0 0 1.5px transparent; transition: box-shadow .12s ease;
}
.merch-card__dot:hover, .merch-card__dot.is-active { box-shadow: 0 0 0 1.5px #0a0a0a; }

/* ---------- PDP (single product) ---------- */
.merch-crumbs { max-width: 1680px; margin: 0 auto; padding: 20px 28px; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: #999; display: flex; gap: 8px; }
.merch-crumbs a:hover { color: #0a0a0a; }

.merch-pdp { max-width: 1680px; margin: 0 auto; display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; padding: 0 28px 80px; align-items: start; }
.merch-pdp > * { min-width: 0; } /* stop a wide child (variations/button) blowing out the grid track */
.merch-pdp__gallery { display: flex; flex-direction: column; gap: 10px; }
.merch-pdp__shot { background: #fff; aspect-ratio: 1 / 1; overflow: hidden; }
.merch-pdp__shot img { width: 100%; height: 100%; object-fit: contain; transition: opacity .15s ease; }

.merch-pdp__summary { position: sticky; top: 110px; }
.merch-pdp__summary-inner { max-width: 460px; }
.merch-pdp__title { font-size: clamp(22px, 2.4vw, 30px); font-weight: 800; letter-spacing: .02em; text-transform: uppercase; }
.merch-pdp__price { font-size: 18px; margin: 14px 0 22px; }
.merch-pdp__excerpt { color: #555; margin-bottom: 26px; }

/* WooCommerce add-to-cart form, restyled */
.merch-pdp__cart .quantity { display: none !important; } /* apparel = qty 1 default */
.merch-pdp__cart .variations,
.merch-pdp__cart .single_variation_wrap { max-width: 100%; }
.merch-pdp__cart .variations { width: 100%; margin-bottom: 18px; border: 0; }
/* The parent Tripgo theme draws a bordered/rounded box around table cells; strip it
   so only the size <select>'s own border shows (not an outer box around the group). */
.merch-pdp__cart .variations,
.merch-pdp__cart .variations tbody,
.merch-pdp__cart .variations tr,
.merch-pdp__cart .variations td,
.merch-pdp__cart .variations th {
	border: 0 !important; background: transparent !important; border-radius: 0 !important; box-shadow: none !important;
}
.merch-pdp__cart .variations td, .merch-pdp__cart .variations th { display: block; padding: 0 0 10px; text-align: left; }
.merch-pdp__cart .variations label { font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.merch-pdp__cart select {
	width: 100%; padding: 14px 16px; border: 1.5px solid #d8d8d8; background: #fff;
	font-size: 14px; text-transform: uppercase; letter-spacing: .06em; border-radius: 0;
}

/* Colour swatches — replace the colour dropdown with clickable dots (built in JS). */
.merch-swatch-row { margin-bottom: 20px; }
.merch-swatch-row .merch-swatch-label { font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; display: block; margin-bottom: 11px; }
.merch-swatch-row .merch-swatch-label em { font-style: normal; font-weight: 500; color: #777; letter-spacing: .03em; text-transform: none; }
.merch-swatches { display: flex; flex-wrap: wrap; gap: 11px; }
.merch-swatch {
	width: 30px; height: 30px; border-radius: 50%; cursor: pointer; padding: 0;
	border: 1px solid rgba(0,0,0,.2); background-clip: padding-box;
	box-shadow: 0 0 0 2px transparent; transition: box-shadow .12s ease, transform .12s ease;
}
.merch-swatch:hover { transform: scale(1.08); }
.merch-swatch.is-active { box-shadow: 0 0 0 2px #fff, 0 0 0 3.5px #0a0a0a; }
.merch-pdp__cart .button,
.merch-pdp__cart button[type="submit"],
.merch-pdp__cart .single_add_to_cart_button {
	width: 100% !important; padding: 18px 24px !important; background: #0a0a0a !important; color: #fff !important;
	border: 1.5px solid #0a0a0a !important; border-radius: 0 !important; box-shadow: none !important;
	font-size: 12px !important; font-weight: 700 !important; letter-spacing: .2em !important; text-transform: uppercase !important;
	cursor: pointer; transition: background .18s, color .18s !important; margin: 0 !important;
}
.merch-pdp__cart .button:hover,
.merch-pdp__cart .single_add_to_cart_button:hover { background: #fff !important; color: #0a0a0a !important; }
/* Disabled state (before a size/colour is chosen) — keep it square too; the
   theme's default disabled style rounds it. */
.merch-pdp__cart .single_add_to_cart_button.disabled,
.merch-pdp__cart .single_add_to_cart_button:disabled,
.merch-pdp__cart .single_add_to_cart_button.wc-variation-selection-needed { border-radius: 0 !important; }
/* The trips theme rounds this button via `.single-product form.cart
   .single_add_to_cart_button { border-radius:12px !important }`, which is more
   specific than the rules above — out-specify it so merch stays square. */
body.smd-merch .merch-pdp__cart button.single_add_to_cart_button,
body.smd-merch .merch-pdp__cart button.single_add_to_cart_button.disabled { border-radius: 0 !important; }

/* Accordion */
.merch-acc { margin-top: 30px; border-top: 1px solid #e6e6e6; }
.merch-acc__item { border-bottom: 1px solid #e6e6e6; }
.merch-acc__item summary {
	list-style: none; cursor: pointer; padding: 18px 0; font-size: 12px; font-weight: 700;
	letter-spacing: .14em; text-transform: uppercase; display: flex; justify-content: space-between; align-items: center;
}
.merch-acc__item summary::-webkit-details-marker { display: none; }
.merch-acc__item summary::after { content: "+"; font-size: 18px; font-weight: 400; }
.merch-acc__item[open] summary::after { content: "\2212"; }
.merch-acc__body { padding: 0 0 20px; color: #555; font-size: 14px; }
/* Headings inside the description (Printify copy: "Product Details", "Fit", …)
   match the section label (DESCRIPTION) — small, uppercase, tracked — instead of
   rendering as big bold theme headings. */
.merch-acc__body h1, .merch-acc__body h2, .merch-acc__body h3,
.merch-acc__body h4, .merch-acc__body h5, .merch-acc__body h6 {
	font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
	color: #0a0a0a; margin: 24px 0 10px; line-height: 1.4;
}

/* Size chart — lifted from the product description into its own accordion.
   Scrolls horizontally on narrow screens so wide grids never break the layout. */
.merch-sizechart { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.merch-sizechart table { width: 100%; border-collapse: collapse; font-size: 13px; min-width: 320px; color: #0a0a0a; }
.merch-sizechart th, .merch-sizechart td { border: 1px solid #e6e6e6; padding: 9px 12px; text-align: center; white-space: nowrap; }
.merch-sizechart thead th,
.merch-sizechart tr:first-child th,
.merch-sizechart tr:first-child td { background: #f7f7f7; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; font-size: 11px; }

/* ---------- Legal / content pages (Privacy, Terms, Delivery & Returns) ---------- */
.merch-legal { max-width: 820px; margin: 0 auto; padding: 8px 28px 80px; }
.merch-legal__title { font-size: clamp(26px, 4vw, 40px); font-weight: 800; letter-spacing: .02em; text-transform: uppercase; margin-bottom: 26px; }
.merch-legal__body { color: #333; font-size: 15px; line-height: 1.7; }
.merch-legal__body h2 { font-size: 15px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; margin: 34px 0 12px; }
.merch-legal__body p { margin: 0 0 16px; }
.merch-legal__body ul { margin: 0 0 16px; padding-left: 20px; }
.merch-legal__body li { margin: 0 0 8px; }
.merch-legal__body a { text-decoration: underline; }
.merch-legal__body a:hover { color: #000; }
.merch-legal__meta { font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: #999; margin-bottom: 24px; }

/* ---------- Size Guide ---------- */
.merch-sizeguide__group { margin: 38px 0 0; }
.merch-sizeguide__heading { font-size: 13px; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; color: #0a0a0a; margin: 0 0 4px; padding-bottom: 12px; border-bottom: 2px solid #0a0a0a; }
.merch-sizeguide__applies { font-size: 12px; color: #999; letter-spacing: .02em; text-transform: none; margin: 10px 0 14px; }
.merch-sizeguide .merch-sizechart { margin-top: 8px; }
.merch-sizeguide .merch-sizechart table { min-width: 480px; }

/* ---------- Contact page (merch-branded) ---------- */
.merch-contact { max-width: 1180px; margin: 0 auto; padding: 8px 28px 80px; }
.merch-contact__head { max-width: 640px; margin-bottom: 36px; }
.merch-contact__title { font-size: clamp(26px, 4vw, 40px); font-weight: 800; letter-spacing: .02em; text-transform: uppercase; margin-bottom: 14px; }
.merch-contact__sub { color: #555; font-size: 16px; line-height: 1.6; }
.merch-contact__grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 48px; align-items: start; }
.merch-contact__rail { display: flex; flex-direction: column; gap: 28px; }
.merch-contact__block h2 { font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; margin-bottom: 12px; }
.merch-contact__block p { color: #555; font-size: 14px; line-height: 1.6; margin: 0; }
.merch-contact__link { display: block; font-size: 14px; padding: 4px 0; border-bottom: 1px solid #eee; }
.merch-contact__link:hover { color: #000; }
.merch-contact__social { display: flex; gap: 14px; }
.merch-contact__social a { width: 40px; height: 40px; border: 1.5px solid #d8d8d8; display: inline-flex; align-items: center; justify-content: center; color: #0a0a0a; transition: border-color .15s, background .15s, color .15s; }
.merch-contact__social a:hover { border-color: #0a0a0a; background: #0a0a0a; color: #fff; }
.merch-contact__social svg { width: 18px; height: 18px; }

/* Bespoke contact form */
.merch-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.merch-form label, .merch-form__full { display: block; font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: #0a0a0a; margin-bottom: 16px; }
.merch-form input, .merch-form select, .merch-form textarea {
	display: block; width: 100%; margin-top: 9px; padding: 13px 14px; border: 1.5px solid #d8d8d8;
	background: #fff; font-size: 14px; border-radius: 0; color: #0a0a0a; font-family: inherit; letter-spacing: normal; text-transform: none;
}
.merch-form textarea { resize: vertical; }
.merch-form input:focus, .merch-form select:focus, .merch-form textarea:focus { outline: none; border-color: #0a0a0a; }
.merch-form__hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }
.merch-form__submit {
	margin-top: 6px; padding: 15px 36px; background: #0a0a0a; color: #fff; border: 1.5px solid #0a0a0a;
	font-size: 12px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; cursor: pointer; transition: background .18s, color .18s;
}
.merch-form__submit:hover { background: #fff; color: #0a0a0a; }
.merch-contact__thanks h2 { font-size: 20px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; margin-bottom: 10px; }
.merch-contact__thanks p { color: #555; }
.merch-contact__error { color: #b3261e; font-weight: 600; margin-bottom: 18px; }
@media (max-width: 560px) { .merch-form__row { grid-template-columns: 1fr; gap: 0; } }

/* WPForms restyle inside the merch contact (black/white, square) */
.merch-contact .wpforms-field-label { font-size: 11px !important; font-weight: 700 !important; letter-spacing: .12em !important; text-transform: uppercase !important; color: #0a0a0a !important; }
.merch-contact .wpforms-field input[type=text],
.merch-contact .wpforms-field input[type=email],
.merch-contact .wpforms-field textarea {
	width: 100% !important; max-width: 100% !important; border: 1.5px solid #d8d8d8 !important; border-radius: 0 !important;
	padding: 14px 16px !important; font-size: 14px !important; background: #fff !important;
}
.merch-contact .wpforms-field input:focus,
.merch-contact .wpforms-field textarea:focus { border-color: #0a0a0a !important; box-shadow: none !important; outline: none !important; }
.merch-contact .wpforms-submit {
	background: #0a0a0a !important; color: #fff !important; border: 1.5px solid #0a0a0a !important; border-radius: 0 !important;
	padding: 16px 34px !important; font-size: 12px !important; font-weight: 700 !important; letter-spacing: .2em !important;
	text-transform: uppercase !important; box-shadow: none !important; cursor: pointer; transition: background .18s, color .18s !important;
}
.merch-contact .wpforms-submit:hover { background: #fff !important; color: #0a0a0a !important; }

@media (max-width: 860px) {
	.merch-contact__grid { grid-template-columns: 1fr; gap: 36px; }
}

/* ---------- Newsletter ---------- */
.merch-news { background: #0a0a0a; color: #fff; padding: 70px 28px; text-align: center; }
.merch-news__title { font-size: clamp(22px, 3vw, 34px); font-weight: 800; letter-spacing: .04em; text-transform: uppercase; }
.merch-news__sub { color: #bbb; margin: 12px 0 26px; font-size: 14px; }
.merch-news__form { display: flex; max-width: 480px; margin: 0 auto; gap: 0; }
.merch-news__form input {
	flex: 1; padding: 16px 18px; border: 1.5px solid #444; background: #111; color: #fff;
	font-size: 14px; letter-spacing: .04em; border-radius: 0;
}
.merch-news__form input::placeholder { color: #888; text-transform: uppercase; letter-spacing: .1em; font-size: 12px; }
.merch-news__form button {
	padding: 16px 28px; background: #fff; color: #0a0a0a; border: 1.5px solid #fff; cursor: pointer;
	font-size: 12px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; border-radius: 0;
}
.merch-news__form button:hover { background: transparent; color: #fff; }

/* ---------- Footer ---------- */
.merch-footer { background: #fff; color: #0a0a0a; border-top: 1px solid #ededed; padding: 60px 28px 26px; }
.merch-footer__cols { max-width: 1680px; margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr) 1.3fr; gap: 40px; }
.merch-footer__col h3 { font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; margin-bottom: 16px; }
.merch-footer__col a { display: block; font-size: 13px; color: #555; padding: 6px 0; }
.merch-footer__col a:hover { color: #0a0a0a; }
.merch-footer__brand { align-items: flex-start; }
/* Footer logo: currentColor is black here (footer text colour), so the masked logo
   renders black on the white footer. */
.merch-footer__logo .merch-logo-mark { width: 54px; height: 54px; }
.merch-footer__logo .merch-wordmark { font-size: 18px; font-weight: 800; letter-spacing: .24em; text-transform: uppercase; }
.merch-footer__social { display: flex; gap: 14px; margin-top: 18px; }
.merch-footer__social a { color: #0a0a0a; }
.merch-footer__social svg { width: 22px; height: 22px; }
.merch-footer__bar {
	max-width: 1680px; margin: 40px auto 0; padding-top: 22px; border-top: 1px solid #ededed;
	display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
	font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: #999;
}

/* ---------- Responsive ---------- */
@media (max-width: 1000px) {
	.merch-pdp { grid-template-columns: 1fr; gap: 28px; }
	.merch-pdp__summary { position: static; }
	.merch-pdp__summary-inner { max-width: none; }
}
@media (max-width: 860px) {
	.merch-nav { display: none; }
	.merch-burger { display: flex; }
	.merch-header__inner { padding: 14px 18px; }
	.merch-footer__cols { grid-template-columns: 1fr 1fr; gap: 30px 24px; }
	.merch-footer__brand { grid-column: 1 / -1; }
	.merch-rail-arrows { display: none; }
	.merch-footer__pay { display: none; } /* hide VISA/MASTERCARD/AMEX line on mobile */
}
@media (max-width: 520px) {
	.merch-pdp__gallery { grid-template-columns: 1fr; }
	.merch-pdp__shot, .merch-pdp__shot:first-child { aspect-ratio: 4/5; }
	.merch-news__form { flex-direction: column; gap: 10px; }
}
