/* ============================================================================
   Quat — main stylesheet
   Pixel-match mot livesajten. Dark, minimalist, mobile-first.
   ========================================================================== */

/* ----------------------------------------------------------------------------
   1. Tokens
   -------------------------------------------------------------------------- */
:root {
	--quat-bg:       #000000;
	--quat-fg:       #FFFFFF;
	--quat-accent:   #FFD600;
	--quat-muted:    #A1A1AA;
	--quat-card:     #0B0B0B;
	--quat-card-2:   #131316;
	--quat-card-3:   #1A1A1D;
	--quat-border:   rgba(255, 255, 255, 0.08);
	--quat-border-2: rgba(255, 255, 255, 0.12);
	--quat-success:  #4ADE80;

	--quat-radius:   12px;
	--quat-radius-lg: 18px;

	--quat-shadow-accent: 0 4px 20px rgba(255, 214, 0, 0.25);
	--quat-shadow-soft:   0 2px 8px rgba(0, 0, 0, 0.4);

	--quat-container: 1280px;

	--quat-font-sans: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI",
	                  "Helvetica Neue", Arial, sans-serif;
	--quat-font-mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo,
	                  Monaco, Consolas, monospace;
}

/* ----------------------------------------------------------------------------
   2. Reset / base
   -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; scroll-behavior: smooth; }

html, body {
	margin: 0;
	padding: 0;
	background: var(--quat-bg);
	color: var(--quat-fg);
	font-family: var(--quat-font-sans);
	font-size: 16px;
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

body { min-height: 100vh; overflow-x: hidden; }
img, svg, video, picture { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; transition: color 0.15s; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: 0; padding: 0; }

h1, h2, h3, h4, h5, h6 {
	margin: 0 0 0.6em;
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 1.05;
	color: var(--quat-fg);
}
p { margin: 0 0 1em; }
::selection { background: var(--quat-accent); color: var(--quat-bg); }

/* ----------------------------------------------------------------------------
   3. Buttons
   -------------------------------------------------------------------------- */
.quat-btn {
	display: inline-flex; align-items: center; justify-content: center;
	gap: 0.5rem;
	padding: 0.95rem 1.6rem;
	border-radius: 999px;
	border: 1px solid transparent;
	background: transparent;
	color: var(--quat-fg);
	font-weight: 600;
	font-size: 0.95rem;
	letter-spacing: -0.005em;
	line-height: 1;
	text-decoration: none !important;
	transition: transform 0.15s, background 0.15s, color 0.15s, border-color 0.15s, box-shadow 0.15s;
	white-space: nowrap;
}
.quat-btn:focus-visible { outline: 2px solid var(--quat-accent); outline-offset: 3px; }
.quat-btn--sm { padding: 0.65rem 1.1rem; font-size: 0.875rem; }

.quat-btn--primary {
	background: var(--quat-fg);
	color: #000;
}
.quat-btn--primary:hover {
	background: #E5E5E5;
	color: #000;
	transform: translateY(-1px);
}

.quat-btn--secondary {
	background: transparent;
	color: var(--quat-fg);
	border: 1px solid var(--quat-border-2);
}
.quat-btn--secondary:hover {
	border-color: var(--quat-muted);
	background: var(--quat-card);
	color: var(--quat-fg);
}

.quat-btn--ghost {
	background: var(--quat-card);
	border: 1px solid var(--quat-border-2);
}
.quat-btn--ghost:hover { border-color: var(--quat-muted); }

.quat-btn--lg { padding: 1.15rem 1.75rem; font-size: 1rem; }
.quat-btn--block { width: 100%; }

/* WP button block */
.wp-block-button__link {
	background: var(--quat-fg) !important;
	color: #000 !important;
	border-radius: 999px !important;
	font-weight: 600 !important;
	padding: 0.95rem 1.6rem !important;
}

/* ----------------------------------------------------------------------------
   4. Top-bar (fri frakt + leverans)
   -------------------------------------------------------------------------- */
