/* ==========================================================================
   Fast Step — design system
   Ported from the "Fast Step Industrial Parts" prototype. Black & amber,
   Archivo display + Hanken Grotesk body. All values mirror the prototype's
   inline styles, re-expressed as tokens + components.
   ========================================================================== */

:root {
	--fs-ink:        #0B0B0C;
	--fs-ink-2:      #18181B;
	--fs-ink-3:      #27272A;
	--fs-ink-4:      #3F3F46;
	--fs-gray-1:     #52525B;
	--fs-gray-2:     #71717A;
	--fs-gray-3:     #A1A1AA;
	--fs-gray-4:     #C4C4C8;
	--fs-d4:         #D4D4D8;
	--fs-line:       #E5E5E7;
	--fs-line-2:     #F0F0F1;
	--fs-line-3:     #EFEFF1;
	--fs-surface:    #F5F5F6;
	--fs-surface-2:  #FAFAFA;
	--fs-surface-3:  #F6F6F7;
	--fs-amber:      #FFB200;
	--fs-amber-ink:  #B98600;
	--fs-green:      #16a34a;
	--fs-red:        #dc2626;
	--fs-white:      #ffffff;

	--fs-display: 'Archivo', system-ui, sans-serif;
	--fs-body:    'Hanken Grotesk', system-ui, sans-serif;
	--fs-max:     1280px;
	--fs-radius:  8px;
}

/* ---- accessibility helpers ---- */
.screen-reader-text {
	border: 0; clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%);
	height: 1px; width: 1px; margin: -1px; padding: 0; overflow: hidden;
	position: absolute !important; word-wrap: normal !important;
}
.screen-reader-text:focus {
	background: #fff; clip: auto !important; clip-path: none;
	color: var(--fs-ink); display: block; height: auto; left: 6px; top: 6px;
	padding: 12px 18px; width: auto; z-index: 100000; border-radius: 6px;
	box-shadow: 0 6px 18px rgba(0,0,0,.25); font-family: var(--fs-display); font-weight: 700;
}

/* ---- reset / base (from prototype <style>) ---- */
*, *::before, *::after { box-sizing: border-box; }
.fs-site {
	margin: 0;
	font-family: var(--fs-body);
	color: var(--fs-ink-2);
	background: #fff;
	-webkit-font-smoothing: antialiased;
	overflow-x: clip; /* contain decorative absolute elements without breaking the sticky header */
}
.fs-site ::selection { background: var(--fs-amber); color: var(--fs-ink); }
.fs-site img { max-width: 100%; height: auto; }
.fs-site a { color: inherit; }
.fs-icon { display: block; flex: none; }
[data-noscrollbar] { scrollbar-width: none; }
[data-noscrollbar]::-webkit-scrollbar { display: none; }

