/* ==========================================================================
   SPV WHOLESALE — "Dark Premium Tech" design system
   Solar Power PV · Trade & Wholesale
   ========================================================================== */

@font-face {
	font-family: 'Inter';
	src: url('../fonts/inter-var.woff2') format('woff2');
	font-weight: 100 900; font-style: normal; font-display: swap;
}
@font-face {
	font-family: 'Sora';
	src: url('../fonts/sora-var.woff2') format('woff2');
	font-weight: 400 800; font-style: normal; font-display: swap;
}

:root {
	--bg: #090d14;
	--bg-1: #0c111a;
	--panel: #121925;
	--panel-2: #18212f;
	--panel-3: #1d2838;
	--line: rgba(255,255,255,.09);
	--line-2: rgba(255,255,255,.055);
	--text: #e9eff7;
	--text-dim: #9caabe;
	--text-mute: #8593a8;
	--amber: #ffb020;
	--amber-2: #ffc658;
	--amber-soft: rgba(255,176,32,.14);
	--mint: #46e6c0;
	--mint-soft: rgba(70,230,192,.12);
	--well: #eef1f6;          /* light well for white-bg product photos */
	--on-amber: #0a0e15;

	--font-body: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
	--font-display: 'Sora', var(--font-body);

	--wrap: 1220px;
	--wrap-narrow: 840px;
	--r-sm: 8px; --r: 14px; --r-lg: 20px; --r-xl: 28px;
	--sh-2: 0 18px 40px rgba(0,0,0,.45);
	--sh-3: 0 30px 70px rgba(0,0,0,.6);
	--gut: clamp(16px, 4vw, 30px);
	--sec: clamp(60px, 9vw, 124px);
	--ease: cubic-bezier(.22,.61,.36,1);
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; scroll-padding-top: 96px; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
	margin: 0;
	font-family: var(--font-body);
	color: var(--text);
	background: var(--bg);
	font-size: 17px;
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--text); text-decoration: none; transition: color .18s var(--ease); }
a:hover { color: var(--amber); }
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 700; line-height: 1.04; letter-spacing: -.025em; margin: 0 0 .5em; color: #fff; }
h1 { font-size: clamp(2.4rem, 6vw, 4.4rem); }
h2 { font-size: clamp(1.9rem, 4vw, 3rem); }
h3 { font-size: clamp(1.2rem, 1.9vw, 1.45rem); }
p { margin: 0 0 1.1em; color: var(--text-dim); }
ul, ol { margin: 0; padding: 0; }
strong { font-weight: 700; color: #fff; }
::selection { background: var(--amber); color: var(--on-amber); }
:focus-visible { outline: 2px solid var(--amber); outline-offset: 3px; border-radius: 4px; }

.ico { flex: none; vertical-align: middle; }
.muted { color: var(--text-mute); }

/* ---- Layout --------------------------------------------------------------- */
.wrap { width: 100%; max-width: var(--wrap); margin-inline: auto; padding-inline: var(--gut); }
.wrap--narrow { max-width: var(--wrap-narrow); }
.section { padding-block: var(--sec); position: relative; }
.section--tight { padding-block: clamp(40px, 6vw, 72px); }
.section--mist { background: var(--bg-1); }
.section--ink { background: var(--bg-1); }
.section + .section, .section--mist + .section--mist { border-top: 1px solid var(--line-2); }

.skip-link { position: absolute; left: -999px; top: 0; background: var(--amber); color: var(--on-amber); padding: 10px 16px; z-index: 200; border-radius: 0 0 8px 0; font-weight: 600; }
.skip-link:focus { left: 0; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ---- Eyebrow (clean label, no pill, no icon) ------------------------------ */
.eyebrow {
	display: inline-flex; align-items: center; gap: 10px;
	font-family: var(--font-display); font-weight: 600; font-size: .8rem;
	letter-spacing: .18em; text-transform: uppercase;
	color: var(--amber); background: none; padding: 0; margin-bottom: 22px; border-radius: 0;
}
.eyebrow::before { content: ''; width: 26px; height: 1px; background: var(--amber); opacity: .7; }
.eyebrow .ico { display: none; }            /* drop the emoji-in-pill icons */
.eyebrow--solar { color: var(--amber); }
.section--ink .eyebrow { color: var(--amber); }

.sec-head { max-width: 760px; margin: 0 auto clamp(40px, 5vw, 64px); }
.sec-head .eyebrow::before { display: none; }
.sec-head .eyebrow { gap: 0; }
.sec-head p { color: var(--text-dim); font-size: 1.12rem; margin: 0; }
.sec-head--row { display: flex; align-items: flex-end; justify-content: space-between; gap: 28px; max-width: none; margin-bottom: 44px; }
.sec-head--row .eyebrow { margin-bottom: 14px; }
.sec-head--row h2 { margin: 0; }
.lead { font-size: 1.22rem; color: var(--text-dim); line-height: 1.55; }

/* ---- Buttons -------------------------------------------------------------- */
.btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 10px;
	font-family: var(--font-display); font-weight: 600; font-size: .98rem;
	padding: 14px 24px; border-radius: 100px; border: 1px solid transparent;
	cursor: pointer; transition: transform .15s var(--ease), box-shadow .25s var(--ease), background .2s, color .2s, border-color .2s;
	line-height: 1; white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn .ico { transition: transform .2s var(--ease); }
.btn:hover .ico { transform: translateX(3px); }
.btn-lg { padding: 17px 30px; font-size: 1.05rem; }

.btn-solar { background: var(--amber); color: var(--on-amber); box-shadow: 0 0 0 0 var(--amber-soft); }
.btn-solar:hover { background: var(--amber-2); color: var(--on-amber); box-shadow: 0 10px 34px rgba(255,176,32,.34); transform: translateY(-2px); }
.btn-dark { background: rgba(255,255,255,.06); color: #fff; border-color: var(--line); }
.btn-dark:hover { background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.25); transform: translateY(-2px); }
.btn-ghost { background: transparent; color: #fff; border-color: var(--line); }
.btn-ghost:hover { border-color: var(--amber); color: var(--amber); background: var(--amber-soft); }
.btn-ghost-light { background: rgba(255,255,255,.05); color: #fff; border-color: rgba(255,255,255,.22); }
.btn-ghost-light:hover { background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.5); }

.link-arrow { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-display); font-weight: 600; color: var(--amber); min-height: 44px; }
.link-arrow .ico { transition: transform .2s var(--ease); }
.link-arrow:hover { color: var(--amber-2); }
.link-arrow:hover .ico { transform: translateX(4px); }

/* ---- Brandmark ------------------------------------------------------------ */
.brandmark { display: inline-flex; align-items: stretch; gap: 12px; }
.brandmark__bar { width: 4px; flex: none; border-radius: 4px; background: linear-gradient(180deg, var(--amber-2), #ff7a00); box-shadow: 0 0 14px rgba(255,176,32,.55); }
.brandmark__stack { display: flex; flex-direction: column; justify-content: center; line-height: 1; }
.brandmark__word { font-family: var(--font-display); font-weight: 800; font-size: 1.42rem; letter-spacing: -.035em; color: #fff; }
.brandmark__word b { color: var(--amber); font-weight: 800; margin-left: .14em; }
.brandmark__sub { font-size: .6rem; font-weight: 600; letter-spacing: .3em; text-transform: uppercase; color: var(--text-mute); margin-top: 6px; }

/* ---- Topbar --------------------------------------------------------------- */
.topbar { background: #05080d; color: var(--text-mute); font-size: .82rem; border-bottom: 1px solid var(--line-2); }
.topbar__inner { display: flex; align-items: center; justify-content: space-between; min-height: 40px; gap: 16px; }
.topbar__msg { display: inline-flex; align-items: center; gap: 9px; margin: 0; color: var(--text-dim); }
.topbar__msg .ico { color: var(--amber); }
.topbar__links { display: flex; align-items: center; gap: 24px; }
.topbar__links a { display: inline-flex; align-items: center; gap: 7px; color: var(--text-dim); font-weight: 500; }
.topbar__links a:hover { color: #fff; }
.topbar__links .ico { color: var(--amber); }
.topbar__account { padding: 5px 13px; border: 1px solid var(--line); border-radius: 100px; }

/* ---- Header --------------------------------------------------------------- */
.site-header { position: sticky; top: 0; z-index: 100; background: rgba(9,13,20,.72); backdrop-filter: saturate(1.5) blur(14px); border-bottom: 1px solid transparent; transition: border-color .25s, background .25s; }
.site-header.is-stuck { border-bottom-color: var(--line); background: rgba(9,13,20,.9); }
.site-header__inner { display: flex; align-items: center; justify-content: space-between; min-height: 80px; gap: 20px; }
.site-header__brand { flex: none; }

.primary-nav { display: flex; align-items: center; gap: 20px; }
.primary-nav__list { display: flex; align-items: center; gap: 2px; list-style: none; }
.primary-nav__list a { display: inline-block; font-family: var(--font-display); font-weight: 500; font-size: .97rem; color: var(--text-dim); padding: 9px 15px; border-radius: 8px; }
.primary-nav__list > li > a:hover, .primary-nav__list .current-menu-item > a { color: #fff; background: rgba(255,255,255,.05); }
.primary-nav__cta { display: flex; align-items: center; gap: 2px; }
.header-util { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-display); font-weight: 500; font-size: .9rem; color: var(--text-dim); padding: 9px 11px; border-radius: 8px; white-space: nowrap; border: 0; background: transparent; cursor: pointer; }
.header-util:hover { color: #fff; background: rgba(255,255,255,.06); }
.header-util .ico { color: var(--amber); }
.header-util--phone .header-util__label { display: none; }
/* Cart: icon-only on desktop, label only in mobile nav */
@media (min-width: 1101px) { .cart-btn .header-util__label { display: none; } }
/* Visual separator + gap before the amber CTA pill */
.primary-nav__cta > .btn { margin-left: 16px; }
.primary-nav__cta > .btn::before { content: ''; display: block; position: absolute; left: -9px; top: 20%; height: 60%; width: 1px; background: var(--line); pointer-events: none; }
.primary-nav__cta > .btn { position: relative; }
@media (max-width: 1280px) and (min-width: 1101px) { .header-util__label { display: none; } .primary-nav { gap: 16px; } .primary-nav__list a { padding: 9px 11px; } }
@media (max-width: 1100px) { .header-util__label, .header-util--phone .header-util__label { display: inline; } }

/* ---- Carousel ------------------------------------------------------------- */
.carousel { position: relative; }
.carousel__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 28px; }
.carousel__heading h2 { margin: 0; }
.carousel__heading .eyebrow { margin-bottom: 12px; }
.carousel__controls { display: flex; align-items: center; gap: 10px; flex: none; }
.carousel__viewall { white-space: nowrap; }
.carousel__btn { width: 46px; height: 46px; border-radius: 50%; background: var(--panel); border: 1px solid var(--line); color: #fff; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: .18s var(--ease); flex: none; }
.carousel__btn:hover:not(:disabled) { background: var(--amber); color: var(--on-amber); border-color: var(--amber); }
.carousel__btn:disabled { opacity: .3; cursor: default; }
.carousel__btn[data-dir="prev"] .ico { transform: rotate(180deg); }
.carousel__track { display: flex; gap: 18px; overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth; padding-bottom: 8px; margin-inline: calc(var(--gut) * -1); padding-inline: var(--gut); scrollbar-width: none; -ms-overflow-style: none; }
.carousel__track::-webkit-scrollbar { display: none; }
.carousel__track.is-dragging { scroll-behavior: auto; cursor: grabbing; scroll-snap-type: none; }
.carousel__track.is-dragging a { pointer-events: none; }
.carousel__item { flex: 0 0 auto; width: clamp(238px, 78vw, 286px); scroll-snap-align: start; }
.carousel__item .pcard { height: 100%; }

.primary-nav__list .sub-menu { position: absolute; min-width: 230px; background: var(--panel); border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--sh-2); padding: 8px; margin-top: 10px; list-style: none; opacity: 0; visibility: hidden; transform: translateY(6px); transition: .18s var(--ease); z-index: 50; }
.primary-nav__list li { position: relative; }
.primary-nav__list li:hover > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.primary-nav__list .sub-menu a { display: block; padding: 9px 12px; font-size: .92rem; }

/* Mobile header right group: cart + hamburger, hidden on desktop */
.header-mob-right { display: none; align-items: center; gap: 8px; }
.mob-cart-btn { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border: 1px solid var(--line); border-radius: var(--r-sm); background: rgba(255,255,255,.05); color: var(--amber); cursor: pointer; position: relative; }
.mob-cart-btn:hover { background: rgba(255,255,255,.1); }
.mob-cart-btn .ico { display: block; }
@media (max-width: 1100px) { .header-mob-right { display: flex; } }

.nav-toggle { display: none; flex-direction: column; gap: 5px; width: 46px; height: 44px; align-items: center; justify-content: center; background: rgba(255,255,255,.05); border: 1px solid var(--line); border-radius: var(--r-sm); cursor: pointer; }
.nav-toggle__bar { width: 22px; height: 2px; background: #fff; border-radius: 2px; transition: .22s var(--ease); }
body.nav-open .nav-toggle__bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
body.nav-open .nav-toggle__bar:nth-child(2) { opacity: 0; }
body.nav-open .nav-toggle__bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.nav-backdrop { display: none; position: fixed; inset: 0; z-index: 98; background: rgba(0,0,0,.55); pointer-events: none; }
body.nav-open .nav-backdrop { display: block; }

/* ---- Hero ----------------------------------------------------------------- */
.hero { position: relative; background: radial-gradient(120% 90% at 78% 8%, #14233a 0%, #0a101b 46%, var(--bg) 100%); color: #fff; overflow: hidden; border-bottom: 1px solid var(--line-2); }
.hero__bg { position: absolute; inset: 0; pointer-events: none; }
.hero__rays { position: absolute; top: -22%; right: -8%; width: 760px; height: 760px; background: radial-gradient(circle at center, rgba(255,176,32,.4), rgba(255,176,32,0) 60%); filter: blur(10px); animation: heroDrift 14s var(--ease) infinite alternate; }
@keyframes heroDrift { from { transform: translate(0,0) scale(1); } to { transform: translate(-26px,24px) scale(1.08); } }
.hero__grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px); background-size: 52px 52px; -webkit-mask-image: radial-gradient(circle at 72% 26%, #000 0%, transparent 68%); mask-image: radial-gradient(circle at 72% 26%, #000 0%, transparent 68%); }
.hero__inner { position: relative; display: grid; grid-template-columns: 1.12fr .88fr; gap: clamp(34px, 5vw, 76px); align-items: center; padding-block: clamp(64px, 9vw, 128px); }
.hero__copy h1 { color: #fff; margin-bottom: 22px; }
.hero__lede { font-size: 1.22rem; color: var(--text-dim); max-width: 580px; margin-bottom: 34px; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 30px; }
.hero__assure { display: flex; flex-wrap: wrap; gap: 16px 28px; list-style: none; }
.hero__assure li { display: inline-flex; align-items: center; gap: 9px; font-weight: 500; color: var(--text-dim); font-size: .95rem; }
.hero__assure .ico { color: var(--mint); }

.hero__panel { position: relative; }
.hero__card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--sh-3); overflow: hidden; max-width: 400px; margin-inline: auto; }
.hero__card-media { position: relative; aspect-ratio: 4/3; background: var(--well); display: flex; align-items: center; justify-content: center; padding: 22px; }
.hero__card-media img { width: 100%; height: 100%; object-fit: contain; mix-blend-mode: multiply; }
.hero__card-flag { position: absolute; top: 14px; left: 14px; display: inline-flex; align-items: center; gap: 6px; background: rgba(9,13,20,.82); color: #fff; font-size: .74rem; font-weight: 600; padding: 6px 12px; border-radius: 100px; backdrop-filter: blur(6px); }
.hero__card-flag .ico { color: var(--amber); }
.hero__card-body { padding: 18px 22px 22px; }
.hero__card-brand { font-family: var(--font-display); font-size: .72rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--amber); }
.hero__card-name { display: block; font-family: var(--font-display); color: #fff; font-size: 1.05rem; margin: 6px 0 12px; line-height: 1.25; }
.hero__card-price { display: flex; flex-direction: column; gap: 3px; }
.hero__card-price span { color: #fff; font-size: 1.18rem; font-weight: 800; font-family: var(--font-display); }
.hero__card-price span small { color: var(--text-mute); text-decoration: line-through; font-size: .82rem; font-weight: 500; margin-left: 6px; }
.hero__card-price em { font-style: normal; font-weight: 600; color: var(--amber); font-family: var(--font-display); font-size: .85rem; }

.hero__stat { position: absolute; background: rgba(18,25,37,.9); color: #fff; border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--sh-2); padding: 13px 17px; text-align: left; backdrop-filter: blur(8px); }
.hero__stat strong { display: block; font-family: var(--font-display); font-size: 1.3rem; line-height: 1; color: #fff; }
.hero__stat span { font-size: .74rem; color: var(--text-dim); }
.hero__stat--a { bottom: -16px; left: -14px; }
.hero__stat--b { top: 6px; right: -10px; }
.hero__stat--b strong { color: var(--mint); }

/* ---- Brand strip (auto marquee) ------------------------------------------- */
.brandstrip { border-block: 1px solid var(--line-2); background: var(--bg); padding-block: 30px; overflow: hidden; }
.brandstrip__label { text-align: center; font-size: .74rem; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--text-mute); margin: 0 0 20px; }
.brandstrip__list { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px 12px; list-style: none; }
.brandstrip__list a { font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; color: var(--text-dim); letter-spacing: -.01em; padding: 9px 20px; border: 1px solid var(--line); border-radius: 100px; transition: .2s var(--ease); }
.brandstrip__list a:hover { border-color: var(--amber); color: #fff; transform: translateY(-2px); }

/* ---- Feature row (no icon boxes; thin keyline panels) --------------------- */
.usp-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line-2); border: 1px solid var(--line-2); border-radius: var(--r); overflow: hidden; }
.usp { background: var(--bg); padding: 30px 26px; transition: background .25s var(--ease); position: relative; }
.usp::before { content: ''; position: absolute; top: 0; left: 0; width: 38px; height: 2px; background: var(--amber); opacity: .85; }
.usp:hover { background: var(--panel); }
.usp__icon { display: inline-flex; align-items: center; justify-content: center; width: auto; height: auto; border-radius: 0; background: none; color: var(--amber); margin-bottom: 18px; }
.usp__icon .ico { width: 26px; height: 26px; }
.usp h3 { margin-bottom: 9px; color: #fff; }
.usp p { color: var(--text-dim); font-size: .97rem; margin: 0; }

/* ---- Category grid -------------------------------------------------------- */
.cat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.cat-card { display: flex; flex-direction: column; background: var(--panel); border: 1px solid var(--line); border-radius: var(--r); padding: 28px 26px; transition: .22s var(--ease); position: relative; overflow: hidden; }
.cat-card::after { content: ''; position: absolute; inset: 0 0 auto 0; height: 1px; background: linear-gradient(90deg, transparent, var(--amber), transparent); opacity: 0; transition: opacity .25s; }
.cat-card:hover { transform: translateY(-5px); border-color: rgba(255,255,255,.18); background: var(--panel-2); color: var(--text); }
.cat-card:hover::after { opacity: .8; }
.cat-card__icon { display: inline-flex; align-items: center; justify-content: center; width: auto; height: auto; border-radius: 0; background: none; color: var(--amber); margin-bottom: 18px; }
.cat-card__icon .ico { width: 26px; height: 26px; }
.cat-card__title { margin-bottom: 9px; color: #fff; }
.cat-card__blurb { color: var(--text-dim); font-size: .96rem; flex: 1; margin-bottom: 18px; }
.cat-card__foot { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-display); font-weight: 600; color: var(--amber); font-size: .9rem; }
.cat-card__foot .ico { transition: transform .2s var(--ease); }
.cat-card:hover .cat-card__foot .ico { transform: translateX(4px); }

/* ---- Product grid + cards (dark chrome, light image well) ----------------- */
.pgrid, .woocommerce ul.products { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; list-style: none; margin: 0; padding: 0; }
.woocommerce ul.products::before, .woocommerce ul.products::after { content: none; }
.pcard, .woocommerce ul.products li.product {
	display: flex; flex-direction: column; background: var(--panel); border: 1px solid var(--line);
	border-radius: var(--r); overflow: hidden; transition: .22s var(--ease); width: auto !important; margin: 0 !important; float: none !important; text-align: left;
}
.pcard:hover, .woocommerce ul.products li.product:hover { transform: translateY(-5px); border-color: rgba(255,255,255,.2); box-shadow: var(--sh-2); }
.pcard__media { position: relative; aspect-ratio: 1/1; background: var(--well); display: flex; align-items: center; justify-content: center; padding: 20px; }
.pcard__media img { width: 100%; height: 100%; object-fit: contain; mix-blend-mode: multiply; transition: transform .35s var(--ease); }
.pcard:hover .pcard__media img { transform: scale(1.06); }
.pcard__noimg { color: #b6c0cc; }
.pcard__stock { position: absolute; top: 11px; left: 11px; display: inline-flex; align-items: center; gap: 5px; background: rgba(9,13,20,.82); color: var(--mint); font-size: .7rem; font-weight: 700; padding: 5px 10px; border-radius: 100px; backdrop-filter: blur(6px); }
.pcard__stock--soon { color: var(--amber-2); }
.pcard__body { display: flex; flex-direction: column; flex: 1; padding: 17px 19px 19px; }
.pcard__brand { font-family: var(--font-display); font-size: .7rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--amber); margin-bottom: 6px; }
.pcard__title { font-size: 1rem; line-height: 1.32; margin: 0 0 14px; font-family: var(--font-body); font-weight: 600; letter-spacing: 0; }
.pcard__title a { color: #fff; }
.pcard__title a:hover { color: var(--amber); }
.price { margin-top: auto; margin-bottom: 14px; }
.price__rrp { display: block; font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; color: #fff; }
.price__rrp .price__lbl { font-size: .7rem; font-weight: 600; color: var(--text-mute); letter-spacing: .08em; }
.price__rrp .amount, .price__rrp bdi { font-weight: 700; }
.price__trade { display: inline-flex; align-items: center; gap: 6px; font-size: .82rem; font-weight: 600; color: var(--amber); margin-top: 4px; }
.price__now { font-family: var(--font-display); font-weight: 800; font-size: 1.32rem; color: #fff; line-height: 1; }
.price__now .amount, .price__now bdi { color: #fff; }
.price__was { display: inline-block; margin-left: 8px; font-size: .86rem; color: var(--text-mute); text-decoration: line-through; }
.price__save { display: inline-flex; align-items: center; gap: 5px; margin-top: 7px; font-size: .78rem; font-weight: 600; color: var(--mint); }
.price__save .ico { color: var(--mint); }
.price__save--trade { color: var(--amber); }
.price__save--trade .ico { color: var(--amber); }
/* WooCommerce price_html tag (single product) */
.price-tag { display: inline-flex; align-items: center; gap: 5px; margin-left: 8px; font-size: .8rem; font-weight: 600; color: var(--mint); font-family: var(--font-body); vertical-align: middle; }
.price-tag--trade { color: var(--amber); }
.woocommerce div.product p.price del, .woocommerce div.product p.price del .amount { color: var(--text-mute); font-weight: 500; }
.woocommerce div.product p.price ins, .woocommerce div.product p.price ins .amount { color: #fff; font-weight: 800; text-decoration: none; }
.pcard__cta { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-display); font-weight: 600; font-size: .88rem; color: var(--text-dim); padding-top: 13px; border-top: 1px solid var(--line-2); }
.pcard__cta:hover { color: var(--amber); }
.pcard__cta .ico { transition: transform .2s var(--ease); }
.pcard__cta:hover .ico { transform: translateX(4px); }

/* ---- Split (why) + tiers -------------------------------------------------- */
.split { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(34px, 5vw, 76px); align-items: center; }
.split__copy .lead { margin-bottom: 26px; }
.ticklist { list-style: none; display: grid; gap: 15px; margin-bottom: 30px; }
.ticklist li { display: flex; gap: 13px; align-items: flex-start; color: var(--text-dim); }
.ticklist .ico { color: var(--mint); margin-top: 3px; flex: none; }
.ticklist--light li { color: var(--text-dim); }
.ticklist strong { color: #fff; }

.pricetiers { background: linear-gradient(180deg, var(--panel-2), var(--panel)); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 30px; box-shadow: var(--sh-2); }
.pricetiers h3 { color: #fff; margin-bottom: 5px; }
.pricetiers__sub { color: var(--text-mute); font-size: .92rem; margin-bottom: 20px; }
.pricetiers ul { list-style: none; display: grid; gap: 10px; margin-bottom: 16px; }
.pricetiers li { display: grid; grid-template-columns: 1fr auto auto; align-items: center; gap: 12px; padding: 15px 17px; background: rgba(255,255,255,.03); border: 1px solid var(--line); border-radius: var(--r); }
.pricetiers li.is-best { background: var(--amber); border-color: var(--amber); }
.pricetiers__tier { font-family: var(--font-display); font-weight: 700; color: #fff; }
.pricetiers li.is-best .pricetiers__tier, .pricetiers li.is-best .pricetiers__band { color: var(--on-amber); }
.pricetiers__band { font-size: .86rem; color: var(--text-mute); }
.pricetiers__off { font-family: var(--font-display); font-weight: 700; color: var(--amber); justify-self: end; }
.pricetiers li.is-best .pricetiers__off { color: var(--on-amber); }
.pricetiers__foot { display: inline-flex; align-items: center; gap: 7px; font-size: .82rem; color: var(--text-mute); margin: 0; }
.pricetiers__foot .ico { color: var(--amber); }

/* ---- Two ways to buy (comparison) ----------------------------------------- */
.compare { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items: start; }
.compare__card { position: relative; background: var(--panel); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 34px 32px; display: flex; flex-direction: column; }
.compare__card--trade { background: radial-gradient(120% 120% at 100% 0%, #20304a, var(--panel)); border-color: rgba(255,176,32,.4); box-shadow: 0 0 0 1px rgba(255,176,32,.15), var(--sh-2); }
.compare__ribbon { position: absolute; top: 18px; right: 18px; background: var(--amber); color: var(--on-amber); font-family: var(--font-display); font-weight: 700; font-size: .72rem; letter-spacing: .04em; text-transform: uppercase; padding: 6px 13px; border-radius: 100px; }
.compare__who { font-family: var(--font-display); font-size: .76rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--amber); }
.compare__head h3 { margin: 6px 0 0; color: #fff; font-size: 1.4rem; }
.compare__price { font-family: var(--font-display); color: var(--text-dim); font-size: 1.05rem; margin: 18px 0 22px; padding-bottom: 22px; border-bottom: 1px solid var(--line); }
.compare__price strong { color: #fff; font-size: 2.6rem; font-weight: 800; letter-spacing: -.02em; }
.compare__card--trade .compare__price strong { color: var(--amber); }
.compare .ticklist { margin-bottom: 28px; }
.compare .ticklist li { color: var(--text-dim); }
.compare__card > .btn { margin-top: auto; }
.compare__actions { margin-top: auto; display: grid; gap: 10px; }
.compare__actions .btn { width: 100%; }

/* ---- Steps ---------------------------------------------------------------- */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; list-style: none; counter-reset: s; }
.step { position: relative; background: var(--panel); border: 1px solid var(--line); border-radius: var(--r); padding: 34px 28px; }
.step__n { display: block; font-family: var(--font-display); font-weight: 800; font-size: 2.6rem; line-height: 1; color: transparent; -webkit-text-stroke: 1.5px var(--amber); margin-bottom: 18px; }
.step h3 { margin-bottom: 9px; color: #fff; }
.step p { color: var(--text-dim); margin: 0; font-size: .97rem; }

/* ---- Quotes --------------------------------------------------------------- */
.quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.quote { background: var(--panel); border: 1px solid var(--line); border-radius: var(--r); padding: 30px 28px; display: flex; flex-direction: column; }
.quote__stars { display: flex; gap: 2px; color: var(--amber); margin-bottom: 16px; }
.quote blockquote { margin: 0 0 20px; font-size: 1.06rem; line-height: 1.6; color: #eef3fa; }
.quote figcaption { display: flex; flex-direction: column; margin-top: auto; padding-top: 16px; border-top: 1px solid var(--line-2); }
.quote figcaption strong { font-family: var(--font-display); color: #fff; }
.quote figcaption span { color: var(--text-mute); font-size: .9rem; }

/* ---- FAQ ------------------------------------------------------------------ */
.faq { display: grid; gap: 10px; }
.faq__item { background: var(--panel); border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; transition: border-color .2s; }
.faq__item.is-open { border-color: rgba(255,176,32,.4); }
.faq__q { display: flex; align-items: center; justify-content: space-between; gap: 16px; width: 100%; text-align: left; background: none; border: 0; cursor: pointer; padding: 22px 24px; font-family: var(--font-display); font-weight: 600; font-size: 1.06rem; color: #fff; }
.faq__q .ico { flex: none; color: var(--amber); transition: transform .25s var(--ease); }
.faq__item.is-open .faq__q .ico { transform: rotate(45deg); }
.faq__a { padding: 0 24px 24px; }
.faq__a p { margin: 0; color: var(--text-dim); }

/* ---- CTA band ------------------------------------------------------------- */
.cta-band { background: radial-gradient(120% 140% at 80% 0%, #1a2c44 0%, var(--bg-1) 55%); color: #fff; position: relative; overflow: hidden; border-top: 1px solid var(--line-2); }
.cta-band::before { content: ''; position: absolute; top: -40%; left: 58%; width: 600px; height: 600px; background: radial-gradient(circle, rgba(255,176,32,.22), transparent 60%); }
.cta-band__inner { position: relative; display: grid; grid-template-columns: 1.4fr auto; align-items: center; gap: 40px; padding-block: clamp(52px, 7vw, 88px); }
.cta-band__text h2 { color: #fff; margin: 14px 0 12px; }
.cta-band__text p { color: var(--text-dim); margin: 0; max-width: 660px; }
.cta-band__actions { display: flex; flex-direction: column; gap: 12px; }
.cta-band__actions .btn { width: 100%; }

/* ---- Footer --------------------------------------------------------------- */
.site-footer { background: #05080d; color: var(--text-dim); border-top: 1px solid var(--line); }
.site-footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.4fr; gap: 44px; padding-block: clamp(54px, 7vw, 84px); }
.site-footer__brand .brandmark { margin-bottom: 18px; }
.site-footer__brand p { font-size: .96rem; max-width: 340px; color: var(--text-mute); }
.site-footer__contact { list-style: none; display: grid; gap: 11px; margin-top: 18px; }
.site-footer__contact li { display: flex; align-items: center; gap: 11px; }
.site-footer__contact .ico { color: var(--amber); }
.site-footer__contact a, .site-footer__contact span { color: var(--text-dim); }
.site-footer__contact a:hover { color: #fff; }
.footer-email-lbl { font-size: .75rem; color: var(--text-muted, #5a6a7e); margin-left: 2px; }
.footer-widget__title { color: #fff; font-size: .76rem; letter-spacing: .16em; text-transform: uppercase; margin-bottom: 18px; }
.site-footer__col ul { list-style: none; display: grid; gap: 11px; }
.site-footer__col a { color: var(--text-mute); font-size: .96rem; }
.site-footer__col a:hover { color: var(--amber); }
.site-footer__newsletter p { font-size: .95rem; margin-bottom: 18px; color: var(--text-mute); }
.site-footer__assurance { list-style: none; display: flex; flex-wrap: wrap; gap: 16px; margin-top: 20px; }
.site-footer__assurance li { display: inline-flex; align-items: center; gap: 8px; font-size: .85rem; }
.site-footer__assurance .ico { color: var(--mint); }
.site-footer__bar { border-top: 1px solid var(--line-2); }
.site-footer__bar-inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-block: 22px; flex-wrap: wrap; }
.site-footer__bar p { margin: 0; font-size: .82rem; color: var(--text-mute); }
.site-footer__legal { display: flex; gap: 20px; }
.site-footer__legal a { color: var(--text-mute); font-size: .82rem; }
.site-footer__legal a:hover { color: #fff; }

.to-top { position: fixed; right: 22px; bottom: 22px; width: 46px; height: 46px; border-radius: 50%; background: var(--amber); color: var(--on-amber); border: 0; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: var(--sh-2); opacity: 0; transform: translateY(10px); transition: .25s var(--ease); z-index: 90; }
.to-top .ico { transform: rotate(-90deg); }
.to-top.is-on { opacity: 1; transform: translateY(0); }

/* ---- Page hero + prose ---------------------------------------------------- */
.page-hero { background: radial-gradient(110% 120% at 82% 0%, #15273e 0%, #0a101b 50%, var(--bg) 100%); color: #fff; padding-block: clamp(56px, 8vw, 104px); position: relative; overflow: hidden; border-bottom: 1px solid var(--line-2); }
.page-hero::before { content: ''; position: absolute; top: -28%; right: -6%; width: 520px; height: 520px; background: radial-gradient(circle, rgba(255,176,32,.2), transparent 62%); }
.page-hero h1 { color: #fff; position: relative; margin: 0; }
.page-hero__desc { color: var(--text-dim); position: relative; margin-top: 14px; font-size: 1.12rem; max-width: 680px; }
.page-hero--inline { background: var(--bg-1); color: #fff; padding-block: clamp(30px, 4vw, 52px); border-bottom: 1px solid var(--line-2); }
.page-hero--inline h1 { color: #fff; }
/* ---- 404 page ------------------------------------------------------------- */
.error-404 { background: radial-gradient(110% 120% at 80% 0%, #15273e 0%, #0a101b 50%, var(--bg) 100%); border-bottom: 1px solid var(--line-2); }
.error-404__num { font-family: var(--font-display); font-weight: 800; font-size: clamp(6rem,20vw,14rem); line-height: 1; color: transparent; -webkit-text-stroke: 2px var(--amber); letter-spacing: -.04em; margin-bottom: 8px; }
.error-404__heading { font-size: clamp(1.8rem,4vw,2.8rem); color: #fff; margin-bottom: 0; }
.error-404__actions { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; }
.page-article { padding-bottom: var(--sec); }
.prose { padding-block: clamp(38px, 5vw, 64px); font-size: 1.06rem; color: var(--text-dim); }
.prose > :first-child { margin-top: 0; }
.prose h2, .prose h3 { color: #fff; margin-top: 1.5em; }
.prose ul, .prose ol { padding-left: 1.2em; margin: 0 0 1.2em; }
.prose li { margin-bottom: .5em; color: var(--text-dim); }
.prose a { color: var(--amber); text-decoration: underline; text-underline-offset: 3px; }
.prose strong { color: #fff; }

.feature-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line-2); border: 1px solid var(--line-2); border-radius: var(--r); overflow: hidden; margin: 8px 0 16px; }
.feature-row .usp { background: var(--bg); }

/* ---- Brands page ---------------------------------------------------------- */
.brand-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.brand-card { display: flex; flex-direction: column; background: var(--panel); border: 1px solid var(--line); border-radius: var(--r); padding: 28px 26px; scroll-margin-top: 110px; transition: .22s var(--ease); }
.brand-card:hover { border-color: rgba(255,255,255,.2); transform: translateY(-4px); background: var(--panel-2); }
.brand-card__head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.brand-card__name { font-family: var(--font-display); font-weight: 800; font-size: 1.35rem; letter-spacing: -.02em; color: #fff; }
.brand-card__count { font-size: .76rem; font-weight: 700; color: var(--amber); background: var(--amber-soft); padding: 4px 11px; border-radius: 100px; white-space: nowrap; }
.brand-card__blurb { color: var(--text-dim); font-size: .97rem; flex: 1; margin-bottom: 18px; }

/* ---- Tables --------------------------------------------------------------- */
.spec-table { width: 100%; border-collapse: collapse; margin: 8px 0 20px; font-size: .96rem; }
.spec-table th, .spec-table td { text-align: left; padding: 14px 15px; border-bottom: 1px solid var(--line); color: var(--text-dim); }
.spec-table thead th { font-family: var(--font-display); font-size: .8rem; letter-spacing: .06em; text-transform: uppercase; color: var(--text-mute); background: rgba(255,255,255,.02); }
.spec-table tbody tr:hover { background: rgba(255,255,255,.025); }
.spec-table td:first-child { font-weight: 600; color: #fff; }
.table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; border-radius: var(--r-sm); }

/* ---- Stat band ------------------------------------------------------------ */
.statband { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line-2); border: 1px solid var(--line-2); border-radius: var(--r); overflow: hidden; }
.statband__item { background: var(--bg); padding: 30px 24px; text-align: center; }
.statband__item strong { display: block; font-family: var(--font-display); font-weight: 800; font-size: clamp(1.9rem, 3vw, 2.6rem); color: var(--amber); line-height: 1; margin-bottom: 9px; }
.statband__item span { color: var(--text-dim); font-size: .92rem; }

/* ---- Contact -------------------------------------------------------------- */
.contact-layout { display: grid; grid-template-columns: .8fr 1.2fr; gap: 32px; align-items: start; }
.contact-aside { display: grid; gap: 20px; }
.contact-card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 28px; }
.contact-card h3 { margin-bottom: 18px; color: #fff; }
.contact-card--ink { background: linear-gradient(160deg, var(--panel-2), var(--panel)); }
.contact-card--ink p { font-size: .96rem; margin-bottom: 18px; color: var(--text-dim); }
.contact-card__list { list-style: none; display: grid; gap: 18px; }
.contact-card__list li { display: flex; gap: 14px; align-items: flex-start; }
.contact-card__ico { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; flex: none; border-radius: 10px; background: var(--amber-soft); color: var(--amber); }
.contact-card__lbl { display: block; font-family: var(--font-display); font-weight: 700; font-size: .74rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-mute); margin-bottom: 3px; }
.contact-card__list a, .contact-card__list span:not(.contact-card__lbl) { font-weight: 600; font-size: 1.05rem; color: var(--text); }
.contact-card__list a:hover { color: var(--amber); }

/* ---- Credit application layout -------------------------------------------- */
.apply-layout { display: grid; grid-template-columns: 1.55fr .85fr; gap: 32px; align-items: start; }
.apply-aside { display: grid; gap: 18px; position: sticky; top: 100px; }
.apply-aside .contact-card { padding: 24px; }
.apply-aside .contact-card h3 { font-size: 1.15rem; margin-bottom: 14px; }
.apply-aside .btn { width: 100%; }
.form-section { font-family: var(--font-display); font-size: 1.05rem; color: #fff; margin: 8px 0 16px; padding-bottom: 12px; border-bottom: 1px solid var(--line); }
.form-section:not(:first-child) { margin-top: 28px; }
.form-section__hint { font-weight: 500; font-size: .85rem; color: var(--text-mute); }

/* ---- Trade credit --------------------------------------------------------- */
.credit-band { display: grid; grid-template-columns: 1.25fr .75fr; gap: clamp(30px, 4vw, 60px); align-items: center; background: var(--panel); border: 1px solid var(--line); border-radius: var(--r-xl); padding: clamp(30px, 4vw, 56px); }
.credit-band .ticklist { margin-bottom: 26px; }
.credit-band .lead { color: var(--text-dim); }
.credit-card { background: radial-gradient(120% 120% at 100% 0%, #1c2f49, var(--panel-2)); color: var(--text-dim); border-radius: var(--r-lg); padding: 30px; box-shadow: var(--sh-2); position: relative; overflow: hidden; border: 1px solid var(--line); }
.credit-card::before { content: ''; position: absolute; top: -40%; right: -30%; width: 320px; height: 320px; background: radial-gradient(circle, rgba(255,176,32,.22), transparent 62%); }
.credit-card__tag { position: relative; display: inline-flex; align-items: center; gap: 7px; background: var(--amber-soft); color: var(--amber); font-family: var(--font-display); font-weight: 600; font-size: .8rem; padding: 6px 13px; border-radius: 100px; }
.credit-card__big { position: relative; font-family: var(--font-display); font-weight: 800; font-size: 2.7rem; color: #fff; line-height: 1; margin: 20px 0 14px; }
.credit-card__big span { display: block; font-size: .9rem; font-weight: 500; color: var(--text-mute); margin-top: 7px; }
.credit-card p { position: relative; font-size: .95rem; margin-bottom: 18px; }
.credit-card__row { position: relative; display: flex; justify-content: space-between; align-items: center; padding: 13px 0; border-top: 1px solid var(--line); }
.credit-card__row strong { color: #fff; font-family: var(--font-display); }
.credit-card__row--due strong { color: var(--amber); }

/* ---- Info banners (dark + accent keyline, NOT pastel boxes) --------------- */
.trade-note { display: flex; align-items: center; flex-wrap: wrap; gap: 12px; background: var(--panel); border: 1px solid var(--line); border-left: 3px solid var(--amber); border-radius: var(--r); padding: 16px 20px; margin-bottom: 24px; font-size: .95rem; color: var(--text-dim); }
.trade-note .ico { color: var(--amber); flex: none; }
.trade-note strong, .trade-note b { color: #fff; }
.trade-note__cta { display: inline-flex; align-items: center; gap: 6px; margin-left: auto; padding: 10px 18px; background: var(--amber); color: var(--on-amber) !important; border-radius: 100px; font-family: var(--font-display); font-weight: 600; font-size: .9rem; text-decoration: none !important; white-space: nowrap; }
.trade-note__cta:hover { background: var(--amber-2); }
.trade-note__cta .ico { color: var(--on-amber); }

.proof-banner { display: flex; gap: 15px; align-items: flex-start; background: var(--panel); border: 1px solid var(--line); border-left: 3px solid var(--amber); border-radius: var(--r); padding: 18px 20px; margin-bottom: 24px; }
.proof-banner__ico { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; flex: none; border-radius: 10px; background: var(--amber-soft); color: var(--amber); }
.proof-banner strong { display: block; color: #fff; font-family: var(--font-display); margin-bottom: 4px; }
.proof-banner span { color: var(--text-dim); font-size: .92rem; }
.proof-banner a { color: var(--amber); font-weight: 700; text-decoration: underline; }

/* ---- Forms ---------------------------------------------------------------- */
.enquiry { background: var(--panel); border: 1px solid var(--line); border-radius: var(--r-lg); padding: clamp(24px, 3vw, 36px); }
.enquiry__title { margin-bottom: 18px; color: #fff; }
.enquiry__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.field { display: flex; flex-direction: column; gap: 8px; }
.field--full { margin-bottom: 16px; }
.field__lbl { font-family: var(--font-display); font-weight: 600; font-size: .9rem; color: #fff; }
.field__lbl em { color: var(--amber); font-style: normal; }
.field input, .field select, .field textarea {
	font: inherit; font-size: .98rem; color: #fff; background: var(--bg); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 13px 15px; width: 100%; transition: border-color .16s, background .16s, box-shadow .16s;
}
.field select { color: #fff; }
.field select option { background: var(--panel); color: #fff; }
.field input::placeholder, .field textarea::placeholder { color: var(--text-mute); }
.field textarea { resize: vertical; min-height: 110px; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--amber); background: var(--bg-1); box-shadow: 0 0 0 3px var(--amber-soft); }
.field--file input[type=file] { font: inherit; font-size: .9rem; color: var(--text-dim); background: var(--bg); border: 1px dashed var(--line); border-radius: var(--r-sm); padding: 14px; width: 100%; cursor: pointer; }
.field--file input[type=file]::file-selector-button { font: inherit; font-weight: 600; font-family: var(--font-display); background: var(--amber); color: var(--on-amber); border: 0; border-radius: 6px; padding: 8px 14px; margin-right: 12px; cursor: pointer; }
.field--file input[type=file]:hover { border-color: var(--amber); }
.field-note { display: flex; gap: 7px; align-items: flex-start; font-size: .82rem; color: var(--text-mute); margin-top: 2px; }
.field-note .ico { color: var(--amber); flex: none; margin-top: 2px; }
.field-note a { color: var(--amber); }
.enquiry__hp { position: absolute; left: -9999px; }
.consent { display: flex; gap: 11px; align-items: flex-start; margin-bottom: 18px; font-size: .92rem; color: var(--text-dim); }
.consent input { margin-top: 4px; width: 18px; height: 18px; accent-color: var(--amber); flex: none; }
.consent--credit { background: var(--amber-soft); border: 1px solid rgba(255,176,32,.3); border-radius: var(--r-sm); padding: 13px 15px; color: var(--text); font-weight: 500; }
.consent--credit .ico { color: var(--amber); flex: none; }
.enquiry__foot { display: inline-flex; align-items: center; gap: 8px; font-size: .84rem; color: var(--text-mute); margin: 14px 0 0; }
.enquiry__foot .ico { color: var(--amber); }
.notice { display: flex; gap: 12px; align-items: flex-start; padding: 16px 18px; border-radius: var(--r); margin-bottom: 20px; }
.notice--ok { background: var(--mint-soft); color: #b8f5e6; border: 1px solid rgba(70,230,192,.3); }
.notice--ok .ico { color: var(--mint); }
.notice--ok strong, .notice--ok a { color: #fff; }
.notice--err { background: rgba(255,90,70,.1); color: #ffb3a8; border: 1px solid rgba(255,90,70,.3); }
.notice--err .ico { color: #ff6a52; }

/* ---- WooCommerce specifics ------------------------------------------------ */
.shop-wrap { padding-block: var(--sec); }
.woocommerce .woocommerce-result-count { color: var(--text-mute); font-size: .92rem; margin-bottom: 18px; }
.woocommerce .woocommerce-ordering { margin-bottom: 18px; }
.woocommerce .woocommerce-ordering select { font: inherit; padding: 11px 38px 11px 13px; border: 1px solid var(--line); border-radius: var(--r-sm); background: var(--panel) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9'%3E%3Cpath d='M1 1l6 6 6-6' stroke='%23ffb020' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 14px center; color: #fff; -webkit-appearance: none; appearance: none; cursor: pointer; }
.woocommerce-breadcrumb { color: var(--text-mute); font-size: .9rem; margin-bottom: 18px; }
.woocommerce-breadcrumb a { color: var(--text-dim); }
.crumb-sep { color: var(--text-mute); }
.woocommerce ul.products li.product .pcard__body .price { display: block; }
/* card actions: add-to-cart + view */
.pcard__actions { display: flex; gap: 8px; align-items: stretch; padding-top: 13px; border-top: 1px solid var(--line-2); }
.pcard__actions .button, .woocommerce ul.products li.product .pcard__actions a.button {
	flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 7px; margin: 0;
	background: var(--amber); color: var(--on-amber); font-family: var(--font-display); font-weight: 600; font-size: .88rem;
	padding: 11px 14px; border-radius: 100px; border: 0; transition: background .18s, transform .15s;
}
.pcard__actions .button:hover { background: var(--amber-2); transform: translateY(-1px); color: var(--on-amber); }
.pcard__actions .added_to_cart { flex: 1; display: inline-flex; align-items: center; justify-content: center; background: var(--mint-soft); color: var(--mint); border-radius: 100px; font-family: var(--font-display); font-weight: 600; font-size: .82rem; padding: 11px 12px; }
.pcard__view { flex: none; display: inline-flex; align-items: center; justify-content: center; width: 44px; border: 1px solid var(--line); border-radius: 100px; color: var(--text-dim); transition: .18s var(--ease); }
.pcard__view:hover { border-color: var(--amber); color: var(--amber); }
.pcard__view .ico { transition: transform .2s var(--ease); }
.pcard__view:hover .ico { transform: translateX(2px); }
.shop-wrap h1, .shop-wrap .page-title { color: #fff; margin-bottom: 8px; }

.single-trade { background: var(--panel); border: 1px solid var(--line); border-left: 3px solid var(--amber); border-radius: var(--r); padding: 20px 22px; margin: 22px 0; }
.single-trade__row { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; color: var(--text); }
.single-trade__row .ico { color: var(--amber); }
.single-trade__actions { display: flex; flex-wrap: wrap; gap: 12px; }
.single-trade__brand { margin: 14px 0 0; font-size: .92rem; color: var(--text-mute); }
/* Sticky product gallery — follows the summary column on desktop scroll */
@media (min-width: 768px) {
	.woocommerce div.product .woocommerce-product-gallery {
		position: sticky;
		top: 100px;
		align-self: start;
	}
}
/* Override WooCommerce smallscreen floats — theme uses CSS Grid, not floats */
@media (max-width: 768px) {
	.woocommerce div.product div.images,
	.woocommerce div.product div.summary { float: none; width: 100%; }
}
.single-usps { list-style: none; display: grid; gap: 11px; margin: 18px 0; }
.single-usps li { display: flex; align-items: center; gap: 11px; font-size: .95rem; color: var(--text-dim); }
.single-usps .ico { color: var(--mint); }
.woocommerce div.product { color: var(--text-dim); }
.woocommerce div.product .product_title { font-family: var(--font-display); color: #fff; }
.woocommerce div.product p.price, .woocommerce div.product span.price { color: #fff; font-family: var(--font-display); }
.woocommerce div.product .woocommerce-tabs ul.tabs li { background: var(--panel); border-color: var(--line); }
.woocommerce div.product .woocommerce-tabs ul.tabs li a { color: var(--text-dim); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active { background: var(--panel-2); border-bottom-color: var(--panel-2); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--amber); font-weight: 600; }
.woocommerce div.product .woocommerce-tabs .panel { background: var(--panel); border: 1px solid var(--line); color: var(--text-dim); border-radius: 0 var(--r) var(--r) var(--r); padding: clamp(20px,3vw,32px); margin-top: 0; }
.woocommerce div.product form.cart .quantity input.qty { font: inherit; font-size: .98rem; background: var(--bg); border: 1px solid var(--line); border-radius: var(--r-sm); color: #fff; padding: 13px 15px; width: 70px; text-align: center; transition: border-color .16s, background .16s, box-shadow .16s; -moz-appearance: textfield; }
.woocommerce div.product form.cart .quantity input.qty::-webkit-outer-spin-button,
.woocommerce div.product form.cart .quantity input.qty::-webkit-inner-spin-button { -webkit-appearance: none; }
.woocommerce div.product form.cart .quantity input.qty:focus { outline: none; border-color: var(--amber); background: var(--bg-1); box-shadow: 0 0 0 3px var(--amber-soft); }
.woocommerce #respond input#submit, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button {
	background: rgba(255,255,255,.06); color: #fff; font-family: var(--font-display); font-weight: 600; border-radius: 100px; padding: 13px 24px; border: 1px solid var(--line);
}
.woocommerce #respond input#submit:hover, .woocommerce a.button:hover, .woocommerce button.button:hover { background: rgba(255,255,255,.12); }
.woocommerce .woocommerce-message, .woocommerce .woocommerce-info, .woocommerce .woocommerce-error { background: var(--panel); border-top: 3px solid var(--amber); color: var(--text-dim); }
.woocommerce .star-rating span { color: var(--amber); }

/* ---- Postlist ------------------------------------------------------------- */
.postlist { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.postcard { background: var(--panel); border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; }
.postcard__media img { aspect-ratio: 16/10; object-fit: cover; width: 100%; }
.postcard__body { padding: 22px; }
.postcard__title a { color: #fff; }
.pagination { margin-top: 36px; }
.pagination .page-numbers { display: inline-flex; min-width: 42px; height: 42px; align-items: center; justify-content: center; padding: 0 12px; border: 1px solid var(--line); border-radius: var(--r-sm); margin: 0 4px; font-family: var(--font-display); font-weight: 600; color: var(--text-dim); }
.pagination .page-numbers.current { background: var(--amber); color: var(--on-amber); border-color: var(--amber); }

/* ---- Conversion + reviews ------------------------------------------------- */
.cardrate { display: inline-flex; align-items: center; gap: 1px; margin: 0 0 8px; }
.cardrate__s { color: #3a4759; display: inline-flex; }
.cardrate__s.is-on { color: var(--amber); }
.cardrate__n { font-size: .76rem; color: var(--text-mute); margin-left: 5px; }
.ships-today { display: flex; align-items: center; gap: 9px; font-size: .95rem; color: var(--text-dim); margin: 4px 0 14px; padding: 11px 14px; background: var(--mint-soft); border-radius: var(--r-sm); }
.ships-today .ico { color: var(--mint); flex: none; }
.ships-today span { flex: 1; min-width: 0; }
.ships-today strong { color: #fff; }
.pay-reassure { margin: 14px 0 4px; }
.pay-reassure__line { display: flex; align-items: flex-start; gap: 8px; font-size: .88rem; color: var(--text-mute); margin: 0 0 10px; }
.pay-reassure__line .ico { color: var(--amber); flex: none; margin-top: 2px; }
.pay-reassure__line span { flex: 1; min-width: 0; }
.pay-reassure__line a { color: var(--amber); }
.paychips { list-style: none; display: flex; flex-wrap: wrap; gap: 7px; margin: 0; padding: 0; }
.paychips li { font-family: var(--font-display); font-weight: 700; font-size: .68rem; letter-spacing: .03em; color: var(--text-dim); background: rgba(255,255,255,.05); border: 1px solid var(--line); border-radius: 5px; padding: 5px 9px; }
.paychips--sm li { font-size: .64rem; padding: 4px 7px; }
.site-footer__pay { border-top: 1px solid var(--line-2); }
.site-footer__pay-inner { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 14px; padding-block: 18px; }
.site-footer__pay-lbl { display: inline-flex; align-items: center; gap: 8px; font-size: .82rem; color: var(--text-mute); font-weight: 600; }
.site-footer__pay-lbl .ico { color: var(--mint); }

/* Sticky add-to-cart (mobile) */
.sticky-cart { position: fixed; left: 0; right: 0; bottom: 0; z-index: 95; display: none; align-items: center; gap: 14px; padding: 12px var(--gut); background: rgba(9,13,20,.94); backdrop-filter: blur(12px); border-top: 1px solid var(--line); transform: translateY(100%); transition: transform .28s var(--ease); }
.sticky-cart.is-on { transform: translateY(0); }
.sticky-cart__info { display: flex; flex-direction: column; min-width: 0; flex: 1; }
.sticky-cart__name { font-family: var(--font-display); font-weight: 600; font-size: .9rem; color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sticky-cart__price { font-size: .82rem; color: var(--text-dim); }
.sticky-cart__price del { color: var(--text-mute); }
.sticky-cart__price ins { text-decoration: none; color: #fff; }
.sticky-cart__btn { flex: none; }
@media (max-width: 768px) { .sticky-cart { display: flex; } body.woocommerce.single-product { padding-bottom: 76px; } body.woocommerce.single-product .to-top { bottom: 96px; } }

/* ---- Shop facet filters ---------------------------------------------------- */
/* Hide the now-empty WooCommerce archive header wrapper */
.woocommerce-products-header:empty,
.woocommerce-products-header { display: none; }

.shop-filters { margin-bottom: 28px; }
.shop-filters__title { font-size: clamp(1.6rem, 3.5vw, 2.2rem); margin: 0; color: #fff; }
.shop-filters__row { display: flex; flex-wrap: wrap; gap: 20px 32px; padding: 20px 24px; background: var(--panel); border: 1px solid var(--line); border-radius: var(--r); }
.filter-group { display: flex; flex-direction: column; gap: 10px; min-width: 0; }
.filter-group__label { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-display); font-weight: 600; font-size: .72rem; letter-spacing: .15em; text-transform: uppercase; color: var(--text-mute); white-space: nowrap; }
.filter-group__pills { display: flex; flex-wrap: wrap; gap: 7px; }
.filter-pill { display: inline-flex; align-items: center; gap: 5px; font-family: var(--font-display); font-weight: 500; font-size: .84rem; color: var(--text-dim); background: var(--bg-1); border: 1px solid var(--line); border-radius: 100px; padding: 6px 13px; transition: .16s var(--ease); white-space: nowrap; }
.filter-pill:hover { color: #fff; border-color: rgba(255,255,255,.25); background: var(--panel-2); }
.filter-pill.is-on { background: var(--amber); color: var(--on-amber); border-color: var(--amber); font-weight: 700; }
.filter-pill.is-on:hover { background: var(--amber-2); color: var(--on-amber); }
.filter-pill__n { font-size: .72rem; opacity: .7; }
.shop-filters__active { display: flex; align-items: center; gap: 10px; margin-top: 12px; font-size: .88rem; color: var(--text-dim); padding: 0 4px; }
.shop-filters__active .ico { color: var(--mint); flex: none; }
.shop-filters__active span { color: #fff; font-weight: 500; }
.shop-filters__clear { color: var(--text-mute); margin-left: 8px; font-size: .82rem; }
.shop-filters__clear:hover { color: var(--amber); }
@media (max-width: 680px) { .shop-filters__row { flex-direction: column; gap: 16px; padding: 16px; } .filter-group__pills { gap: 6px; } .filter-pill { font-size: .8rem; padding: 11px 14px; } }

/* ---- Header search --------------------------------------------------------- */
.header-search-toggle { background: none; border: none; }
.site-search {
	position: absolute; top: 100%; left: 0; right: 0; z-index: 99;
	background: var(--panel); border-bottom: 1px solid var(--line);
	box-shadow: 0 24px 48px rgba(0,0,0,.5);
	animation: searchSlide .22s cubic-bezier(.22,.61,.36,1) both;
}
@keyframes searchSlide {
	from { opacity: 0; transform: translateY(-8px); }
	to   { opacity: 1; transform: translateY(0); }
}
.site-search__inner { display: flex; align-items: center; gap: 12px; padding-block: 16px; }
.site-search__form { display: flex; flex: 1; }
.site-search__input {
	flex: 1; background: var(--bg); border: 1px solid var(--line); border-right: 0;
	border-radius: var(--r-sm) 0 0 var(--r-sm); color: var(--text);
	font-family: var(--font-body); font-size: 1rem; padding: 13px 18px; outline: none;
	transition: border-color .18s;
}
.site-search__input::placeholder { color: var(--text-mute); }
.site-search__input:focus { border-color: var(--amber); }
.site-search__submit { border-radius: 0 var(--r-sm) var(--r-sm) 0 !important; padding: 13px 18px !important; }
.site-search__close {
	background: none; border: 1px solid var(--line); color: var(--text-dim);
	width: 40px; height: 40px; border-radius: 50%; cursor: pointer; font-size: 1.1rem;
	display: flex; align-items: center; justify-content: center; flex: none;
	transition: .15s; line-height: 1;
}
.site-search__close:hover { color: #fff; border-color: var(--amber); background: var(--amber-soft); }

/* ---- Price tiers (single product page) ------------------------------------ */
.price-tiers {
	display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 20px 0 10px;
}
.price-tier {
	background: var(--panel); border: 1px solid var(--line); border-radius: var(--r);
	padding: 18px 20px; display: flex; flex-direction: column; gap: 4px;
}
.price-tier--trade {
	background: var(--panel-2); border-color: var(--amber);
	box-shadow: 0 0 0 1px var(--amber-soft), inset 0 0 20px var(--amber-soft);
}
.price-tier__label {
	font-family: var(--font-display); font-weight: 600; font-size: .82rem;
	letter-spacing: .04em; text-transform: uppercase; color: var(--text-dim);
	display: flex; align-items: center; gap: 6px; margin-bottom: 4px;
}
.price-tier--trade .price-tier__label { color: var(--amber); }
.price-tier__you { font-weight: 400; letter-spacing: 0; text-transform: none; color: var(--mint); }
.price-tier__amount { font-family: var(--font-display); font-weight: 800; font-size: 1.55rem; color: #fff; line-height: 1; }
.price-tier__save { font-size: .83rem; color: var(--text-mute); }
.price-tier--trade .price-tier__save { color: var(--amber-2); }
.price-tier__rrp { font-size: .8rem; color: var(--text-mute); margin-top: 2px; }
.price-tier__actions { display: flex; flex-direction: column; gap: 8px; margin-top: 14px; }
.price-tier__actions .btn { text-align: center; justify-content: center; padding: 11px 16px; font-size: .88rem; }
.single-trade__confirmed {
	display: flex; align-items: center; gap: 8px; padding: 12px 16px;
	background: var(--mint-soft); border-radius: var(--r-sm); color: #fff;
	font-size: .94rem; margin: 16px 0 10px;
}
.single-trade__confirmed .ico { color: var(--mint); flex: none; }
.single-trade__brand {
	display: flex; align-items: center; gap: 8px; font-size: .84rem;
	color: var(--text-mute); margin: 10px 0 0; padding-top: 8px;
	border-top: 1px solid var(--line-2);
}
.single-trade__brand .ico { color: var(--amber); flex: none; }
@media (max-width: 560px) { .price-tiers { grid-template-columns: 1fr; } }

/* ---- Cart button + floating cart drawer ----------------------------------- */
.cart-btn { position: relative; }
.cart-badge { position: absolute; top: 4px; right: 4px; min-width: 17px; height: 17px; border-radius: 100px; background: var(--amber); color: var(--on-amber); font-family: var(--font-display); font-size: .6rem; font-weight: 700; line-height: 17px; text-align: center; padding: 0 4px; pointer-events: none; transition: transform .2s var(--ease), opacity .2s; }
.cart-badge.is-empty { transform: scale(0); opacity: 0; }
/* On mobile nav the label shows, so reposition badge to sit on the icon top-right */
@media (max-width: 1100px) { .cart-badge { top: 10px; right: auto; left: 20px; } }

.cart-drawer { position: fixed; inset: 0; z-index: 300; pointer-events: none; }
.cart-drawer[aria-hidden="false"] { pointer-events: auto; }
.cart-drawer__overlay { position: absolute; inset: 0; background: rgba(0,0,0,.6); opacity: 0; transition: opacity .28s var(--ease); cursor: pointer; backdrop-filter: blur(2px); }
.cart-drawer[aria-hidden="false"] .cart-drawer__overlay { opacity: 1; }
.cart-drawer__panel { position: absolute; top: 0; right: 0; bottom: 0; width: min(440px, 96vw); background: var(--bg-1); border-left: 1px solid var(--line); box-shadow: var(--sh-3); display: flex; flex-direction: column; transform: translateX(100%); transition: transform .32s var(--ease); overflow: hidden; }
.cart-drawer[aria-hidden="false"] .cart-drawer__panel { transform: translateX(0); }

/* Header */
.cart-drawer__head { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; border-bottom: 1px solid var(--line); flex: none; background: var(--bg-1); }
.cart-drawer__title { display: flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 700; font-size: 1.1rem; color: #fff; }
.cart-drawer__title .ico { color: var(--amber); }
.cart-drawer__close { background: none; border: 1px solid var(--line); border-radius: 50%; width: 36px; height: 36px; cursor: pointer; color: var(--text-dim); font-size: 1rem; display: flex; align-items: center; justify-content: center; flex: none; transition: .15s; line-height: 1; }
.cart-drawer__close:hover { border-color: var(--amber); color: var(--amber); background: var(--amber-soft); }

/* Scrollable items area */
.cart-drawer__body { flex: 1; overflow-y: auto; padding: 0; display: flex; flex-direction: column; }
.cart-drawer .widget_shopping_cart_content { display: flex; flex-direction: column; flex: 1; }
.cart-drawer .woocommerce-mini-cart { list-style: none; padding: 0; margin: 0; flex: 1; }
.cart-drawer .woocommerce-mini-cart-item { display: flex; align-items: center; gap: 14px; padding: 18px 24px; border-bottom: 1px solid var(--line-2); transition: background .15s; }
.cart-drawer .woocommerce-mini-cart-item:hover { background: rgba(255,255,255,.025); }

/* Thumbnail */
.cart-drawer .mini-cart-thumb { flex: none; display: block; }
.cart-drawer .mini-cart-thumb img { width: 76px; height: 76px; object-fit: contain; border-radius: var(--r-sm); background: var(--well); padding: 8px; display: block; }

/* Name + qty info */
.cart-drawer .mini-cart-info { flex: 1; min-width: 0; }
.cart-drawer .mini-cart-info__name { display: block; color: #fff; font-weight: 600; font-size: .9rem; line-height: 1.35; margin-bottom: 6px; }
.cart-drawer .mini-cart-info__name:hover { color: var(--amber); }
.cart-drawer .mini-cart-info .quantity { font-size: .82rem; color: var(--text-mute); }
.cart-drawer .mini-cart-info .wc-item-meta { font-size: .8rem; color: var(--text-mute); margin-bottom: 4px; list-style: none; padding: 0; }

/* Remove button */
.cart-drawer .remove_from_cart_button { display: inline-flex; align-items: center; justify-content: center; flex: none; width: 28px; height: 28px; border-radius: 50%; background: rgba(255,255,255,.05); border: 1px solid var(--line); color: var(--text-mute); font-size: .95rem; text-decoration: none; transition: .15s; margin-left: 4px; }
.cart-drawer .remove_from_cart_button:hover { background: rgba(255,80,60,.15); border-color: rgba(255,80,60,.4); color: #ff6040; }

/* Footer: total + buttons */
.cart-drawer__footer { flex: none; padding: 20px 24px; border-top: 1px solid var(--line); background: var(--bg-1); }
.cart-drawer .woocommerce-mini-cart__total { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 18px; font-family: var(--font-display); font-weight: 700; color: #fff; font-size: 1rem; }
.cart-drawer .woocommerce-mini-cart__total strong { font-size: .8rem; font-weight: 600; color: var(--text-mute); text-transform: uppercase; letter-spacing: .06em; }
.cart-drawer .woocommerce-mini-cart__total .amount { font-size: 1.4rem; color: var(--amber); }
.cart-drawer .woocommerce-mini-cart__buttons { display: grid; gap: 10px; margin: 0; padding: 0; }
.cart-drawer .woocommerce-mini-cart__buttons a.button,
.cart-drawer .woocommerce-mini-cart__buttons a { display: flex !important; align-items: center; justify-content: center; padding: 14px 20px; border-radius: 100px; font-family: var(--font-display); font-weight: 600; font-size: .96rem; transition: background .18s, color .18s, border-color .18s; }
.cart-drawer .woocommerce-mini-cart__buttons a.checkout { background: var(--amber) !important; color: var(--on-amber) !important; border: 1px solid var(--amber) !important; }
.cart-drawer .woocommerce-mini-cart__buttons a.checkout:hover { background: var(--amber-2) !important; }
.cart-drawer .woocommerce-mini-cart__buttons a:not(.checkout) { background: transparent; border: 1px solid var(--line); color: var(--text-dim); }
.cart-drawer .woocommerce-mini-cart__buttons a:not(.checkout):hover { border-color: var(--amber); color: var(--amber); }

/* Empty state */
.cart-empty-state { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 56px 24px 40px; gap: 10px; flex: 1; }
.cart-empty-state .ico { color: var(--amber); opacity: .25; margin-bottom: 8px; }
.cart-empty-state__title { font-family: var(--font-display); font-weight: 700; font-size: 1.15rem; color: #fff; margin: 0; }
.cart-empty-state__sub { color: var(--text-mute); font-size: .9rem; margin: 0 0 18px; max-width: 240px; }
.cart-empty-state .btn { white-space: nowrap; }

/* ---- Checkout (telegram-payment-relay) theming ---------------------------- */
.CheckoutInput { font: inherit; background: var(--bg) !important; border: 1px solid var(--line) !important; border-radius: var(--r-sm) !important; color: #fff !important; padding: 13px 15px !important; width: 100% !important; transition: border-color .16s, box-shadow .16s !important; }
.CheckoutInput:focus { outline: none !important; border-color: var(--amber) !important; box-shadow: 0 0 0 3px var(--amber-soft) !important; }
.SubmitButton { font: inherit; font-family: var(--font-display) !important; font-weight: 700 !important; font-size: 1rem !important; background: var(--amber) !important; color: var(--on-amber) !important; border-radius: 100px !important; border: 0 !important; padding: 14px 28px !important; width: 100% !important; cursor: pointer !important; transition: background .18s !important; }
.SubmitButton:hover { background: var(--amber-2) !important; }
.Select-source { font: inherit; background: var(--bg) !important; border: 1px solid var(--line) !important; border-radius: var(--r-sm) !important; color: #fff !important; padding: 11px 13px !important; width: 100% !important; }
.ProductSummary-totalsRead { color: var(--text-dim) !important; }

/* ---- Reveal animation (JS only) ------------------------------------------- */
.js .reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.js .reveal.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .js .reveal { opacity: 1; transform: none; transition: none; } }

/* ---- Responsive ----------------------------------------------------------- */
@media (max-width: 1080px) {
	.usp-grid { grid-template-columns: repeat(2, 1fr); }
	.pgrid, .woocommerce ul.products { grid-template-columns: repeat(3, 1fr); }
	.site-footer__grid { grid-template-columns: 1fr 1fr; }
	.brand-list { grid-template-columns: repeat(2, 1fr); }
	.statband { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 1100px) {
	.primary-nav__cta { display: flex; flex-direction: column; align-items: stretch; gap: 6px; }
	.primary-nav__cta > .btn { margin-left: 0; }
	.primary-nav__cta > .btn::before { display: none; }
	.nav-toggle { display: flex; }
	/* backdrop-filter on the header creates a containing block that traps the
	   fixed-position drawer — drop it on mobile so the drawer fills the viewport. */
	.site-header { backdrop-filter: none; -webkit-backdrop-filter: none; background: var(--bg); border-bottom: 1px solid var(--line); }
	.primary-nav {
		position: fixed; inset: 0 0 0 auto; width: min(380px, 88vw); background: var(--bg-1); flex-direction: column; align-items: stretch; justify-content: flex-start; gap: 0; padding: 92px 24px 28px; box-shadow: var(--sh-3); border-left: 1px solid var(--line); transform: translateX(100%); transition: transform .3s var(--ease); overflow-y: auto; z-index: 99;
	}
	body.nav-open .primary-nav { transform: translateX(0); }
	body.nav-open { overflow: hidden; }
	.primary-nav__list { flex-direction: column; align-items: stretch; gap: 2px; }
	.primary-nav__list a { padding: 14px 14px; font-size: 1.08rem; border-radius: var(--r-sm); color: #fff; }
	.primary-nav__list .sub-menu { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; border: 0; padding: 0 0 0 12px; margin: 0; background: none; }
	.primary-nav__cta { margin-top: 18px; }
	.primary-nav__cta .header-util { justify-content: flex-start; padding: 13px 14px; border-radius: var(--r-sm); background: rgba(255,255,255,.04); border: 1px solid var(--line); }
	.primary-nav__cta .btn { width: 100%; justify-content: center; }
	.hero__inner { grid-template-columns: 1fr; }
	.hero__panel { max-width: 440px; margin-top: 8px; margin-inline: auto; }
	.split { grid-template-columns: 1fr; }
	.credit-band { grid-template-columns: 1fr; }
	.contact-layout { grid-template-columns: 1fr; }
	.apply-layout { grid-template-columns: 1fr; }
	.apply-aside { position: static; grid-template-columns: 1fr 1fr; }
	.apply-aside .contact-card--ink { grid-column: 1 / -1; }
	.steps, .quotes { grid-template-columns: 1fr; }
	.compare { grid-template-columns: 1fr; }
	.cta-band__inner { grid-template-columns: 1fr; }
	.cta-band__actions { flex-direction: row; flex-wrap: wrap; }
	.cta-band__actions .btn { width: auto; }
	.sec-head--row { flex-direction: column; align-items: flex-start; }
	.brand-list { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 680px) {
	body { font-size: 16px; }
	.topbar__msg { display: none; }
	.topbar__inner { justify-content: center; }
	.usp-grid, .cat-grid, .pgrid, .woocommerce ul.products, .feature-row, .postlist { grid-template-columns: 1fr 1fr; }
	.enquiry__grid { grid-template-columns: 1fr; }
	.site-footer__grid { grid-template-columns: 1fr; gap: 32px; }
	.apply-aside { grid-template-columns: 1fr; }
	.hero__stat--a { left: 0; }
	.hero__stat--b { right: 0; }
	.trade-note__cta { margin-left: 0; }
	.statband { grid-template-columns: 1fr 1fr; }
	.carousel__head { flex-wrap: wrap; gap: 14px; }
}
@media (max-width: 460px) {
	.pgrid, .woocommerce ul.products, .usp-grid, .feature-row { grid-template-columns: 1fr; }
	.cat-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
	.cat-card { padding: 18px 14px; }
	.cat-card__icon { margin-bottom: 12px; }
	.cat-card__blurb { font-size: .85rem; }
	.hero__actions .btn, .split__copy > .btn { width: 100%; }
	.brand-list, .statband { grid-template-columns: 1fr; }
	.hero__stat { display: none; }
	.trade-note__cta { white-space: normal; text-align: center; justify-content: center; width: 100%; }
}

/* ── Cookie consent banner ─────────────────────────────────────────────────── */
.spv-cc {
	position: fixed;
	bottom: 0; left: 0; right: 0;
	z-index: 99999;
	background: var(--panel, #121925);
	border-top: 1px solid #1e2d42;
	box-shadow: 0 -4px 32px rgba(0,0,0,.45);
	transform: translateY(100%);
	transition: transform .35s cubic-bezier(.4,0,.2,1), opacity .35s;
	opacity: 0;
}
.spv-cc--show { transform: translateY(0); opacity: 1; }
.spv-cc--hide { transform: translateY(100%); opacity: 0; }
.spv-cc__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 18px 32px;
	display: flex;
	align-items: center;
	gap: 32px;
}
.spv-cc__copy { flex: 1; min-width: 0; }
.spv-cc__title {
	font-weight: 700;
	font-size: .9rem;
	color: #fff;
	margin: 0 0 4px;
}
.spv-cc__desc {
	font-size: .8rem;
	color: var(--text-dim, #8fa3bf);
	margin: 0;
	line-height: 1.5;
}
.spv-cc__link { color: var(--amber, #ffb020); text-decoration: underline; }
.spv-cc__link:hover { color: #fff; }
.spv-cc__actions { display: flex; gap: 10px; flex-shrink: 0; }
.spv-cc__btn {
	padding: 9px 20px;
	border-radius: 6px;
	font-size: .82rem;
	font-weight: 600;
	cursor: pointer;
	border: 1.5px solid transparent;
	white-space: nowrap;
	transition: background .18s, color .18s, border-color .18s;
}
.spv-cc__btn--primary {
	background: var(--amber, #ffb020);
	color: #090d14;
	border-color: var(--amber, #ffb020);
}
.spv-cc__btn--primary:hover { background: #ffc840; border-color: #ffc840; }
.spv-cc__btn--ghost {
	background: transparent;
	color: var(--text-dim, #8fa3bf);
	border-color: #2a3a52;
}
.spv-cc__btn--ghost:hover { color: #fff; border-color: #fff; }
@media (max-width: 640px) {
	.spv-cc__inner { flex-direction: column; padding: 16px 20px; gap: 14px; }
	.spv-cc__actions { width: 100%; }
	.spv-cc__btn { flex: 1; text-align: center; }
}

/* Mobile: 600px fixes */
@media (max-width: 600px) {
	/* WooCommerce tabs scroll horizontally instead of overflowing */
	.woocommerce div.product .woocommerce-tabs ul.tabs { display: flex; overflow-x: auto; flex-wrap: nowrap; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
	.woocommerce div.product .woocommerce-tabs ul.tabs::-webkit-scrollbar { display: none; }
	.woocommerce div.product .woocommerce-tabs ul.tabs li { flex-shrink: 0; white-space: nowrap; }
	/* Tab panel: full rounded corners when tabs scroll */
	.woocommerce div.product .woocommerce-tabs .panel { border-radius: var(--r); }
	/* Add-to-cart row stretches to full width */
	.woocommerce div.product form.cart { display: flex; flex-wrap: wrap; gap: 10px; align-items: stretch; }
	.woocommerce div.product form.cart .quantity { flex: none; }
	.woocommerce div.product form.cart .single_add_to_cart_button { flex: 1; min-width: 0; }
	/* Quote button spans full width below cart form */
	.spv-quote-btn { width: 100%; justify-content: center; }
	/* Review form: name + email stack */
	#respond .comment-form-author,
	#respond .comment-form-email { width: 100% !important; float: none !important; margin-right: 0 !important; }
}

/* Mobile: 480px fixes */
@media (max-width: 480px) {
	/* Footer copyright bar stacks */
	.site-footer__bar-inner { flex-direction: column; align-items: flex-start; gap: 6px; }
	.site-footer__legal { gap: 14px; }
	/* Topbar links tighter on very small screens */
	.topbar__links { gap: 10px; font-size: .76rem; }
	.topbar__account { padding: 4px 9px; }
}

/* Bulk quote request button */
.spv-quote-btn { display: inline-flex; align-items: center; gap: 7px; margin-top: 10px; background: transparent; border: 1px solid var(--line); color: var(--text-dim); font-size: .9rem; padding: 11px 18px; border-radius: var(--r-sm); transition: border-color .16s, color .16s; text-decoration: none; }
.spv-quote-btn:hover { border-color: var(--amber); color: var(--amber); }
.spv-quote-btn .ico { flex-shrink: 0; }