.quat-topbar {
	border-bottom: 1px solid var(--quat-border);
	background: var(--quat-bg);
}
.quat-topbar__inner {
	max-width: var(--quat-container);
	margin: 0 auto;
	padding: 0.5rem 1.5rem;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0.6rem;
	font-size: 0.78rem;
	color: var(--quat-muted);
	letter-spacing: 0.01em;
}
.quat-topbar__item { display: inline-flex; align-items: center; gap: 0.4rem; }
.quat-topbar__sep { color: var(--quat-border-2); }

/* ----------------------------------------------------------------------------
   5. Header
   -------------------------------------------------------------------------- */
.quat-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: rgba(0, 0, 0, 0.92);
	-webkit-backdrop-filter: saturate(180%) blur(20px);
	        backdrop-filter: saturate(180%) blur(20px);
	border-bottom: 1px solid var(--quat-border);
}

.quat-header__inner {
	max-width: var(--quat-container);
	margin: 0 auto;
	padding: 1rem 1.5rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
}

.quat-header__logo { display: inline-flex; align-items: center; }

.quat-logo {
	display: inline-flex;
	flex-direction: column;
	line-height: 1;
}
.quat-logo__main {
	font-family: var(--quat-font-sans);
	font-weight: 700;
	font-size: 1.55rem;
	letter-spacing: -0.04em;
	color: var(--quat-fg);
}
.quat-logo__sub {
	font-family: var(--quat-font-mono);
	font-size: 0.55rem;
	letter-spacing: 0.22em;
	color: var(--quat-muted);
	margin-top: 0.15rem;
	text-transform: uppercase;
}

.quat-header__actions {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.quat-header__cart {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px; height: 44px;
	border-radius: 999px;
	background: var(--quat-card);
	border: 1px solid var(--quat-border-2);
	color: var(--quat-fg);
}
.quat-header__cart:hover { border-color: var(--quat-muted); color: var(--quat-accent); }

.cart-count {
	position: absolute;
	top: -2px; right: -2px;
	min-width: 18px; height: 18px;
	padding: 0 5px;
	border-radius: 999px;
	background: var(--quat-accent);
	color: #000;
	font-size: 0.65rem;
	font-weight: 700;
	display: inline-flex; align-items: center; justify-content: center;
	line-height: 1;
}

/* ----------------------------------------------------------------------------
   6. Hero (live-versionen)
   -------------------------------------------------------------------------- */
.quat-hero {
	display: grid;
	gap: 2rem;
	grid-template-columns: 1fr;
	padding: clamp(2rem, 5vw, 4rem) 1.5rem clamp(2rem, 5vw, 4rem);
	max-width: var(--quat-container);
	margin: 0 auto;
	align-items: center;
}

@media (min-width: 900px) {
	.quat-hero {
		grid-template-columns: 1.1fr 1fr;
		gap: 4rem;
		padding: clamp(3rem, 6vw, 5rem) 1.5rem;
	}
}

/* Visual vänster */
.quat-hero__visual {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 380px;
}

.quat-hero__phone {
	position: relative;
	width: 220px;
	aspect-ratio: 9 / 19;
	border-radius: 38px;
	background: linear-gradient(180deg, #2a2a2c 0%, #0e0e10 100%);
	border: 1px solid #3a3a3d;
	padding: 10px;
	box-shadow:
		-30px 60px 100px -40px rgba(255, 255, 255, 0.12),
		0 60px 120px -30px rgba(255, 214, 0, 0.08);
	transform: rotate(-12deg);
}
.quat-hero__phone::after {
	content: "";
	position: absolute;
	inset: 14px;
	border-radius: 28px;
	background: linear-gradient(160deg, rgba(255,255,255,0.06) 0%, transparent 35%, rgba(255,214,0,0.04) 100%);
	pointer-events: none;
}
.quat-hero__phone-screen {
	width: 100%; height: 100%;
	border-radius: 28px;
	background:
		radial-gradient(120% 80% at 50% 0%, rgba(255,214,0,0.18) 0%, transparent 60%),
		linear-gradient(180deg, #16161a 0%, #050506 100%);
	position: relative;
	overflow: hidden;
}
.quat-hero__phone-notch {
	position: absolute;
	top: 10px; left: 50%;
	transform: translateX(-50%);
	width: 90px; height: 22px;
	background: #050506;
	border-radius: 999px;
}

.quat-hero__selected-tag {
	position: absolute;
	bottom: -10px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--quat-bg);
	border: 1px solid var(--quat-border-2);
	border-radius: 8px;
	padding: 0.6rem 1rem;
	display: inline-flex;
	flex-direction: column;
	gap: 0.15rem;
	min-width: 180px;
}
.quat-hero__selected-eyebrow {
	font-family: var(--quat-font-mono);
	font-size: 0.6rem;
	letter-spacing: 0.18em;
	color: var(--quat-muted);
	text-transform: uppercase;
}
.quat-hero__selected-name {
	font-weight: 600;
	font-size: 0.95rem;
	color: var(--quat-fg);
}

/* Content höger */
.quat-hero__content { display: flex; flex-direction: column; }

.quat-hero__eyebrow {
	font-family: var(--quat-font-mono);
	font-size: 0.7rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--quat-muted);
	margin: 0 0 1.25rem;
}

.quat-hero__title {
	font-size: clamp(2.5rem, 6vw, 4.25rem);
	font-weight: 700;
	letter-spacing: -0.04em;
	line-height: 0.95;
	margin: 0 0 2rem;
}
.quat-hero__title-soft { color: var(--quat-muted); font-weight: 700; }

.quat-hero__price-row {
	display: flex;
	align-items: baseline;
	gap: 0.75rem;
	margin: 0 0 1.25rem;
}
.quat-hero__price {
	font-size: clamp(2rem, 4vw, 2.75rem);
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--quat-fg);
}
.quat-hero__price-old {
	font-size: 1rem;
	color: var(--quat-muted);
	text-decoration: line-through;
}