@keyframes fs-fadeUp { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
@keyframes fs-fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes fs-cartSlideIn { from { transform: translateX(100%); } to { transform: none; } }
@keyframes fs-spinslow { to { transform: rotate(360deg); } }
@keyframes fs-pulse { 0%, 100% { opacity: 1; } 50% { opacity: .5; } }

/* ---- layout ---- */
.fs-container { max-width: var(--fs-max); margin: 0 auto; padding: 0 24px; }
.fs-section { max-width: var(--fs-max); margin: 0 auto; padding: 72px 24px; }
.fs-band { border-top: 1px solid var(--fs-line); border-bottom: 1px solid var(--fs-line); background: var(--fs-surface); }
.fs-band .fs-section { padding: 64px 24px; }

/* ---- buttons ---- */
.fs-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 9px;
	font-family: var(--fs-display); font-weight: 800; font-size: 14px;
	letter-spacing: .03em; text-transform: uppercase;
	border: none; border-radius: 6px; padding: 15px 26px; cursor: pointer;
	text-decoration: none; transition: background .15s, color .15s, border-color .15s;
	line-height: 1;
}
.fs-btn--dark  { background: var(--fs-ink); color: #fff; }
.fs-btn--dark:hover  { background: var(--fs-ink-3); color: #fff; }
.fs-btn--amber { background: var(--fs-amber); color: var(--fs-ink); }
.fs-btn--amber:hover { background: var(--fs-ink); color: var(--fs-amber); }
.fs-btn--ghost { background: transparent; color: var(--fs-ink); border: 1.5px solid var(--fs-d4); }
.fs-btn--ghost:hover { border-color: var(--fs-ink); }
.fs-btn--light { background: #fff; color: var(--fs-ink); border: 1.5px solid var(--fs-d4); }
.fs-btn--light:hover { border-color: var(--fs-ink); }
.fs-btn--block { width: 100%; }
.fs-btn--sm { padding: 12px 18px; font-size: 12px; }

/* ---- section heading + eyebrow ---- */
.fs-eyebrow { display: flex; align-items: center; gap: 9px; margin-bottom: 10px; }
.fs-eyebrow--center { justify-content: center; }
.fs-eyebrow__bar { width: 24px; height: 2px; background: var(--fs-amber); flex: none; }
.fs-eyebrow__icon { display: flex; color: var(--fs-ink); }
.fs-eyebrow__text {
	font-family: var(--fs-display); font-weight: 700; font-size: 12px;
	letter-spacing: .16em; text-transform: uppercase; color: var(--fs-amber-ink);
}
.fs-h2 { margin: 0; font-family: var(--fs-display); font-weight: 800; font-size: 36px; letter-spacing: -.02em; color: var(--fs-ink); }
.fs-sechead { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 30px; flex-wrap: wrap; }
.fs-sechead__link {
	font-family: var(--fs-display); font-weight: 700; font-size: 12.5px; letter-spacing: .05em;
	text-transform: uppercase; color: var(--fs-ink); text-decoration: none;
	display: inline-flex; align-items: center; gap: 7px; white-space: nowrap;
}
.fs-sechead__link:hover { color: var(--fs-amber-ink); }

/* ---- carousels ---- */
.fs-carousel { display: flex; gap: 16px; overflow-x: auto; scroll-snap-type: x proximity; scroll-behavior: smooth; padding: 4px 2px 10px; }
.fs-carousel > * { scroll-snap-align: start; flex: 0 0 250px; }
.fs-arrows { display: flex; gap: 8px; }
.fs-arrow {
	width: 42px; height: 42px; border: 1px solid var(--fs-d4); background: #fff; border-radius: 50%;
	display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--fs-ink);
	font-size: 22px; line-height: 0; transition: .15s;
}
.fs-arrow:hover { border-color: var(--fs-ink); background: var(--fs-ink); color: #fff; }

/* ---- countdown ---- */
.fs-cd { display: flex; align-items: center; gap: 7px; }
.fs-cd__cell { display: flex; flex-direction: column; align-items: center; }
.fs-cd__num {
	background: var(--fs-ink); color: #fff; font-family: var(--fs-display); font-weight: 800; font-size: 16px;
	width: 42px; height: 42px; border-radius: 6px; display: flex; align-items: center; justify-content: center;
}
.fs-cd__num--amber { background: var(--fs-amber); color: var(--fs-ink); }
.fs-cd__label { font-size: 9.5px; color: var(--fs-gray-3); margin-top: 4px; letter-spacing: .05em; }

/* =========================================================================
   HEADER
   ========================================================================= */
.fs-announce { background: var(--fs-ink); color: #fff; }
.fs-announce__inner { max-width: var(--fs-max); margin: 0 auto; padding: 0 24px; height: 38px; display: flex; align-items: center; justify-content: center; gap: 10px; }
.fs-announce__icon { color: var(--fs-amber); display: flex; }
.fs-announce__text { font-size: 12.5px; letter-spacing: .02em; color: #E4E4E7; text-align: center; }

.fs-header { position: sticky; top: 0; z-index: 50; background: #fff; border-bottom: 1px solid var(--fs-line); }
.fs-topbar { border-bottom: 1px solid var(--fs-line-2); }
.fs-topbar__inner { max-width: var(--fs-max); margin: 0 auto; padding: 0 24px; height: 36px; display: flex; align-items: center; justify-content: space-between; font-size: 12px; color: var(--fs-gray-2); }
.fs-topbar__left { display: flex; align-items: center; gap: 20px; }
.fs-topbar__item { display: flex; align-items: center; gap: 6px; }
.fs-topbar__item svg { color: var(--fs-ink); }
.fs-topbar__sep { opacity: .4; }
.fs-topbar__right { display: flex; align-items: center; gap: 18px; }
.fs-topbar__right ul { display: flex; align-items: center; gap: 18px; list-style: none; margin: 0; padding: 0; }
.fs-topbar__right li { margin: 0; list-style: none; }
.fs-topbar__right a { text-decoration: none; color: var(--fs-gray-2); }
.fs-topbar__right a:hover { color: var(--fs-ink); }
.fs-topbar__b2b { color: var(--fs-ink) !important; font-weight: 600; display: flex; align-items: center; gap: 6px; }
.fs-topbar strong { color: var(--fs-ink); }

/* Language switcher */
.fs-lang { display: inline-flex; align-items: center; gap: 7px; direction: ltr; }
.fs-lang__ico { color: var(--fs-gray-3); display: flex; flex: none; }
.fs-lang__link { font-size: 12.5px; font-weight: 600; color: var(--fs-gray-2); text-decoration: none; }
.fs-lang__link:hover { color: var(--fs-ink) !important; }
.fs-lang__link.is-current { color: var(--fs-ink); }
.fs-lang__sep { color: var(--fs-line); font-size: 12px; }
/* Drawer variant (mobile menu) */
.fs-lang--drawer { display: flex; gap: 10px; margin: 6px 16px 4px; padding: 12px 14px; border: 1px solid var(--fs-line); border-radius: 8px; }
.fs-lang--drawer .fs-lang__link { font-size: 15px; }

.fs-bar { max-width: var(--fs-max); margin: 0 auto; padding: 0 24px; height: 84px; display: flex; align-items: center; gap: 28px; }
.fs-logo { display: flex; align-items: center; gap: 11px; text-decoration: none; flex: none; }
.fs-logo__mark { width: 44px; height: 44px; background: var(--fs-ink); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: var(--fs-amber); }
.fs-logo__mark img { width: 44px; height: 44px; border-radius: 8px; object-fit: cover; }
.fs-logo__name { display: flex; flex-direction: column; line-height: 1; }
.fs-logo__title { font-family: var(--fs-display); font-weight: 900; font-size: 22px; letter-spacing: -.02em; color: var(--fs-ink); }
.fs-logo__tag { font-family: var(--fs-display); font-weight: 600; font-size: 9.5px; letter-spacing: .22em; color: var(--fs-gray-3); margin-top: 3px; }

.fs-search { flex: 1; display: flex; align-items: stretch; height: 48px; border: 2px solid var(--fs-ink); border-radius: 6px; overflow: hidden; background: #fff; }
.fs-search__cat { position: relative; display: flex; align-items: center; border-right: 1px solid var(--fs-line); background: var(--fs-surface-2); }
.fs-search__cat select { appearance: none; border: none; background: transparent; padding: 0 34px 0 16px; font-size: 13px; font-weight: 600; color: var(--fs-ink); cursor: pointer; height: 100%; outline: none; }
.fs-search__cat svg { position: absolute; right: 12px; pointer-events: none; color: var(--fs-gray-2); }
.fs-search__input { flex: 1; border: none; outline: none; padding: 0 16px; font-size: 14px; color: var(--fs-ink-2); min-width: 0; }
.fs-search__btn {
	background: var(--fs-amber); border: none; padding: 0 24px; display: flex; align-items: center; gap: 8px; cursor: pointer; color: var(--fs-ink);
	font-family: var(--fs-display); font-weight: 800; font-size: 13px; letter-spacing: .04em; text-transform: uppercase; transition: .15s;
}
.fs-search__btn:hover { background: var(--fs-ink); color: var(--fs-amber); }

.fs-actions { display: flex; align-items: center; gap: 6px; flex: none; }
.fs-iconbtn { display: flex; flex-direction: column; align-items: center; gap: 3px; background: none; border: none; cursor: pointer; padding: 6px 10px; color: var(--fs-ink-3); position: relative; text-decoration: none; }
.fs-iconbtn:hover { color: var(--fs-ink); }
.fs-iconbtn__label { font-size: 10.5px; font-weight: 600; letter-spacing: .02em; }
.fs-bubble { position: absolute; top: -7px; right: -9px; background: var(--fs-ink); color: #fff; font-size: 10px; font-weight: 700; min-width: 16px; height: 16px; border-radius: 8px; display: flex; align-items: center; justify-content: center; padding: 0 3px; }
.fs-cartbtn { display: flex; align-items: center; gap: 10px; background: var(--fs-ink); border: none; cursor: pointer; padding: 10px 16px; border-radius: 6px; color: #fff; text-decoration: none; transition: .15s; }
.fs-cartbtn:hover { background: var(--fs-ink-3); }
.fs-cartbtn__ico { position: relative; display: flex; color: var(--fs-amber); }
.fs-cartbtn__ico .fs-bubble { background: var(--fs-amber); color: var(--fs-ink); top: -9px; right: -10px; font-weight: 800; min-width: 17px; height: 17px; border-radius: 9px; }
.fs-cartbtn__meta { display: flex; flex-direction: column; align-items: flex-start; line-height: 1.15; min-width: 0; }
.fs-cartbtn__cap { font-size: 10px; letter-spacing: .04em; color: var(--fs-gray-3); }
.fs-cartbtn__val { font-family: var(--fs-display); font-weight: 800; font-size: 14px; white-space: nowrap; color: #fff; }
/* Keep the WooCommerce price amount white & on one line inside the dark pill
   (long currencies like SAR ر.س were wrapping and losing colour). */
.fs-cartbtn__val .woocommerce-Price-amount,
.fs-cartbtn__val .woocommerce-Price-currencySymbol,
.fs-cartbtn__val bdi { color: #fff; white-space: nowrap; }

/* nav bar */
.fs-navbar { border-top: 1px solid var(--fs-line-2); background: #fff; }
.fs-navbar__inner { max-width: var(--fs-max); margin: 0 auto; padding: 0 24px; height: 52px; display: flex; align-items: center; gap: 4px; }
.fs-megatrigger { position: relative; align-self: stretch; display: flex; align-items: center; }
.fs-megatrigger__btn {
	display: flex; align-items: center; gap: 10px; background: var(--fs-amber); border: none; cursor: pointer; height: 38px; padding: 0 18px; border-radius: 6px; color: var(--fs-ink);
	font-family: var(--fs-display); font-weight: 800; font-size: 13px; letter-spacing: .03em; text-transform: uppercase;
}
.fs-nav { display: flex; align-items: center; gap: 2px; margin-left: 8px; list-style: none; padding: 0; }
.fs-nav a { display: flex; align-items: center; gap: 7px; padding: 10px 14px; font-family: var(--fs-body); font-weight: 600; font-size: 14px; color: var(--fs-ink-3); text-decoration: none; border-radius: 6px; }
.fs-nav a:hover { background: var(--fs-surface); color: var(--fs-ink); }
.fs-nav__tag { background: var(--fs-amber); color: var(--fs-ink); font-family: var(--fs-display); font-weight: 800; font-size: 9px; letter-spacing: .04em; padding: 2px 5px; border-radius: 3px; }
.fs-bulk { margin-left: auto; display: flex; align-items: center; gap: 7px; font-family: var(--fs-display); font-weight: 700; font-size: 12.5px; letter-spacing: .03em; text-transform: uppercase; color: var(--fs-ink); text-decoration: none; }
.fs-bulk:hover { color: var(--fs-amber-ink); }

/* mega menu */
.fs-mega { position: absolute; top: calc(100% + 8px); left: 0; width: 940px; max-width: calc(100vw - 48px); background: #fff; border: 1px solid var(--fs-line); box-shadow: 0 30px 70px rgba(0,0,0,.22); border-radius: 8px; display: grid; grid-template-columns: 262px 1fr; overflow: hidden; z-index: 60; }
.fs-mega[hidden] { display: none; }
.fs-mega__rail { background: var(--fs-ink); padding: 8px 0; }
.fs-mega__cat { width: 100%; display: flex; align-items: center; gap: 13px; padding: 10px 18px; background: transparent; border: none; border-left: 3px solid transparent; cursor: pointer; color: var(--fs-d4); font-family: var(--fs-body); font-weight: 500; font-size: 13.5px; text-align: left; text-decoration: none; }
/* Guard: keep rail labels readable even if a plugin styles generic <a> links. */
.fs-mega__rail .fs-mega__cat, .fs-mega__rail .fs-mega__cat span { color: var(--fs-d4); }
.fs-mega__rail .fs-mega__cat:hover, .fs-mega__rail .fs-mega__cat:hover span,
.fs-mega__rail .fs-mega__cat.is-active, .fs-mega__rail .fs-mega__cat.is-active span { color: #fff; }
.fs-mega__cat svg { color: var(--fs-amber); display: flex; }
.fs-mega__cat .fs-mega__chev { margin-left: auto; opacity: .5; }
.fs-mega__cat:hover, .fs-mega__cat.is-active { background: var(--fs-ink-2); color: #fff; border-left-color: var(--fs-amber); }
.fs-mega__panels { min-width: 0; display: flex; }
.fs-mega__panel { flex: 1; padding: 26px 28px; display: grid; grid-template-columns: 1fr 232px; gap: 28px; align-content: stretch; min-height: 320px; }
.fs-mega__panel[hidden] { display: none; }
.fs-mega__head { display: flex; align-items: center; gap: 8px; margin-bottom: 18px; }
.fs-mega__title { font-family: var(--fs-display); font-weight: 800; font-size: 17px; color: var(--fs-ink); }
.fs-mega__count { font-size: 12px; color: var(--fs-gray-3); font-weight: 500; }
.fs-mega__subs { display: grid; grid-template-columns: 1fr 1fr; gap: 2px 28px; }
.fs-mega__sub { display: flex; align-items: center; justify-content: space-between; font-family: var(--fs-body); font-size: 13.5px; color: var(--fs-gray-1); text-decoration: none; padding: 7px 0; border-bottom: 1px solid var(--fs-surface); }
.fs-mega__sub:hover { color: var(--fs-ink); }
.fs-mega__sub span { font-size: 11px; color: var(--fs-gray-4); }
.fs-mega__all { display: inline-flex; align-items: center; gap: 7px; margin-top: 18px; font-family: var(--fs-display); font-weight: 700; font-size: 12px; letter-spacing: .05em; text-transform: uppercase; color: var(--fs-ink); text-decoration: none; }
.fs-mega__all:hover { color: var(--fs-amber-ink); }
.fs-mega__feat { position: relative; display: flex; flex-direction: column; justify-content: flex-end; background: var(--fs-ink); border-radius: 8px; padding: 20px; text-decoration: none; overflow: hidden; min-height: 230px; }
.fs-mega__feat-tag { position: absolute; top: 16px; left: 16px; background: var(--fs-amber); color: var(--fs-ink); font-family: var(--fs-display); font-weight: 800; font-size: 10px; letter-spacing: .06em; text-transform: uppercase; padding: 5px 9px; border-radius: 3px; z-index: 2; }
.fs-mega__feat-ico { position: absolute; top: 46%; left: 50%; transform: translate(-50%,-50%); color: var(--fs-ink-4); }
.fs-mega__feat-title { color: #fff; font-family: var(--fs-display); font-weight: 800; font-size: 16px; line-height: 1.25; position: relative; z-index: 2; }
.fs-mega__feat-sub { color: var(--fs-gray-3); font-size: 12.5px; margin-top: 5px; position: relative; z-index: 2; }
.fs-mega-scrim { position: fixed; inset: 0; z-index: 55; }
.fs-mega-scrim[hidden] { display: none; }

/* =========================================================================
   HERO
   ========================================================================= */
.fs-hero { background: #fff; background-image: linear-gradient(rgba(11,11,12,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(11,11,12,.035) 1px, transparent 1px); background-size: 30px 30px; border-bottom: 1px solid var(--fs-line); }
.fs-hero__inner { max-width: var(--fs-max); margin: 0 auto; padding: 56px 24px 60px; display: grid; grid-template-columns: 1.35fr 1fr; gap: 48px; align-items: center; }
.fs-hero__badge { display: inline-flex; align-items: center; gap: 9px; background: #fff; border: 1px solid var(--fs-line); padding: 7px 13px; border-radius: 40px; margin-bottom: 24px; }
.fs-hero__dot { width: 7px; height: 7px; border-radius: 50%; background: var(--fs-green); box-shadow: 0 0 0 3px rgba(22,163,74,.18); }
.fs-hero__badge span:last-child { font-size: 12.5px; font-weight: 600; color: var(--fs-ink-4); }
.fs-hero__title { margin: 0 0 20px; font-family: var(--fs-display); font-weight: 900; font-size: 60px; line-height: 1.02; letter-spacing: -.025em; color: var(--fs-ink); }
.fs-hero__hl { position: relative; white-space: nowrap; }
.fs-hero__hl::after { content: ""; position: absolute; left: 0; right: 0; bottom: 6px; height: 14px; background: var(--fs-amber); z-index: -1; opacity: .85; }
.fs-hero__text { margin: 0 0 30px; font-size: 17px; line-height: 1.6; color: var(--fs-gray-1); max-width: 520px; }
.fs-hero__cta { display: flex; align-items: center; gap: 14px; margin-bottom: 30px; flex-wrap: wrap; }
.fs-hero__chips { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
.fs-hero__chips-label { font-size: 12px; font-weight: 600; color: var(--fs-gray-3); letter-spacing: .04em; text-transform: uppercase; }
.fs-chip { font-size: 13px; font-weight: 600; color: var(--fs-ink-4); text-decoration: none; padding-bottom: 3px; border-bottom: 2px solid var(--fs-line); }
.fs-chip:hover { color: var(--fs-ink); border-color: var(--fs-amber); }

.fs-dealcard { position: relative; background: var(--fs-ink); border-radius: 14px; padding: 26px; overflow: hidden; }
.fs-dealcard__gear { position: absolute; right: -40px; top: -40px; color: var(--fs-ink-2); animation: fs-spinslow 26s linear infinite; }
.fs-dealcard__inner { position: relative; z-index: 2; }
.fs-dealcard__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.fs-dealcard__flag { display: inline-flex; align-items: center; gap: 7px; background: var(--fs-amber); color: var(--fs-ink); font-family: var(--fs-display); font-weight: 800; font-size: 11px; letter-spacing: .05em; text-transform: uppercase; padding: 6px 11px; border-radius: 4px; animation: fs-pulse 2.4s ease infinite; }
.fs-dealcard__clock { display: flex; gap: 6px; }
.fs-dealcard__clock span { background: var(--fs-ink-2); color: #fff; font-family: var(--fs-display); font-weight: 800; font-size: 15px; width: 38px; height: 38px; border-radius: 6px; display: flex; align-items: center; justify-content: center; }
.fs-dealcard__clock span.is-amber { background: var(--fs-amber); color: var(--fs-ink); }
.fs-dealcard__body { background: #fff; border-radius: 10px; padding: 22px; display: flex; flex-direction: column; align-items: center; text-align: center; }
.fs-dealcard__media { height: 120px; display: flex; align-items: center; justify-content: center; color: var(--fs-ink-3); transform: scale(1.7); }
.fs-dealcard__media img { max-height: 120px; width: auto; }
.fs-dealcard__brand { font-family: var(--fs-display); font-weight: 700; font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--fs-amber-ink); margin-top: 8px; }
.fs-dealcard__name { font-weight: 600; font-size: 15px; color: var(--fs-ink-2); margin: 4px 0 10px; line-height: 1.3; }
.fs-dealcard__price { display: flex; align-items: baseline; gap: 10px; margin-bottom: 14px; }
.fs-dealcard__price ins { text-decoration: none; font-family: var(--fs-display); font-weight: 900; font-size: 30px; color: var(--fs-ink); }
.fs-dealcard__price del { font-size: 15px; color: var(--fs-gray-3); }
.fs-dealcard__off { background: var(--fs-ink); color: var(--fs-amber); font-family: var(--fs-display); font-weight: 800; font-size: 11px; padding: 3px 7px; border-radius: 4px; }

/* ---- rotating hero image slider (Site Content → Hero slider) ---- */
.fs-heroslider { position: relative; overflow: hidden; padding: 0; }
.fs-slides { position: relative; min-height: 520px; }
.fs-slide { position: absolute; inset: 0; opacity: 0; visibility: hidden; transition: opacity .6s ease; background-size: cover; background-position: center; background-color: var(--fs-ink); display: flex; align-items: center; }
.fs-slide.is-active { opacity: 1; visibility: visible; position: relative; }
.fs-slide__shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(11,11,12,.85) 0%, rgba(11,11,12,.6) 42%, rgba(11,11,12,.15) 100%); }
.fs-slide__inner { position: relative; z-index: 2; max-width: var(--fs-max); margin: 0 auto; padding: 70px 24px; width: 100%; color: #fff; }
.fs-heroslider .fs-hero__title { color: #fff; max-width: 640px; }
.fs-heroslider .fs-hero__text { color: #E5E5E7; max-width: 540px; }
.fs-heroslider .fs-hero__badge { background: rgba(255,255,255,.12); color: #fff; }
.fs-btn--ghostlight { background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,.5); }
.fs-btn--ghostlight:hover { border-color: #fff; background: rgba(255,255,255,.1); }
.fs-slides__nav { position: absolute; top: 50%; transform: translateY(-50%); z-index: 3; width: 46px; height: 46px; border-radius: 50%; border: none; background: rgba(255,255,255,.9); color: var(--fs-ink); font-size: 26px; line-height: 1; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.fs-slides__nav:hover { background: #fff; }
.fs-slides__nav--prev { left: 18px; }
.fs-slides__nav--next { right: 18px; }
.fs-slides__dots { position: absolute; bottom: 18px; left: 50%; transform: translateX(-50%); z-index: 3; display: flex; gap: 8px; }
.fs-dot { width: 9px; height: 9px; border-radius: 50%; border: none; background: rgba(255,255,255,.45); cursor: pointer; padding: 0; transition: .2s; }
.fs-dot.is-active { background: var(--fs-amber); width: 22px; border-radius: 5px; }
@media (max-width: 1100px) { .fs-slides { min-height: 420px; } .fs-slide__inner { padding: 52px 24px; } }

/* =========================================================================
   TRUST STRIP
   ========================================================================= */
.fs-trust { background: var(--fs-ink); color: #fff; }
.fs-trust__inner { max-width: var(--fs-max); margin: 0 auto; padding: 0 24px; display: grid; grid-template-columns: repeat(5,1fr); }
.fs-trust__item { display: flex; align-items: center; gap: 13px; padding: 22px 18px; border-right: 1px solid var(--fs-ink-2); }
.fs-trust__item:last-child { border-right: none; }
.fs-trust__item svg { color: var(--fs-amber); flex: none; }
.fs-trust__title { font-family: var(--fs-display); font-weight: 700; font-size: 13.5px; color: #fff; }
.fs-trust__sub { font-size: 12px; color: var(--fs-gray-3); }

/* =========================================================================
   CATEGORY GRID
   ========================================================================= */
.fs-cats { display: grid; grid-template-columns: repeat(auto-fill, minmax(186px,1fr)); gap: 14px; }
.fs-cat { display: flex; flex-direction: column; gap: 14px; background: #fff; border: 1px solid var(--fs-line); border-radius: 8px; padding: 20px; text-decoration: none; transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease; }
.fs-cat:hover { transform: translateY(-4px); border-color: var(--fs-ink); box-shadow: 0 14px 30px rgba(0,0,0,.10); }
.fs-cat__ico { width: 52px; height: 52px; border-radius: 9px; background: var(--fs-surface); display: flex; align-items: center; justify-content: center; color: var(--fs-ink); }
.fs-cat__name { font-family: var(--fs-display); font-weight: 700; font-size: 15px; color: var(--fs-ink); line-height: 1.2; }
.fs-cat__count { font-size: 12.5px; color: var(--fs-gray-3); }
/* Brand → Category drill-down block on a brand archive */
.fs-brandcats { margin: 0 0 30px; }
.fs-brandcats__title { font-family: var(--fs-display); font-weight: 800; font-size: 22px; letter-spacing: -.01em; color: var(--fs-ink); margin: 0 0 16px; }

/* =========================================================================
   BEST SELLER TABS
   ========================================================================= */
.fs-tabs { display: flex; align-items: center; gap: 4px; background: var(--fs-surface); padding: 5px; border-radius: 8px; }
.fs-tab { background: transparent; border: none; cursor: pointer; padding: 9px 16px; border-radius: 6px; font-family: var(--fs-display); font-weight: 700; font-size: 13px; letter-spacing: .02em; color: var(--fs-gray-1); }
.fs-tab.is-active { background: var(--fs-ink); color: #fff; box-shadow: 0 2px 6px rgba(0,0,0,.18); }

/* =========================================================================
   SPOTLIGHT
   ========================================================================= */
.fs-spotlight { background: var(--fs-ink); color: #fff; overflow: hidden; }
.fs-spotlight__inner { max-width: var(--fs-max); margin: 0 auto; padding: 0 24px; display: grid; grid-template-columns: 1fr 1fr; align-items: stretch; }
.fs-spotlight__copy { padding: 66px 56px 66px 0; }
.fs-spotlight__kick { font-family: var(--fs-display); font-weight: 700; font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--fs-gray-3); margin-bottom: 10px; }
.fs-spotlight__title { margin: 0 0 18px; font-family: var(--fs-display); font-weight: 900; font-size: 42px; line-height: 1.05; letter-spacing: -.02em; }
.fs-spotlight__text { margin: 0 0 26px; font-size: 16px; line-height: 1.6; color: var(--fs-gray-3); max-width: 460px; }
.fs-spotlight__specs { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--fs-ink-3); border: 1px solid var(--fs-ink-3); border-radius: 8px; overflow: hidden; margin-bottom: 28px; max-width: 460px; }
.fs-spotlight__spec { background: var(--fs-ink); padding: 16px 18px; }
.fs-spotlight__spec dt { font-size: 11px; color: var(--fs-gray-2); letter-spacing: .04em; text-transform: uppercase; margin-bottom: 5px; }
.fs-spotlight__spec dd { margin: 0; font-family: var(--fs-display); font-weight: 700; font-size: 17px; color: #fff; }
.fs-spotlight__buy { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
.fs-spotlight__price { display: flex; align-items: baseline; gap: 10px; }
.fs-spotlight__price ins { text-decoration: none; font-family: var(--fs-display); font-weight: 900; font-size: 38px; color: var(--fs-amber); }
.fs-spotlight__price small { font-size: 13px; color: var(--fs-gray-2); }
.fs-spotlight__media { position: relative; display: flex; align-items: center; justify-content: center; background: #111114; border-left: 1px solid var(--fs-ink-3); min-height: 380px; }
.fs-spotlight__gear { position: absolute; color: #1A1A1E; animation: fs-spinslow 40s linear infinite; }
.fs-spotlight__icon { position: relative; color: var(--fs-ink-4); transform: scale(2.6); }
.fs-spotlight__icon img { max-height: 240px; width: auto; }
.fs-spotlight__warranty { position: absolute; bottom: 28px; right: 28px; background: var(--fs-amber); color: var(--fs-ink); font-family: var(--fs-display); font-weight: 800; font-size: 11px; letter-spacing: .05em; text-transform: uppercase; padding: 7px 12px; border-radius: 4px; }

/* =========================================================================
   BRANDS
   ========================================================================= */
.fs-brands { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px,1fr)); gap: 14px; }
.fs-brand { height: 92px; display: flex; align-items: center; justify-content: center; background: #fff; border: 1px solid var(--fs-line); border-radius: 8px; text-decoration: none; transition: border-color .16s ease, box-shadow .16s ease; }
.fs-brand:hover { border-color: var(--fs-ink); box-shadow: 0 10px 24px rgba(0,0,0,.08); }
.fs-brand span { font-family: var(--fs-display); font-weight: 800; font-size: 20px; letter-spacing: .02em; color: var(--fs-ink-4); }
.fs-brand:hover span { color: var(--fs-ink); }

/* =========================================================================
   B2B CTA
   ========================================================================= */
.fs-b2b { position: relative; background: var(--fs-ink); border-radius: 16px; overflow: hidden; display: grid; grid-template-columns: 1.3fr 1fr; gap: 40px; align-items: center; padding: 52px 56px; }
.fs-b2b__bg { position: absolute; right: -30px; bottom: -60px; color: #141417; }
.fs-b2b__copy { position: relative; z-index: 2; }
.fs-b2b__tag { display: inline-flex; align-items: center; gap: 8px; background: var(--fs-amber); color: var(--fs-ink); font-family: var(--fs-display); font-weight: 800; font-size: 11px; letter-spacing: .06em; text-transform: uppercase; padding: 6px 12px; border-radius: 4px; margin-bottom: 20px; }
.fs-b2b__title { margin: 0 0 16px; font-family: var(--fs-display); font-weight: 900; font-size: 40px; line-height: 1.05; letter-spacing: -.02em; color: #fff; }
.fs-b2b__text { margin: 0 0 28px; font-size: 16px; line-height: 1.6; color: var(--fs-gray-3); max-width: 520px; }
.fs-b2b__btns { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.fs-b2b__perks { position: relative; z-index: 2; display: flex; flex-direction: column; gap: 12px; }
.fs-perk { display: flex; align-items: center; gap: 14px; background: #141417; border: 1px solid var(--fs-ink-3); border-radius: 10px; padding: 16px 18px; }
.fs-perk svg { color: var(--fs-amber); flex: none; }
.fs-perk__title { font-family: var(--fs-display); font-weight: 700; font-size: 14.5px; color: #fff; }
.fs-perk__sub { font-size: 12.5px; color: var(--fs-gray-3); }

/* =========================================================================
   WHY CHOOSE US
   ========================================================================= */
.fs-why { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px,1fr)); gap: 16px; }
.fs-whycard { background: #fff; border: 1px solid var(--fs-line); border-radius: 10px; padding: 26px; transition: border-color .16s ease, box-shadow .16s ease; }
.fs-whycard:hover { border-color: var(--fs-ink); box-shadow: 0 12px 28px rgba(0,0,0,.08); }
.fs-whycard__ico { width: 50px; height: 50px; border-radius: 10px; background: var(--fs-ink); display: flex; align-items: center; justify-content: center; color: var(--fs-amber); margin-bottom: 18px; }
.fs-whycard__title { font-family: var(--fs-display); font-weight: 800; font-size: 17px; color: var(--fs-ink); margin-bottom: 8px; }
.fs-whycard__text { font-size: 14px; line-height: 1.55; color: var(--fs-gray-1); }

/* =========================================================================
   REVIEWS
   ========================================================================= */
.fs-reviews { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr)); gap: 16px; }
.fs-review { background: #fff; border: 1px solid var(--fs-line); border-radius: 10px; padding: 28px; display: flex; flex-direction: column; gap: 16px; }
.fs-review__top { display: flex; align-items: center; justify-content: space-between; }
.fs-review__verified { display: inline-flex; align-items: center; gap: 5px; font-size: 11.5px; font-weight: 600; color: var(--fs-green); }
.fs-review__text { margin: 0; font-size: 15px; line-height: 1.6; color: var(--fs-ink-3); }
.fs-review__who { display: flex; align-items: center; gap: 12px; margin-top: auto; padding-top: 8px; border-top: 1px solid var(--fs-line-2); }
.fs-review__avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--fs-ink); color: var(--fs-amber); display: flex; align-items: center; justify-content: center; font-family: var(--fs-display); font-weight: 800; font-size: 16px; }
.fs-review__name { font-weight: 700; font-size: 14px; color: var(--fs-ink); }
.fs-review__role { font-size: 12.5px; color: var(--fs-gray-3); }
.fs-stars { display: inline-flex; gap: 1px; line-height: 1; font-size: 14px; }

/* =========================================================================
   NEWSLETTER
   ========================================================================= */
.fs-news { background: var(--fs-amber); }
.fs-news__inner { max-width: var(--fs-max); margin: 0 auto; padding: 52px 24px; display: flex; align-items: center; justify-content: space-between; gap: 40px; flex-wrap: wrap; }
.fs-news__copy { max-width: 560px; }
.fs-news__title { margin: 0 0 8px; font-family: var(--fs-display); font-weight: 900; font-size: 32px; letter-spacing: -.02em; color: var(--fs-ink); }
.fs-news__text { margin: 0; font-size: 15.5px; line-height: 1.5; color: #3A2E08; }
.fs-news__form { display: flex; align-items: stretch; gap: 10px; flex: 1; min-width: 340px; max-width: 520px; }
.fs-news__form input { flex: 1; border: 2px solid var(--fs-ink); border-radius: 6px; padding: 0 18px; height: 54px; font-size: 15px; outline: none; background: #fff; color: var(--fs-ink); }
.fs-news__form button { background: var(--fs-ink); color: #fff; border: none; border-radius: 6px; padding: 0 28px; font-family: var(--fs-display); font-weight: 800; font-size: 14px; letter-spacing: .04em; text-transform: uppercase; cursor: pointer; white-space: nowrap; }
.fs-news__form button:hover { background: var(--fs-ink-3); }

/* =========================================================================
   FOOTER
   ========================================================================= */
.fs-footer { background: var(--fs-ink); color: #fff; }
.fs-footer__top { max-width: var(--fs-max); margin: 0 auto; padding: 60px 24px 0; display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; }
.fs-footer__brand .fs-logo__tag { color: var(--fs-gray-2); }
.fs-footer__about { margin: 18px 0 20px; font-size: 14px; line-height: 1.6; color: var(--fs-gray-3); max-width: 340px; }
.fs-footer__socials { display: flex; gap: 10px; }
.fs-footer__socials a { width: 38px; height: 38px; border: 1px solid var(--fs-ink-3); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: var(--fs-gray-3); text-decoration: none; }
.fs-footer__socials a:hover { border-color: var(--fs-amber); color: var(--fs-amber); }
.fs-footer__col-title { font-family: var(--fs-display); font-weight: 700; font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: #fff; margin-bottom: 16px; }
.fs-footer__links { display: flex; flex-direction: column; gap: 11px; list-style: none; padding: 0; margin: 0; }
.fs-footer__links a { font-size: 14px; color: var(--fs-gray-3); text-decoration: none; }
.fs-footer__links a:hover { color: var(--fs-amber); }
.fs-footer__bar { max-width: var(--fs-max); margin: 40px auto 0; padding: 22px 24px; border-top: 1px solid var(--fs-ink-2); display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.fs-footer__copyright { font-size: 12.5px; color: var(--fs-gray-2); }
.fs-footer__pay { display: flex; align-items: center; gap: 8px; }
.fs-footer__pay span { height: 30px; padding: 0 12px; background: var(--fs-ink-2); border: 1px solid var(--fs-ink-3); border-radius: 5px; display: flex; align-items: center; font-family: var(--fs-display); font-weight: 800; font-size: 11px; letter-spacing: .03em; color: var(--fs-gray-3); }
.fs-footer__spacer { height: 18px; }

/* =========================================================================
   PRODUCT CARD
   ========================================================================= */
.fs-card { display: flex; flex-direction: column; height: 100%; min-height: 360px; background: #fff; border: 1px solid var(--fs-line); border-radius: 8px; overflow: hidden; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.fs-card:hover { transform: translateY(-4px); border-color: var(--fs-ink); box-shadow: 0 16px 34px rgba(0,0,0,.12); }
.fs-card__media { position: relative; background: var(--fs-surface-3); height: 182px; display: flex; align-items: center; justify-content: center; color: var(--fs-ink-3); border-bottom: 1px solid #EDEDEF; }
.fs-card__media a { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; text-decoration: none; }
.fs-prodmedia__icon { display: flex; transform: scale(1.4); }
.fs-prodmedia__img { max-height: 150px; width: auto; object-fit: contain; }
.fs-card__badge { position: absolute; top: 12px; left: 12px; background: var(--fs-amber); color: var(--fs-ink); font-family: var(--fs-display); font-weight: 800; font-size: 10px; letter-spacing: .06em; text-transform: uppercase; padding: 5px 8px; border-radius: 3px; z-index: 2; }
.fs-card__wish { position: absolute; top: 10px; right: 10px; width: 34px; height: 34px; display: flex; align-items: center; justify-content: center; background: #fff; border: 1px solid var(--fs-line); border-radius: 50%; cursor: pointer; color: var(--fs-gray-3); z-index: 2; }
.fs-card__wish:hover { border-color: var(--fs-ink); }
.fs-card__wish.is-active { color: var(--fs-amber); }
.fs-card__body { padding: 14px 14px 0; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.fs-card__brand { font-family: var(--fs-display); font-weight: 700; font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--fs-amber-ink); }
.fs-card__name { font-weight: 600; font-size: 14.5px; line-height: 1.3; color: var(--fs-ink-2); min-height: 38px; text-decoration: none; }
.fs-card__name:hover { color: var(--fs-amber-ink); }
.fs-card__sku { font-size: 11.5px; color: var(--fs-gray-3); font-family: var(--fs-display); letter-spacing: .02em; }
.fs-card__rating { display: flex; align-items: center; gap: 6px; }
.fs-card__rating span.fs-card__reviews { font-size: 11.5px; color: var(--fs-gray-3); }
.fs-card__price { display: flex; align-items: baseline; gap: 8px; margin-top: 2px; }
.fs-card__price .amount, .fs-card__price ins .amount, .fs-card__price ins { text-decoration: none; }
.fs-card__price ins { font-family: var(--fs-display); font-weight: 800; font-size: 20px; color: var(--fs-ink); }
.fs-card__price > .amount { font-family: var(--fs-display); font-weight: 800; font-size: 20px; color: var(--fs-ink); }
.fs-card__price del { font-size: 13px; color: var(--fs-gray-3); }
.fs-card__foot { padding: 12px 14px 14px; }
.fs-card__add { width: 100%; display: flex; align-items: center; justify-content: center; gap: 8px; background: var(--fs-ink); color: #fff; border: none; border-radius: 5px; padding: 12px; font-family: var(--fs-display); font-weight: 700; font-size: 12px; letter-spacing: .05em; text-transform: uppercase; white-space: nowrap; cursor: pointer; text-decoration: none; transition: background .15s, color .15s; }
.fs-card__add:hover { background: var(--fs-amber); color: var(--fs-ink); }
.fs-card__add.loading { opacity: .7; pointer-events: none; }

/* =========================================================================
   CART DRAWER
   ========================================================================= */
.fs-drawer-overlay { position: fixed; inset: 0; background: rgba(11,11,12,.5); z-index: 90; backdrop-filter: blur(2px); opacity: 0; visibility: hidden; transition: opacity .25s ease, visibility .25s ease; }
.fs-drawer { position: fixed; top: 0; right: 0; height: 100%; width: 428px; max-width: 94vw; background: #fff; z-index: 100; display: flex; flex-direction: column; box-shadow: -24px 0 60px rgba(0,0,0,.28); transform: translateX(100%); transition: transform .3s cubic-bezier(.4,0,.2,1); }
.fs-drawer-open .fs-drawer-overlay { opacity: 1; visibility: visible; }
.fs-drawer-open .fs-drawer { transform: translateX(0); }
.fs-drawer__head { display: flex; align-items: center; justify-content: space-between; padding: 20px 22px; border-bottom: 1px solid var(--fs-line); background: var(--fs-ink); color: #fff; flex: none; }
.fs-drawer__title { display: flex; align-items: center; gap: 11px; font-family: var(--fs-display); font-weight: 800; font-size: 17px; letter-spacing: .02em; }
.fs-drawer__title svg { color: var(--fs-amber); }
.fs-drawer__count { background: var(--fs-amber); color: var(--fs-ink); font-family: var(--fs-display); font-weight: 800; font-size: 12px; min-width: 22px; height: 22px; border-radius: 11px; display: flex; align-items: center; justify-content: center; padding: 0 6px; }
.fs-drawer__close { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; background: var(--fs-ink-2); border: none; border-radius: 8px; cursor: pointer; color: #fff; }
.fs-drawer__close:hover { background: var(--fs-ink-3); }
.fs-drawer__dynamic { flex: 1; display: flex; flex-direction: column; min-height: 0; }
.fs-drawer__progress { padding: 16px 22px; background: var(--fs-surface-2); border-bottom: 1px solid var(--fs-line); flex: none; }
.fs-drawer__progress-row { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--fs-ink-3); margin-bottom: 10px; }
.fs-drawer__progress-row svg { color: var(--fs-ink); }
.fs-drawer__track { height: 7px; background: var(--fs-line); border-radius: 4px; overflow: hidden; }
.fs-drawer__fill { height: 100%; background: var(--fs-amber); border-radius: 4px; transition: width .3s ease; }
.fs-drawer__body { flex: 1; overflow-y: auto; padding: 0 22px; }
.fs-drawer__item { display: flex; gap: 13px; padding: 18px 0; border-bottom: 1px solid var(--fs-line-2); }
.fs-drawer__item-media { width: 66px; height: 66px; flex: none; background: var(--fs-surface-3); border: 1px solid #EDEDEF; border-radius: 8px; display: flex; align-items: center; justify-content: center; color: var(--fs-ink-4); overflow: hidden; }
.fs-drawer__item-media img { max-width: 100%; height: auto; }
.fs-drawer__item-main { flex: 1; min-width: 0; }
.fs-drawer__item-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.fs-drawer__item-brand { font-family: var(--fs-display); font-weight: 700; font-size: 9.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--fs-amber-ink); }
.fs-drawer__item-name { font-size: 13.5px; font-weight: 600; color: var(--fs-ink-2); line-height: 1.3; margin-top: 2px; text-decoration: none; display: block; }
.fs-drawer__item-remove { flex: none; width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; background: none; border: none; cursor: pointer; color: var(--fs-gray-3); border-radius: 6px; }
.fs-drawer__item-remove:hover { color: var(--fs-red); background: #FEF2F2; }
.fs-drawer__item-bot { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 10px; }
.fs-qtybox { display: flex; align-items: center; border: 1px solid var(--fs-line); border-radius: 6px; overflow: hidden; }
.fs-qtybox button { width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; background: var(--fs-surface-2); border: none; cursor: pointer; color: var(--fs-ink-3); }
.fs-qtybox button:hover { background: var(--fs-ink); color: #fff; }
.fs-qtybox span { min-width: 34px; text-align: center; font-family: var(--fs-display); font-weight: 700; font-size: 14px; color: var(--fs-ink); }
.fs-drawer__item-price { display: flex; flex-direction: column; align-items: flex-end; line-height: 1.2; }
.fs-drawer__item-line { font-family: var(--fs-display); font-weight: 800; font-size: 16px; color: var(--fs-ink); }
.fs-drawer__item-each { font-size: 11px; color: var(--fs-gray-3); }
.fs-drawer__addon { margin: 18px 0; padding: 16px; background: var(--fs-surface); border-radius: 10px; }
.fs-drawer__addon-label { font-family: var(--fs-display); font-weight: 700; font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--fs-gray-2); margin-bottom: 12px; }
.fs-drawer__addon-row { display: flex; align-items: center; gap: 12px; }
.fs-drawer__addon-media { width: 48px; height: 48px; flex: none; background: #fff; border: 1px solid var(--fs-line); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: var(--fs-ink-4); }
.fs-drawer__addon-name { font-size: 13px; font-weight: 600; color: var(--fs-ink-2); line-height: 1.3; }
.fs-drawer__addon-price { font-family: var(--fs-display); font-weight: 800; font-size: 14px; color: var(--fs-ink); margin-top: 2px; }
.fs-drawer__addon-add { flex: none; display: flex; align-items: center; gap: 5px; background: var(--fs-ink); color: #fff; border: none; border-radius: 6px; padding: 9px 12px; font-family: var(--fs-display); font-weight: 700; font-size: 11px; letter-spacing: .04em; text-transform: uppercase; cursor: pointer; }
.fs-drawer__addon-add:hover { background: var(--fs-amber); color: var(--fs-ink); }
.fs-drawer__empty { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 70px 20px; }
.fs-drawer__empty-ico { width: 80px; height: 80px; border-radius: 50%; background: var(--fs-surface); display: flex; align-items: center; justify-content: center; color: var(--fs-gray-4); margin-bottom: 20px; }
.fs-drawer__empty-title { font-family: var(--fs-display); font-weight: 800; font-size: 19px; color: var(--fs-ink); margin-bottom: 8px; }
.fs-drawer__empty-text { margin: 0 0 22px; font-size: 14px; color: var(--fs-gray-2); max-width: 260px; line-height: 1.5; }
.fs-drawer__foot { border-top: 1px solid var(--fs-line); padding: 18px 22px; background: #fff; flex: none; }
.fs-drawer__promo { display: flex; align-items: stretch; gap: 8px; margin-bottom: 16px; }
.fs-drawer__promo-input { flex: 1; min-width: 0; border: 1px solid var(--fs-line); border-radius: 6px; padding: 0 14px; height: 42px; font-size: 13.5px; color: var(--fs-ink-2); outline: none; }
.fs-drawer__promo-input:focus { border-color: var(--fs-ink); }
.fs-drawer__promo-apply { background: var(--fs-surface); border: 1px solid var(--fs-line); border-radius: 6px; padding: 0 18px; font-family: var(--fs-display); font-weight: 700; font-size: 12px; letter-spacing: .04em; text-transform: uppercase; color: var(--fs-ink-3); cursor: pointer; transition: background .15s, color .15s; }
.fs-drawer__promo-apply:hover { background: var(--fs-ink); color: #fff; }
.fs-drawer__promo-msg { font-size: 12px; color: var(--fs-gray-1); margin: -8px 0 14px; }
.fs-drawer__coupons { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.fs-drawer__coupon { display: inline-flex; align-items: center; gap: 7px; background: var(--fs-surface); border: 1px solid var(--fs-line); border-radius: 6px; padding: 6px 8px 6px 10px; font-size: 12px; font-weight: 600; color: var(--fs-ink-2); }
.fs-drawer__coupon svg { color: var(--fs-amber-ink); }
.fs-drawer__coupon-x { display: inline-flex; background: none; border: none; cursor: pointer; color: var(--fs-gray-3); padding: 2px; border-radius: 4px; }
.fs-drawer__coupon-x:hover { color: var(--fs-red); background: #FEF2F2; }
.fs-drawer__rows { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.fs-drawer__row { display: flex; align-items: center; justify-content: space-between; font-size: 14px; color: var(--fs-gray-1); }
.fs-drawer__row strong, .fs-drawer__row span:last-child { font-weight: 600; color: var(--fs-ink-2); }
.fs-drawer__row--save { color: var(--fs-green); }
.fs-drawer__total { display: flex; align-items: baseline; justify-content: space-between; padding-top: 14px; border-top: 1px solid var(--fs-line); margin-bottom: 16px; }
.fs-drawer__total dt { font-family: var(--fs-display); font-weight: 700; font-size: 15px; color: var(--fs-ink); margin: 0; }
.fs-drawer__total dd { margin: 0; font-family: var(--fs-display); font-weight: 900; font-size: 26px; color: var(--fs-ink); }
.fs-drawer__assure { display: flex; align-items: center; justify-content: center; gap: 16px; margin-top: 6px; }
.fs-drawer__assure span { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--fs-gray-3); }
.fs-drawer__cont { width: 100%; background: none; border: none; cursor: pointer; color: var(--fs-gray-2); font-size: 13px; font-weight: 600; padding: 14px 0 4px; }
.fs-drawer__cont:hover { color: var(--fs-ink); }

/* =========================================================================
   PLP (shop / archive)
   ========================================================================= */
.fs-shop .fs-container { padding-top: 26px; padding-bottom: 84px; }
.fs-crumb { display: flex; align-items: center; gap: 8px; font-size: 13px; margin-bottom: 18px; flex-wrap: wrap; }
.fs-crumb a { color: var(--fs-gray-2); text-decoration: none; }
.fs-crumb a:hover { color: var(--fs-ink); }
.fs-crumb__sep { color: var(--fs-gray-4); }
.fs-crumb__current { color: var(--fs-ink); font-weight: 600; }
.fs-plp-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 26px; flex-wrap: wrap; }
.fs-plp-head h1 { margin: 0 0 6px; font-family: var(--fs-display); font-weight: 800; font-size: 34px; letter-spacing: -.02em; color: var(--fs-ink); }
.fs-plp-head__count { font-size: 13.5px; color: var(--fs-gray-2); }
.fs-plp-sort { display: flex; align-items: center; gap: 10px; }
.fs-plp-sort > span { font-size: 13px; color: var(--fs-gray-2); }
.fs-plp-sort .woocommerce-ordering, .fs-plp-sort form { margin: 0; position: relative; }
.fs-plp-sort select { appearance: none; border: 1px solid var(--fs-d4); background: #fff; border-radius: 7px; padding: 11px 38px 11px 14px; font-size: 13.5px; font-weight: 600; color: var(--fs-ink); cursor: pointer; outline: none; }
.fs-shoplayout { display: grid; grid-template-columns: 250px 1fr; gap: 30px; align-items: start; }
.fs-filters { display: flex; flex-direction: column; gap: 22px; border: 1px solid var(--fs-line); border-radius: 12px; padding: 22px; position: sticky; top: 120px; }
.fs-filters__title { font-family: var(--fs-display); font-weight: 800; font-size: 11.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--fs-ink); margin-bottom: 12px; }
.fs-filters__list { display: flex; flex-direction: column; gap: 1px; }
.fs-filters__list a { display: flex; align-items: center; justify-content: space-between; font-size: 13.5px; color: var(--fs-gray-1); text-decoration: none; padding: 7px 9px; border-radius: 6px; }
.fs-filters__list a:hover, .fs-filters__list a.is-active { background: var(--fs-surface); color: var(--fs-ink); }
.fs-filters__list a span { font-size: 11px; color: var(--fs-gray-4); }
.fs-filters__rule { height: 1px; background: var(--fs-line-3); }
.fs-filters__check { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--fs-ink-3); margin-top: 10px; }
.fs-filters__check:first-of-type { margin-top: 0; }
.fs-filters__box { width: 18px; height: 18px; border-radius: 4px; border: 1.5px solid var(--fs-d4); display: flex; align-items: center; justify-content: center; }
.fs-filters__box.is-on { background: var(--fs-amber); border-color: var(--fs-amber); color: var(--fs-ink); }
ul.products, .fs-grid { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(240px,1fr)); gap: 16px; }
ul.products li.product { margin: 0; width: auto; }
/* Override WooCommerce's default float grid (its .woocommerce-prefixed rules
   outrank ours on specificity, which squished the cards into narrow columns). */
.woocommerce ul.products,
.woocommerce-page ul.products {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 16px;
	margin: 0;
}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	width: auto !important;
	float: none !important;
	margin: 0 !important;
	clear: none !important;
}
.woocommerce ul.products li.product a img { width: 100%; }
.woocommerce ul.products::before,
.woocommerce ul.products::after { content: none !important; }
.fs-pager { display: flex; align-items: center; justify-content: center; gap: 6px; margin-top: 40px; }
.fs-pager a, .fs-pager span { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; border: 1px solid var(--fs-line); background: #fff; border-radius: 8px; color: var(--fs-gray-1); font-family: var(--fs-display); font-weight: 700; text-decoration: none; }
.fs-pager .current { background: var(--fs-ink); border-color: var(--fs-ink); color: #fff; }
.fs-pager a:hover { border-color: var(--fs-ink); color: var(--fs-ink); }
.woocommerce-pagination ul { display: flex; gap: 6px; list-style: none; margin: 40px 0 0; padding: 0; justify-content: center; }
.woocommerce-pagination ul li { margin: 0; }
.woocommerce-pagination a, .woocommerce-pagination span { display: flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 8px; border: 1px solid var(--fs-line); background: #fff; border-radius: 8px; color: var(--fs-gray-1); font-family: var(--fs-display); font-weight: 700; text-decoration: none; }
.woocommerce-pagination .current { background: var(--fs-ink); border-color: var(--fs-ink); color: #fff; }

.fs-empty { border: 1px dashed var(--fs-d4); border-radius: 12px; padding: 80px 20px; text-align: center; }
.fs-empty__title { font-family: var(--fs-display); font-weight: 800; font-size: 20px; color: var(--fs-ink); margin-bottom: 8px; }
.fs-empty p { margin: 0 0 22px; color: var(--fs-gray-2); font-size: 14px; }

/* =========================================================================
   PDP (single product)
   ========================================================================= */
.fs-pdp__top { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; margin-bottom: 64px; }
.fs-pdp__gallery { position: sticky; top: 120px; }
.fs-pdp__main-img { position: relative; border: 1px solid var(--fs-line); border-radius: 14px; background: var(--fs-surface-3); min-height: 460px; display: flex; align-items: center; justify-content: center; color: var(--fs-ink-3); overflow: hidden; }
.fs-pdp__main-img .fs-prodmedia__icon { transform: scale(1); }
.fs-pdp__main-img img { max-width: 90%; height: auto; }
.fs-pdp__badge { position: absolute; top: 18px; left: 18px; background: var(--fs-amber); color: var(--fs-ink); font-family: var(--fs-display); font-weight: 800; font-size: 11px; letter-spacing: .05em; text-transform: uppercase; padding: 6px 10px; border-radius: 4px; z-index: 2; }
.fs-pdp__brand { font-family: var(--fs-display); font-weight: 700; font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: var(--fs-amber-ink); margin-bottom: 8px; }
.fs-pdp__title { margin: 0; font-family: var(--fs-display); font-weight: 800; font-size: 32px; line-height: 1.12; letter-spacing: -.02em; color: var(--fs-ink); }
.fs-pdp__meta { display: flex; align-items: center; gap: 12px; margin: 14px 0 20px; font-size: 13px; color: var(--fs-gray-2); flex-wrap: wrap; }
.fs-pdp__meta .fs-instock { display: inline-flex; align-items: center; gap: 5px; color: var(--fs-green); font-weight: 600; }
.fs-pdp__price { display: flex; align-items: baseline; gap: 12px; margin-bottom: 20px; }
.fs-pdp__price .price, .fs-pdp__price ins { text-decoration: none; }
.fs-pdp__price ins .amount, .fs-pdp__price > .price > .amount, .fs-pdp__price .woocommerce-Price-amount { font-family: var(--fs-display); font-weight: 900; font-size: 38px; color: var(--fs-ink); }
.fs-pdp__price del .amount { font-family: var(--fs-body); font-weight: 400; font-size: 18px; color: var(--fs-gray-3); }
.fs-pdp__desc { margin: 0 0 22px; font-size: 15px; line-height: 1.65; color: var(--fs-gray-1); max-width: 520px; }
.fs-pdp__specs { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 28px; max-width: 460px; margin-bottom: 26px; }
.fs-pdp__spec { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 7px 0; border-bottom: 1px solid var(--fs-line-2); font-size: 13px; }
.fs-pdp__spec dt { color: var(--fs-gray-3); margin: 0; }
.fs-pdp__spec dd { color: var(--fs-ink-2); font-weight: 600; text-align: right; margin: 0; }
.fs-pdp__cart { display: flex; align-items: stretch; gap: 12px; margin-bottom: 12px; }
.fs-pdp__cart .quantity { display: flex; align-items: center; border: 1px solid var(--fs-d4); border-radius: 8px; overflow: hidden; }
.fs-pdp__cart .quantity input.qty { width: 56px; height: 52px; text-align: center; border: none; background: var(--fs-surface-2); font-family: var(--fs-display); font-weight: 800; font-size: 17px; color: var(--fs-ink); -moz-appearance: textfield; }
.fs-pdp__cart .quantity input.qty::-webkit-outer-spin-button, .fs-pdp__cart .quantity input.qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.fs-pdp__addbtn { flex: 1; display: flex; align-items: center; justify-content: center; gap: 9px; background: var(--fs-ink); color: #fff; border: none; border-radius: 8px; padding: 0 24px; height: 52px; font-family: var(--fs-display); font-weight: 800; font-size: 14px; letter-spacing: .03em; text-transform: uppercase; cursor: pointer; }
.fs-pdp__addbtn:hover { background: var(--fs-ink-3); }
.fs-pdp__wish { width: 52px; height: 52px; border: 1px solid var(--fs-d4); background: #fff; border-radius: 8px; display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--fs-ink); flex: none; }
.fs-pdp__wish:hover { border-color: var(--fs-ink); }
.fs-pdp__wish.is-active { color: var(--fs-amber); }
.fs-pdp__assure { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 24px; }
.fs-pdp__assure-item { display: flex; align-items: center; gap: 11px; border: 1px solid var(--fs-line); border-radius: 9px; padding: 13px 15px; }
.fs-pdp__assure-item svg { color: var(--fs-ink); }
.fs-pdp__assure-item span { font-size: 12.5px; color: var(--fs-ink-4); }
.fs-pdp__tabs { border-bottom: 1px solid var(--fs-line); display: flex; gap: 28px; margin-bottom: 28px; }
.fs-pdp__tab { background: none; border: none; border-bottom: 2px solid transparent; color: var(--fs-gray-2); padding: 0 2px 14px; margin-bottom: -1px; cursor: pointer; font-family: var(--fs-display); font-weight: 700; font-size: 14px; }
.fs-pdp__tab.is-active { color: var(--fs-ink); border-bottom-color: var(--fs-amber); }
.fs-pdp__panel { max-width: 820px; color: var(--fs-ink-4); font-size: 15px; line-height: 1.75; }
.fs-pdp__panel[hidden] { display: none; }
.fs-pdp__panel ul { margin: 0; padding-left: 20px; display: flex; flex-direction: column; gap: 8px; }
.fs-pdp__spectable { max-width: 620px; border: 1px solid var(--fs-line); border-radius: 10px; overflow: hidden; }
.fs-pdp__spectable .fs-pdp__spec { padding: 14px 18px; border-bottom: 1px solid var(--fs-line-2); }
.fs-related h2 { margin: 0; font-family: var(--fs-display); font-weight: 800; font-size: 28px; letter-spacing: -.02em; color: var(--fs-ink); }

/* =========================================================================
   WOOCOMMERCE: cart, checkout, account, notices
   ========================================================================= */
.woocommerce-notices-wrapper:empty { display: none; }
.woocommerce-message, .woocommerce-info, .woocommerce-error { list-style: none; border: 1px solid var(--fs-line); border-left: 4px solid var(--fs-amber); background: var(--fs-surface-2); padding: 14px 18px; border-radius: 8px; margin: 0 0 18px; font-size: 14px; }
.woocommerce-error { border-left-color: var(--fs-red); }
.woocommerce-message .button, .woocommerce-info .button { float: right; }

.fs-page { max-width: var(--fs-max); margin: 0 auto; padding: 30px 24px 84px; }
.fs-page--narrow { max-width: 820px; }
.fs-page__title { margin: 0 0 26px; font-family: var(--fs-display); font-weight: 800; font-size: 34px; letter-spacing: -.02em; color: var(--fs-ink); }

.woocommerce-cart .fs-page table.cart, .woocommerce-cart table.shop_table { width: 100%; border-collapse: collapse; border: 1px solid var(--fs-line); border-radius: 12px; overflow: hidden; }
.woocommerce table.shop_table th { background: var(--fs-surface-2); font-family: var(--fs-display); font-weight: 700; font-size: 11px; letter-spacing: .06em; text-transform: uppercase; color: var(--fs-gray-3); padding: 14px 18px; text-align: left; }
.woocommerce table.shop_table td { padding: 18px; border-top: 1px solid var(--fs-line-2); vertical-align: middle; font-size: 14px; }
.woocommerce table.cart img { width: 64px; border-radius: 8px; border: 1px solid #EDEDEF; background: var(--fs-surface-3); }
.woocommerce a.remove { color: var(--fs-gray-3) !important; font-weight: 700; }
.woocommerce a.remove:hover { color: var(--fs-red) !important; background: transparent !important; }
.woocommerce .quantity input.qty { width: 64px; height: 40px; text-align: center; border: 1px solid var(--fs-line); border-radius: 7px; }
.woocommerce .cart-collaterals, .woocommerce-cart-form { margin: 0; }
.cart_totals, .woocommerce-checkout #order_review, .woocommerce .cart_totals { border: 1px solid var(--fs-line); border-radius: 12px; padding: 24px; }
.cart_totals h2, #order_review_heading { font-family: var(--fs-display); font-weight: 800; font-size: 17px; color: var(--fs-ink); margin: 0 0 16px; }
.woocommerce .cart_totals table { width: 100%; }
.woocommerce .cart_totals table th, .woocommerce .cart_totals table td { padding: 10px 0; border: none; font-size: 14px; }
.order-total .amount, .cart-subtotal .amount { font-family: var(--fs-display); font-weight: 800; color: var(--fs-ink); }
.woocommerce #payment, .woocommerce-checkout #payment { background: transparent; border-radius: 12px; }
.woocommerce form .form-row label { font-size: 12.5px; font-weight: 600; color: var(--fs-gray-1); margin-bottom: 6px; display: block; }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce form .form-row select, .select2-container .select2-selection { border: 1px solid var(--fs-d4); border-radius: 7px; padding: 12px 14px; font-size: 14px; }
.woocommerce form .form-row input.input-text:focus, .woocommerce form .form-row textarea:focus { border-color: var(--fs-ink); outline: none; }
.woocommerce #respond input#submit, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button, .woocommerce #place_order, .woocommerce .button.alt {
	background: var(--fs-ink); color: #fff; border: none; border-radius: 7px; padding: 14px 22px;
	font-family: var(--fs-display); font-weight: 800; font-size: 13px; letter-spacing: .04em; text-transform: uppercase; cursor: pointer; transition: .15s;
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover, .woocommerce #place_order:hover, .woocommerce .button.alt:hover { background: var(--fs-amber); color: var(--fs-ink); }
.woocommerce .button.alt, .woocommerce #place_order { background: var(--fs-amber); color: var(--fs-ink); }
.woocommerce .button.alt:hover, .woocommerce #place_order:hover { background: var(--fs-ink); color: var(--fs-amber); }
.woocommerce-checkout .col2-set, .woocommerce .col2-set { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.woocommerce form.checkout { display: grid; grid-template-columns: 1fr 384px; gap: 32px; align-items: start; }
.woocommerce form.checkout .col2-set { grid-template-columns: 1fr; }
.woocommerce form.checkout #customer_details { grid-column: 1; }
.woocommerce form.checkout #order_review_heading, .woocommerce form.checkout #order_review { grid-column: 2; position: sticky; top: 120px; }
.woocommerce-checkout #payment ul.payment_methods { border: none; padding: 0; }
.woocommerce ul.order_details { display: flex; flex-wrap: wrap; gap: 24px; list-style: none; padding: 22px; margin: 0 0 24px; border: 1px solid var(--fs-line); border-radius: 12px; background: var(--fs-surface-2); }
.woocommerce ul.order_details li { font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--fs-gray-2); border: none; }
.woocommerce ul.order_details li strong { display: block; font-family: var(--fs-display); font-size: 15px; color: var(--fs-ink); text-transform: none; letter-spacing: 0; margin-top: 4px; }
.fs-thankyou { text-align: center; padding-top: 20px; }
.fs-thankyou__check { width: 84px; height: 84px; border-radius: 50%; background: var(--fs-green); color: #fff; display: flex; align-items: center; justify-content: center; margin: 0 auto 26px; font-size: 40px; font-weight: 700; }
.fs-thankyou h1 { margin: 0 0 12px; font-family: var(--fs-display); font-weight: 900; font-size: 38px; letter-spacing: -.02em; color: var(--fs-ink); }

/* ---- custom cart page (classic [woocommerce_cart] shortcode) ---- */
.fs-cart-title { margin: 0 0 26px; font-family: var(--fs-display); font-weight: 800; font-size: 34px; letter-spacing: -.02em; color: var(--fs-ink); }
.fs-cart-title span { color: var(--fs-gray-3); font-weight: 700; font-size: 22px; }
.fs-cart-grid { display: grid; grid-template-columns: 1fr 384px; gap: 32px; align-items: start; margin: 0; }
.fs-cart-table { border: 1px solid var(--fs-line); border-radius: 12px; overflow: hidden; }
.fs-cart-head { display: grid; grid-template-columns: 1fr 150px 120px; gap: 12px; padding: 14px 22px; background: var(--fs-surface-2); border-bottom: 1px solid var(--fs-line); font-family: var(--fs-display); font-weight: 700; font-size: 11px; letter-spacing: .06em; text-transform: uppercase; color: var(--fs-gray-3); }
.fs-cart-row { display: grid; grid-template-columns: 1fr 150px 120px; gap: 12px; align-items: center; padding: 18px 22px; border-bottom: 1px solid var(--fs-line-2); }
.fs-cart-prod { display: flex; align-items: center; gap: 14px; min-width: 0; }
.fs-cart-thumb { width: 72px; height: 72px; flex: none; background: var(--fs-surface-3); border: 1px solid #EDEDEF; border-radius: 8px; display: flex; align-items: center; justify-content: center; color: var(--fs-ink-4); overflow: hidden; }
.fs-cart-thumb img { max-width: 100%; height: auto; }
.fs-cart-prod__main { min-width: 0; }
.fs-cart-brand { font-family: var(--fs-display); font-weight: 700; font-size: 9.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--fs-amber-ink); }
.fs-cart-name { display: block; font-size: 14px; font-weight: 600; color: var(--fs-ink-2); line-height: 1.3; margin: 2px 0 6px; text-decoration: none; }
.fs-cart-name:hover { color: var(--fs-amber-ink); }
.fs-cart-remove { display: inline-flex; align-items: center; gap: 5px; background: none; border: none; cursor: pointer; color: var(--fs-gray-3); font-size: 12px; text-decoration: none; padding: 0; }
.fs-cart-remove:hover { color: var(--fs-red); }
.fs-cart-qty { display: flex; justify-content: center; }
.fs-cart-qty .fs-qtybox button { width: 34px; height: 36px; }
.fs-qty-input { width: 44px; height: 36px; text-align: center; border: none; background: #fff; font-family: var(--fs-display); font-weight: 700; font-size: 14px; color: var(--fs-ink); -moz-appearance: textfield; outline: none; }
.fs-qty-input::-webkit-outer-spin-button, .fs-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.fs-cart-line { text-align: right; }
.fs-cart-line__total { font-family: var(--fs-display); font-weight: 800; font-size: 17px; color: var(--fs-ink); }
.fs-cart-line__each { font-size: 11.5px; color: var(--fs-gray-3); }
.fs-cart-cont-row { padding: 16px 22px; }
.fs-cart-cont { display: inline-flex; align-items: center; gap: 7px; background: none; border: none; cursor: pointer; color: var(--fs-ink); font-family: var(--fs-display); font-weight: 700; font-size: 12.5px; letter-spacing: .04em; text-transform: uppercase; text-decoration: none; }
.fs-cart-cont:hover { color: var(--fs-amber-ink); }
.fs-cart-summary { position: sticky; top: 120px; }
.fs-summary-card { border: 1px solid var(--fs-line); border-radius: 12px; padding: 24px; }
.fs-summary-title { margin: 0 0 18px; font-family: var(--fs-display); font-weight: 800; font-size: 17px; color: var(--fs-ink); }
.fs-summary-promo { display: flex; align-items: stretch; gap: 8px; margin-bottom: 18px; }
.fs-summary-promo__input { flex: 1; min-width: 0; border: 1px solid var(--fs-line); border-radius: 7px; padding: 0 14px; height: 44px; font-size: 13.5px; color: var(--fs-ink-2); outline: none; }
.fs-summary-promo__input:focus { border-color: var(--fs-ink); }
.fs-summary-promo__apply { background: var(--fs-surface); border: 1px solid var(--fs-line); border-radius: 7px; padding: 0 18px; font-family: var(--fs-display); font-weight: 700; font-size: 12px; letter-spacing: .04em; text-transform: uppercase; color: var(--fs-ink-3); cursor: pointer; }
.fs-summary-promo__apply:hover { background: var(--fs-ink); color: #fff; }
.fs-summary-rows { display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px; font-size: 14px; }
.fs-summary-row { display: flex; align-items: center; justify-content: space-between; color: var(--fs-gray-1); }
.fs-summary-row > span:last-child { font-weight: 600; color: var(--fs-ink-2); }
.fs-summary-row--save, .fs-summary-row--save > span:last-child { color: var(--fs-green); }
.fs-summary-row--save a { color: var(--fs-gray-3); margin-left: 6px; text-decoration: none; }
.fs-summary-row--save a:hover { color: var(--fs-red); }
.fs-summary-total { display: flex; align-items: baseline; justify-content: space-between; padding-top: 16px; border-top: 1px solid var(--fs-line); margin-bottom: 18px; }
.fs-summary-total > span:first-child { font-family: var(--fs-display); font-weight: 700; font-size: 15px; color: var(--fs-ink); }
.fs-summary-total > span:last-child, .fs-summary-total > span:last-child .woocommerce-Price-amount { font-family: var(--fs-display); font-weight: 900; font-size: 26px; color: var(--fs-ink); }
.fs-summary-checkout { margin-bottom: 16px; }
.fs-summary-assure { display: flex; align-items: center; justify-content: center; gap: 16px; }
.fs-summary-assure span { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--fs-gray-3); }
.fs-cart-empty { border: 1px solid var(--fs-line); border-radius: 12px; padding: 90px 20px; text-align: center; }
.fs-cart-empty__ico { width: 84px; height: 84px; border-radius: 50%; background: var(--fs-surface); display: inline-flex; align-items: center; justify-content: center; color: var(--fs-gray-4); margin-bottom: 22px; }
.fs-cart-empty__title { font-family: var(--fs-display); font-weight: 800; font-size: 22px; color: var(--fs-ink); margin-bottom: 8px; }
.fs-cart-empty__text { margin: 0 0 24px; color: var(--fs-gray-2); font-size: 14.5px; }
@media (max-width: 980px) {
	.fs-cart-grid { grid-template-columns: 1fr; }
	.fs-cart-summary { position: static; }
}

/* ---- custom checkout page (classic [woocommerce_checkout] shortcode) ---- */
.fs-co-steps { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin: 0 0 30px; padding: 0; list-style: none; font-family: var(--fs-display); font-weight: 700; font-size: 12.5px; letter-spacing: .04em; text-transform: uppercase; }
.fs-co-step { display: inline-flex; align-items: center; gap: 7px; color: var(--fs-gray-4); }
.fs-co-step::after { content: "———"; margin-left: 10px; color: var(--fs-line); letter-spacing: -1px; }
.fs-co-step:last-child::after { content: none; }
.fs-co-step.is-done { color: var(--fs-green); }
.fs-co-step.is-current { color: var(--fs-ink); }
.fs-co-main { min-width: 0; }
.fs-co-main .woocommerce-billing-fields,
.fs-co-main .woocommerce-shipping-fields,
.fs-co-main .woocommerce-account-fields,
.fs-co-main .woocommerce-additional-fields { border: 1px solid var(--fs-line); border-radius: 12px; padding: 24px; margin-bottom: 18px; background: #fff; }
.fs-co-main .woocommerce-billing-fields > h3,
.fs-co-main .woocommerce-shipping-fields > h3,
.fs-co-main .woocommerce-additional-fields > h3,
.fs-co-main #ship-to-different-address { margin: 0 0 16px; font-family: var(--fs-display); font-weight: 800; font-size: 16px; color: var(--fs-ink); }
.fs-co-main .form-row { margin: 0 0 14px; padding: 0; }
.fs-co-main .form-row:last-child { margin-bottom: 0; }
.fs-co-side { position: sticky; top: 120px; border: 1px solid var(--fs-line); border-radius: 12px; padding: 24px; }
.fs-co-side__title { margin: 0 0 16px; font-family: var(--fs-display); font-weight: 800; font-size: 16px; color: var(--fs-ink); }
.fs-co-side #order_review { border: none; border-radius: 0; padding: 0; position: static; grid-column: auto; }
.fs-co-side #order_review_heading { position: static; grid-column: auto; }
.fs-co-side #place_order { width: 100%; margin-top: 4px; }
.fs-co-side .woocommerce-checkout-review-order-table { width: 100%; margin-bottom: 18px; }
.fs-co-side .woocommerce-checkout-review-order-table th,
.fs-co-side .woocommerce-checkout-review-order-table td { padding: 10px 0; border: none; font-size: 14px; }
.fs-co-side .order-total .woocommerce-Price-amount { font-family: var(--fs-display); font-weight: 900; font-size: 22px; color: var(--fs-ink); }
/* Match the prototype's compact 1120px container. */
.fs-checkout { max-width: 1120px; }
/* WooCommerce's core stylesheet floats .col-1/.col-2 at ~48% width, which left
   the billing card filling only half its column (a big empty gap). Make the
   billing/shipping blocks fill the whole left column instead. */
.fs-co-main #customer_details { display: block; }
.fs-co-main #customer_details .col-1,
.fs-co-main #customer_details .col-2 { width: 100%; max-width: none; float: none; }
/* Don't render a bordered card for an empty field wrapper (e.g. shipping fields
   when the store has no separate shipping-address step). */
.fs-co-main .woocommerce-shipping-fields:not(:has(*)),
.fs-co-main .woocommerce-account-fields:not(:has(*)),
.fs-co-main .woocommerce-additional-fields:not(:has(*)) { display: none; }

/* PDP add-to-cart form (placed after the generic Woo button rules so the dark
   add button wins over .button.alt). */
.fs-pdp__cart form.cart { display: flex; align-items: stretch; gap: 12px; flex: 1; margin: 0; }
.fs-pdp__cart .single_add_to_cart_button.button { flex: 1; display: flex; align-items: center; justify-content: center; gap: 9px; background: var(--fs-ink); color: #fff; border-radius: 8px; padding: 0 24px; height: 52px; font-family: var(--fs-display); font-weight: 800; font-size: 14px; letter-spacing: .03em; text-transform: uppercase; }
.fs-pdp__cart .single_add_to_cart_button.button:hover { background: var(--fs-ink-3); color: #fff; }
.fs-pdp__cart .quantity { flex: none; }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 1100px) {
	.fs-hero__inner { grid-template-columns: 1fr; }
	.fs-spotlight__inner { grid-template-columns: 1fr; }
	.fs-spotlight__copy { padding: 56px 0; }
	.fs-spotlight__media { min-height: 320px; }
	.fs-b2b { grid-template-columns: 1fr; }
	.fs-pdp__top { grid-template-columns: 1fr; }
	.fs-pdp__gallery { position: static; }
	.woocommerce form.checkout { grid-template-columns: 1fr; }
	.woocommerce form.checkout #order_review_heading, .woocommerce form.checkout #order_review { grid-column: 1; position: static; }
	.fs-trust__inner { grid-template-columns: repeat(2, 1fr); }
	.fs-trust__item:nth-child(odd) { border-right: 1px solid var(--fs-ink-2); }
}
@media (max-width: 980px) {
	.fs-topbar { display: none; }
	.fs-bar { flex-wrap: wrap; height: auto; padding: 14px 24px; gap: 14px; }
	.fs-search { order: 3; flex-basis: 100%; }
	.fs-shoplayout { grid-template-columns: 1fr; }
	.fs-filters { position: static; }
	.fs-footer__top { grid-template-columns: 1fr 1fr; }
	.fs-hero__title { font-size: 44px; }
}
@media (max-width: 760px) {
	.fs-navbar__inner { overflow-x: auto; }
	.fs-nav { flex-wrap: nowrap; }
	.fs-mega { width: 100%; grid-template-columns: 1fr; }
	.fs-mega__rail { display: none; }
	.fs-mega__panel { grid-template-columns: 1fr; }
	.fs-trust__inner { grid-template-columns: 1fr; }
	.fs-trust__item { border-right: none !important; border-bottom: 1px solid var(--fs-ink-2); }
	.fs-news__inner { flex-direction: column; align-items: flex-start; }
	.fs-news__form { min-width: 0; width: 100%; }
	.fs-footer__top { grid-template-columns: 1fr; }
	.fs-section { padding: 48px 24px; }
	.fs-hero__title { font-size: 38px; }
	.fs-iconbtn__label { display: none; }
}

/* =========================================================================
   MOBILE E-COMMERCE UX  (hamburger nav, bottom bar, 2-up grid, filters)
   ========================================================================= */
.fs-burger, .fs-mobnav, .fs-mobnav-overlay, .fs-botnav, .fs-filterbtn { display: none; }
.fs-burger { width: 42px; height: 42px; border: none; background: transparent; cursor: pointer; flex-direction: column; justify-content: center; align-items: center; gap: 5px; padding: 0; flex: none; }
.fs-burger span { display: block; width: 22px; height: 2px; background: var(--fs-ink); border-radius: 2px; transition: .2s; }

/* slide-in navigation drawer */
.fs-mobnav-overlay { position: fixed; inset: 0; background: rgba(11,11,12,.5); z-index: 110; opacity: 0; visibility: hidden; transition: opacity .25s ease, visibility .25s ease; }
.fs-mobnav { position: fixed; top: 0; left: 0; height: 100%; width: 320px; max-width: 86vw; background: #fff; z-index: 120; transform: translateX(-100%); transition: transform .3s cubic-bezier(.4,0,.2,1); flex-direction: column; box-shadow: 24px 0 60px rgba(0,0,0,.28); }
body.fs-mobnav-open { overflow: hidden; }
body.fs-mobnav-open .fs-mobnav-overlay { opacity: 1; visibility: visible; }
body.fs-mobnav-open .fs-mobnav { transform: translateX(0); }
.fs-mobnav__head { display: flex; align-items: center; justify-content: space-between; padding: 16px 18px; background: var(--fs-ink); color: #fff; flex: none; }
.fs-mobnav__title { font-family: var(--fs-display); font-weight: 800; font-size: 16px; }
.fs-mobnav__close { background: var(--fs-ink-2); border: none; color: #fff; width: 36px; height: 36px; border-radius: 8px; display: flex; align-items: center; justify-content: center; cursor: pointer; }
.fs-mobnav__body { flex: 1; overflow-y: auto; -webkit-overflow-scrolling: touch; padding-bottom: 24px; }
.fs-mobnav__cta { display: flex; align-items: center; justify-content: center; gap: 8px; margin: 14px 16px; padding: 13px; background: var(--fs-amber); color: var(--fs-ink); border-radius: 8px; font-family: var(--fs-display); font-weight: 800; text-decoration: none; }
.fs-mobnav__heading { font-family: var(--fs-display); font-weight: 700; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--fs-gray-3); padding: 14px 18px 6px; }
.fs-mobnav__link { display: flex; align-items: center; gap: 9px; padding: 13px 18px; color: var(--fs-ink-2); text-decoration: none; font-size: 15px; font-weight: 500; border-bottom: 1px solid var(--fs-line-2); }
.fs-mobnav__link svg { color: var(--fs-gray-3); flex: none; }
.fs-mobnav__link:active, .fs-mobnav__link:hover { background: var(--fs-surface-2); color: var(--fs-amber-ink); }
.fs-mobnav__bulk { display: flex; align-items: center; justify-content: center; gap: 8px; margin: 16px; padding: 13px; border: 1.5px solid var(--fs-ink); border-radius: 8px; color: var(--fs-ink); text-decoration: none; font-family: var(--fs-display); font-weight: 700; }

/* sticky bottom navigation bar */
.fs-botnav { position: fixed; bottom: 0; left: 0; right: 0; z-index: 80; background: #fff; border-top: 1px solid var(--fs-line); box-shadow: 0 -2px 14px rgba(0,0,0,.07); padding-bottom: env(safe-area-inset-bottom); }
.fs-botnav__item { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 3px; padding: 8px 0 7px; font-size: 10px; font-weight: 600; color: var(--fs-gray-2); text-decoration: none; background: none; border: none; cursor: pointer; min-height: 54px; }
.fs-botnav__item.is-active { color: var(--fs-ink); }
.fs-botnav__item svg { color: currentColor; }
.fs-botnav__ico { position: relative; display: flex; }
.fs-botnav__ico .fs-bubble { right: -9px; }

/* shop filters as a slide-in drawer on small screens */
.fs-filterbtn { align-items: center; gap: 8px; background: var(--fs-ink); color: #fff; border: none; border-radius: 8px; padding: 11px 18px; font-family: var(--fs-display); font-weight: 700; font-size: 13px; letter-spacing: .03em; cursor: pointer; }
.fs-filterbtn svg { color: var(--fs-amber); }

@media (max-width: 980px) {
	.fs-burger { display: flex; }
	.fs-mobnav { display: flex; }
	.fs-mobnav-overlay { display: block; }
	.fs-navbar { display: none; }            /* nav lives in the drawer now */
	.fs-bar { flex-wrap: wrap; align-items: center; gap: 12px; padding: 12px 16px; }
	.fs-logo { order: 1; flex: 1; }
	.fs-burger { order: 0; }
	.fs-actions { order: 2; gap: 8px; }
	.fs-search { order: 3; flex-basis: 100%; }
	.fs-logo__tag { display: none; }
	.fs-cartbtn__meta { display: none; }     /* icon-only cart on mobile */
	.fs-cartbtn { padding: 6px; }
	/* filters become an off-canvas drawer */
	.fs-filterbtn { display: inline-flex; }
	.fs-filters { position: fixed; top: 0; left: 0; height: 100%; width: 320px; max-width: 86vw; background: #fff; z-index: 120; transform: translateX(-100%); transition: transform .3s cubic-bezier(.4,0,.2,1); overflow-y: auto; -webkit-overflow-scrolling: touch; padding: 20px 18px 40px; box-shadow: 24px 0 60px rgba(0,0,0,.28); margin: 0; }
	body.fs-filters-open { overflow: hidden; }
	body.fs-filters-open .fs-filters { transform: translateX(0); }
	body.fs-filters-open .fs-mobnav-overlay { opacity: 1; visibility: visible; }
}

@media (max-width: 768px) {
	.fs-botnav { display: flex; }
	body { padding-bottom: 60px; }           /* clear the bottom bar */
}

@media (max-width: 600px) {
	/* the requested 2-up product grid */
	ul.products, .fs-grid, .fs-cats, .fs-brands { grid-template-columns: repeat(2, 1fr) !important; gap: 10px; }
	.fs-card { min-height: 0; }
	.fs-card__media { height: 132px; }
	.fs-prodmedia__img { max-height: 104px; }
	.fs-prodmedia__icon { transform: scale(1.1); }
	.fs-card__body { padding: 10px 10px 0; gap: 4px; }
	.fs-card__name { font-size: 13px; min-height: 34px; }
	.fs-card__sku { display: none; }
	.fs-card__price ins, .fs-card__price > .amount { font-size: 17px; }
	.fs-card__foot { padding: 10px; }
	.fs-card__add { padding: 11px 6px; font-size: 10.5px; letter-spacing: .02em; }
	.fs-card__wish { width: 30px; height: 30px; top: 8px; right: 8px; }
	.fs-card__badge { font-size: 9px; padding: 4px 6px; }
	.fs-cats__icon, .fs-cat__icon { transform: none; }
	.fs-plp-head h1, .fs-page__title, .fs-cart-title, .fs-sechead__title { font-size: 26px; }
	.fs-hero__title { font-size: 30px; }
	.fs-section { padding: 40px 16px; }
	.fs-plp-head { align-items: center; }
}