.quat-hero__lead {
	color: var(--quat-muted);
	max-width: 50ch;
	margin: 0 0 2rem;
}

.quat-hero__cta { align-self: stretch; max-width: 360px; margin-bottom: 1.75rem; }

/* ----------------------------------------------------------------------------
   7. Trust list
   -------------------------------------------------------------------------- */
.quat-trust {
	list-style: none; padding: 0; margin: 0;
	display: grid; gap: 0.5rem;
	font-size: 0.875rem;
}
.quat-trust li {
	display: inline-flex; align-items: center; gap: 0.5rem;
	color: var(--quat-muted);
}
.quat-trust li span {
	color: var(--quat-accent);
	font-weight: 700;
}
.quat-trust--inline {
	display: flex; flex-wrap: wrap; gap: 1rem 1.5rem;
	margin-top: 1.25rem;
}

/* ----------------------------------------------------------------------------
   8. Konfigurator (live-versionen)
   -------------------------------------------------------------------------- */
.quat-configurator {
	padding: clamp(3rem, 6vw, 5rem) 1.5rem;
	max-width: var(--quat-container);
	margin: 0 auto;
}

.quat-configurator__intro {
	text-align: center;
	margin-bottom: clamp(2rem, 5vw, 3rem);
}
.quat-configurator__eyebrow {
	font-family: var(--quat-font-mono);
	font-size: 0.7rem;
	letter-spacing: 0.22em;
	color: var(--quat-muted);
	margin: 0 0 0.75rem;
	text-transform: uppercase;
}
.quat-configurator__title {
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	font-weight: 700;
	letter-spacing: -0.03em;
	margin: 0 0 0.75rem;
}
.quat-configurator__lead {
	color: var(--quat-muted);
	margin: 0;
}

.quat-configurator__grid {
	display: grid;
	gap: 1.5rem;
	grid-template-columns: 1fr;
}

@media (min-width: 900px) {
	.quat-configurator__grid {
		grid-template-columns: 1fr 1fr;
		gap: 2rem;
		align-items: stretch;
	}
}

/* Vänster: device-preview-kort */
.quat-configurator__preview { display: flex; }
.quat-configurator__card {
	flex: 1;
	background: var(--quat-card);
	border: 1px solid var(--quat-border);
	border-radius: var(--quat-radius-lg);
	padding: 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.quat-configurator__card-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.quat-configurator__sku {
	font-family: var(--quat-font-mono);
	font-size: 0.7rem;
	letter-spacing: 0.16em;
	color: var(--quat-muted);
}
.quat-configurator__dots { display: inline-flex; gap: 0.3rem; }
.quat-configurator__dot {
	width: 6px; height: 6px;
	border-radius: 999px;
	background: var(--quat-border-2);
}
.quat-configurator__dot.is-active { background: var(--quat-accent); }

.quat-configurator__device {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 280px;
	padding: 1rem 0;
}
.quat-configurator__phone {
	width: 140px;
	aspect-ratio: 9 / 19;
	border-radius: 28px;
	background: linear-gradient(180deg, #2a2a2c 0%, #0e0e10 100%);
	border: 1px solid #3a3a3d;
	padding: 6px;
	position: relative;
}
.quat-configurator__phone::after {
	content: "";
	position: absolute;
	inset: 8px;
	border-radius: 22px;
	background: linear-gradient(160deg, rgba(255,255,255,0.04) 0%, transparent 40%);
	pointer-events: none;
}
.quat-configurator__phone-screen {
	width: 100%; height: 100%;
	border-radius: 22px;
	background:
		radial-gradient(120% 80% at 50% 0%, rgba(255,255,255,0.06) 0%, transparent 60%),
		linear-gradient(180deg, #16161a 0%, #050506 100%);
	position: relative;
	overflow: hidden;
}
.quat-configurator__phone-notch {
	position: absolute;
	top: 8px; left: 50%;
	transform: translateX(-50%);
	width: 60px; height: 16px;
	background: #050506;
	border-radius: 999px;
}

.quat-configurator__card-foot {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	padding-top: 0.75rem;
	border-top: 1px solid var(--quat-border);
}
.quat-configurator__card-eyebrow {
	font-family: var(--quat-font-mono);
	font-size: 0.6rem;
	letter-spacing: 0.18em;
	color: var(--quat-muted);
	text-transform: uppercase;
}
.quat-configurator__card-name {
	font-weight: 600;
	font-size: 1rem;
	color: var(--quat-fg);
}

/* Höger: konfigurator-formulär */
.quat-cfg {
	background: var(--quat-bg);
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

/* Head: premium + pris */
.quat-cfg__head {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 1rem;
	padding-bottom: 0.75rem;
	border-bottom: 1px solid var(--quat-border);
}
.quat-cfg__head-left { display: flex; flex-direction: column; gap: 0.25rem; }
.quat-cfg__premium {
	font-family: var(--quat-font-mono);
	font-size: 0.7rem;
	letter-spacing: 0.22em;
	color: var(--quat-accent);
	margin: 0;
	text-transform: uppercase;
	font-weight: 600;
}
.quat-cfg__product-name {
	font-weight: 600;
	font-size: 1.1rem;
	margin: 0;
	color: var(--quat-fg);
}
.quat-cfg__price {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--quat-fg);
	margin: 0;
}
.quat-cfg__price-old {
	color: var(--quat-muted);
	text-decoration: line-through;
	font-size: 0.85rem;
	font-weight: 500;
	margin-left: 0.4rem;
}

/* Auto-detect */
.quat-cfg__autodetect {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.85rem 1rem;
	background: var(--quat-card);
	border: 1px solid var(--quat-border-2);
	border-radius: var(--quat-radius);
	color: var(--quat-fg);
	font-size: 0.9rem;
	font-weight: 500;
	text-align: left;
	transition: border-color 0.15s, background 0.15s;
}
.quat-cfg__autodetect:hover { border-color: var(--quat-muted); background: var(--quat-card-2); }
.quat-cfg__autodetect-icon {
	width: 28px; height: 28px;
	border-radius: 999px;
	background: var(--quat-bg);
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--quat-accent);
	flex: 0 0 auto;
}
.quat-cfg__autodetect-arrow { margin-left: auto; color: var(--quat-muted); }

/* Field */
.quat-cfg__field { display: flex; flex-direction: column; gap: 0.5rem; }
.quat-cfg__field-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.quat-cfg__field-head label,
.quat-cfg__label {
	font-weight: 600;
	font-size: 0.9rem;
	color: var(--quat-fg);
}
.quat-cfg__field-meta {
	font-family: var(--quat-font-mono);
	font-size: 0.65rem;
	color: var(--quat-muted);
	letter-spacing: 0.05em;
}

/* Select wrapper */
.quat-cfg__select-wrap {
	position: relative;
}
.quat-cfg__select-wrap select {
	width: 100%;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	padding: 0.95rem 2.5rem 0.95rem 1rem;
	background: var(--quat-card);
	border: 1px solid var(--quat-border-2);
	border-radius: var(--quat-radius);
	color: var(--quat-fg);
	font: inherit;
	font-size: 0.95rem;
	font-weight: 500;
	cursor: pointer;
	transition: border-color 0.15s, background 0.15s;
}
.quat-cfg__select-wrap select:focus-visible {
	outline: none;
	border-color: var(--quat-fg);
}
.quat-cfg__select-wrap select:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}
.quat-cfg__select-caret {
	position: absolute;
	right: 1rem;
	top: 50%;
	transform: translateY(-50%);
	pointer-events: none;
	color: var(--quat-muted);
}

/* Segmented */
.quat-cfg__segmented {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.5rem;
	padding: 0.3rem;
	background: var(--quat-card);
	border: 1px solid var(--quat-border-2);
	border-radius: var(--quat-radius);
}
.quat-cfg__segmented-option {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem 0.5rem;
	border-radius: 8px;
	font-size: 0.9rem;
	font-weight: 500;
	color: var(--quat-muted);
	cursor: pointer;
	transition: background 0.15s, color 0.15s;
}
.quat-cfg__segmented-option input {
	position: absolute;
	opacity: 0;
	inset: 0;
	cursor: pointer;
}
.quat-cfg__segmented-option.is-active {
	background: var(--quat-fg);
	color: #000;
	font-weight: 600;
}

/* Pills (typ) */
.quat-cfg__pills {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}
.quat-cfg__pill {
	position: relative;
	padding: 0.55rem 1rem;
	border: 1px solid var(--quat-border-2);
	border-radius: 999px;
	background: var(--quat-bg);
	color: var(--quat-fg);
	font-size: 0.85rem;
	font-weight: 500;
	cursor: pointer;
	transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.quat-cfg__pill input {
	position: absolute;
	opacity: 0;
	inset: 0;
	cursor: pointer;
}
.quat-cfg__pill:hover { border-color: var(--quat-muted); }
.quat-cfg__pill.is-active {
	background: var(--quat-fg);
	color: #000;
	border-color: var(--quat-fg);
	font-weight: 600;
}

/* Typ-beskrivning */
.quat-cfg__desc {
	background: var(--quat-card);
	border: 1px solid var(--quat-border);
	border-radius: var(--quat-radius);
	padding: 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}
.quat-cfg__desc-eyebrow {
	font-family: var(--quat-font-mono);
	font-size: 0.7rem;
	letter-spacing: 0.22em;
	color: var(--quat-accent);
	margin: 0;
	text-transform: uppercase;
	font-weight: 600;
}
.quat-cfg__desc-headline {
	font-weight: 700;
	font-size: 1rem;
	margin: 0;
	color: var(--quat-fg);
}
.quat-cfg__desc-bullets {
	list-style: none; padding: 0; margin: 0.25rem 0 0;
	display: flex; flex-direction: column; gap: 0.4rem;
}
.quat-cfg__desc-bullets li {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	color: var(--quat-muted);
	font-size: 0.875rem;
}
.quat-cfg__desc-bullets li span {
	width: 8px; height: 8px;
	border-radius: 999px;
	background: var(--quat-success);
	display: inline-block;
	flex: 0 0 auto;
}

/* DIN KONFIGURATION */
.quat-cfg__summary {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 0.75rem;
	align-items: center;
	padding: 1rem 1.25rem;
	background: var(--quat-card);
	border: 1px solid var(--quat-border-2);
	border-radius: var(--quat-radius);
}
.quat-cfg__summary-icon {
	width: 36px; height: 36px;
	border-radius: 8px;
	background: var(--quat-bg);
	border: 1px solid var(--quat-accent);
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--quat-accent);
	flex: 0 0 auto;
}
.quat-cfg__summary-text { display: flex; flex-direction: column; gap: 0.15rem; min-width: 0; }
.quat-cfg__summary-eyebrow {
	font-family: var(--quat-font-mono);
	font-size: 0.6rem;
	letter-spacing: 0.18em;
	color: var(--quat-muted);
	margin: 0;
	text-transform: uppercase;
}
.quat-cfg__summary-name {
	font-weight: 600;
	font-size: 0.95rem;
	margin: 0;
	color: var(--quat-fg);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.quat-cfg__summary-sub {
	font-size: 0.8rem;
	color: var(--quat-muted);
	margin: 0;
}
.quat-cfg__summary-price span {
	font-weight: 700;
	font-size: 1.1rem;
	color: var(--quat-fg);
}

/* Actions */
.quat-cfg__actions { display: flex; flex-direction: column; gap: 0.5rem; }

/* Picker status */
.quat-picker__status {
	color: var(--quat-muted);
	font-size: 0.875rem;
	margin: 0;
	min-height: 1.4em;
}
.quat-picker__status.is-error { color: #ff8b8b; }
.quat-picker__status.is-success { color: var(--quat-success); }

/* ----------------------------------------------------------------------------
   9. Footer (live-versionen)
   -------------------------------------------------------------------------- */
.quat-footer-wrap { margin-top: 4rem; }

.quat-footer {
	background: var(--quat-bg);
	border-top: 1px solid var(--quat-border);
	padding: 3rem 1.5rem 2rem;
}

.quat-footer__inner {
	max-width: var(--quat-container);
	margin: 0 auto;
	display: grid;
	gap: 2.5rem;
	grid-template-columns: 1fr;
	align-items: start;
	position: relative;
}
@media (min-width: 720px) {
	.quat-footer__inner {
		grid-template-columns: 1fr 1fr;
		gap: 3rem;
	}
}

.quat-footer__brand .quat-logo { display: inline-flex; }

.quat-footer__nav { display: flex; flex-direction: column; gap: 1rem; }
.quat-footer__label {
	font-weight: 700;
	font-size: 0.95rem;
	margin: 0;
	color: var(--quat-fg);
}
.quat-footer-menu {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-direction: column; gap: 0.65rem;
	font-size: 0.875rem;
	color: var(--quat-muted);
}
.quat-footer-menu a:hover { color: var(--quat-accent); }

/* Support-floater */
.quat-footer__support-floater {
	position: absolute;
	right: 0; bottom: 0;
}
.quat-footer__chat {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.7rem 1.1rem;
	background: var(--quat-card);
	border: 1px solid var(--quat-border-2);
	border-radius: 999px;
	color: var(--quat-fg);
	font-size: 0.9rem;
	font-weight: 600;
	transition: border-color 0.15s, background 0.15s;
}
.quat-footer__chat:hover { border-color: var(--quat-muted); background: var(--quat-card-2); }
.quat-footer__chat svg { color: var(--quat-accent); }

.quat-footer__bottom {
	max-width: var(--quat-container);
	margin: 2rem auto 0;
	padding-top: 1.5rem;
	border-top: 1px solid var(--quat-border);
	color: var(--quat-muted);
	font-size: 0.8rem;
}

/* ----------------------------------------------------------------------------
   10. Layout helpers
   -------------------------------------------------------------------------- */
.quat-main { display: block; }

section { padding: 0; }

/* ----------------------------------------------------------------------------
   11. Breadcrumbs
   -------------------------------------------------------------------------- */
.quat-breadcrumbs {
	font-size: 0.85rem;
	color: var(--quat-muted);
	margin-bottom: 1.5rem;
}
.quat-breadcrumbs ol { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 0.5rem; }
.quat-breadcrumbs li { display: inline-flex; align-items: center; gap: 0.5rem; }
.quat-breadcrumbs li + li::before { content: "/"; color: var(--quat-border-2); }
.quat-breadcrumbs a:hover { color: var(--quat-accent); }
.quat-breadcrumbs [aria-current="page"] { color: var(--quat-fg); }

/* ----------------------------------------------------------------------------
   12. WooCommerce overrides
   -------------------------------------------------------------------------- */
.woocommerce-notices-wrapper { margin-bottom: 1.5rem; }
.woocommerce-message, .woocommerce-info, .woocommerce-error {
	background: var(--quat-card) !important;
	border: 1px solid var(--quat-border) !important;
	border-left: 3px solid var(--quat-accent) !important;
	border-radius: var(--quat-radius) !important;
	color: var(--quat-fg) !important;
	padding: 1rem 1.25rem !important;
}
.woocommerce-error { border-left-color: #ff5b5b !important; }

.woocommerce form .form-row label { color: var(--quat-muted); font-size: 0.85rem; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	background: var(--quat-bg) !important;
	color: var(--quat-fg) !important;
	border: 1px solid var(--quat-border-2) !important;
	border-radius: var(--quat-radius) !important;
	padding: 0.85rem 1rem !important;
}

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.wc-block-components-button {
	background: var(--quat-fg) !important;
	color: #000 !important;
	border-radius: 999px !important;
	border: 0 !important;
	font-weight: 600 !important;
	padding: 0.95rem 1.6rem !important;
	cursor: pointer;
	transition: transform 0.15s, background 0.15s !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover {
	background: #E5E5E5 !important;
	color: #000 !important;
}

.woocommerce table.shop_table {
	background: var(--quat-card) !important;
	border: 1px solid var(--quat-border) !important;
	border-radius: var(--quat-radius) !important;
	color: var(--quat-fg) !important;
	border-collapse: separate;
	border-spacing: 0;
	overflow: hidden;
}
.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
	border-color: var(--quat-border) !important;
	color: var(--quat-fg) !important;
	padding: 1rem !important;
}

/* Single product */
.quat-product {
	display: grid;
	gap: 2rem;
	grid-template-columns: 1fr;
	max-width: var(--quat-container);
	margin: 0 auto;
	padding: 2rem 1.5rem;
}
@media (min-width: 900px) {
	.quat-product { grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; }
}
.quat-product__title { margin: 0 0 0.5rem; }
.quat-product__price-big { font-size: 1.75rem; font-weight: 700; color: var(--quat-accent); display: block; margin-bottom: 1rem; }

/* Product loop */
.woocommerce ul.products {
	display: grid !important;
	gap: 1.25rem !important;
	grid-template-columns: repeat(2, 1fr) !important;
}
@media (min-width: 720px) {
	.woocommerce ul.products { grid-template-columns: repeat(3, 1fr) !important; }
}
.woocommerce ul.products li.product {
	background: var(--quat-card) !important;
	border: 1px solid var(--quat-border) !important;
	border-radius: var(--quat-radius) !important;
	padding: 1rem !important;
}

/* Filter bar */
.quat-filter-bar {
	display: flex; flex-wrap: wrap; gap: 0.75rem;
	margin: 0 0 1.5rem;
	padding: 1rem;
	background: var(--quat-card);
	border: 1px solid var(--quat-border);
	border-radius: var(--quat-radius);
}
.quat-filter-bar label { display: grid; gap: 0.35rem; flex: 1 1 200px; }
.quat-filter-bar select {
	background: var(--quat-bg);
	color: var(--quat-fg);
	border: 1px solid var(--quat-border-2);
	border-radius: var(--quat-radius);
	padding: 0.65rem 0.85rem;
}

/* ----------------------------------------------------------------------------
   13. Forms
   -------------------------------------------------------------------------- */
.wpcf7 input[type="text"], .wpcf7 input[type="email"], .wpcf7 input[type="tel"],
.wpcf7 textarea,
.quat-form input, .quat-form textarea, .quat-form select {
	width: 100%;
	background: var(--quat-bg);
	color: var(--quat-fg);
	border: 1px solid var(--quat-border-2);
	border-radius: var(--quat-radius);
	padding: 0.85rem 1rem;
	font: inherit;
}

/* ----------------------------------------------------------------------------
   14. Accessibility
   -------------------------------------------------------------------------- */
.screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0,0,0,0);
	white-space: nowrap; border: 0;
}
:focus-visible { outline: 2px solid var(--quat-accent); outline-offset: 2px; }
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.001ms !important;
		scroll-behavior: auto !important;
	}
}
.skip-link {
	position: absolute;
	top: -40px;
	left: 0;
	background: var(--quat-accent);
	color: #000;
	padding: 0.5rem 1rem;
	z-index: 200;
}
.skip-link:focus { top: 0; }

/* Hide native arrows */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
input[type="number"] { -moz-appearance: textfield; }