:root {
	--kl-bg-base: #0a0a0a;
	--kl-bg-soft: #141414;
	--kl-surface: #17181c;
	--kl-surface-2: #1d1e23;
	--kl-line: rgba(255, 255, 255, 0.08);
	--kl-line-strong: rgba(255, 255, 255, 0.16);
	--kl-text: #f4f4f4;
	--kl-text-soft: #b9bac0;
	--kl-text-meta: #9a9ba1;
	--kl-gold: #e5c071;
	--kl-gold-hover: #ffd990;
	--kl-radius: 14px;
}

body.page-template-katana-landing,
body.kl-landing-active {
	background: var(--kl-bg-base) !important;
	background: linear-gradient(180deg, #0a0a0a 0%, #141414 100%) !important;
	background-attachment: fixed !important;
	color: var(--kl-text);
}

/* Belt-and-suspenders horizontal overflow guard. `overflow-x: clip` is
 * the modern strict-clip rule; `hidden` is the legacy fallback. Both on
 * html and body so neither one creates a horizontal scroll context.
 * Without this, the 100vw rule below leaks ~5-15 px past the viewport on
 * Android Chrome / iOS Safari (scrollbar gutter rounding) and shows up
 * as an empty stripe on the right side of the screen. */
html { overflow-x: hidden; overflow-x: clip; }
body.kl-landing-active { overflow-x: hidden; overflow-x: clip; }

/* Mobile: zero out Shoptimizer's .col-full / archive / content side
 * padding INSIDE the page-content area only — header + footer keep
 * their original padding because their .col-full divs sit outside
 * #content. Without this, the theme leaves ~16-24 px of dead space on
 * either side of the landing on phones, which makes hero / trust /
 * carousel look caged. */
@media (max-width: 900px) {
	body.kl-landing-active #content,
	body.kl-landing-active #content .col-full,
	body.kl-landing-active .shoptimizer-archive,
	body.kl-landing-active .shoptimizer-archive .col-full,
	body.kl-landing-active .archive-header,
	body.kl-landing-active .archive-header .col-full,
	body.kl-landing-active #content .woocommerce,
	body.kl-landing-active #content .woocommerce .col-full {
		padding-left: 0 !important;
		padding-right: 0 !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
		max-width: 100% !important;
	}
}

/* Full-bleed the landing main on desktop so the trust strip / reviews
 * band / carousel / newsletter span the viewport. On viewports ≤900 px
 * the surrounding Shoptimizer .col-full chrome is already nearly full-
 * width (theme media queries), so we drop the 100vw escape on mobile —
 * keeps Slick's container width measurement sane and stops sub-pixel
 * 100vw overflow on the right side. */
@media (min-width: 901px) {
	body.kl-landing-active .katana-landing,
	body.kl-landing-active main#katana-landing {
		width: 100vw;
		max-width: 100vw;
		margin-left: calc(50% - 50vw);
		margin-right: calc(50% - 50vw);
	}
}

.katana-landing,
.katana-landing * { box-sizing: border-box; }
.katana-landing {
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", Helvetica, Arial, sans-serif;
	color: var(--kl-text);
	line-height: 1.55;
	font-size: 16px;
}
.katana-landing a { color: var(--kl-gold); text-decoration: none; transition: color .25s ease; }
.katana-landing a:hover { color: var(--kl-gold-hover); }
.katana-landing img { max-width: 100%; height: auto; display: block; }
.katana-landing .kl-container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.katana-landing .kl-eyebrow {
	font-size: 11px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase;
	color: var(--kl-gold); margin: 0 0 14px;
}
.katana-landing .kl-h2 {
	font-size: clamp(26px, 3vw, 38px); font-weight: 800; letter-spacing: -0.01em; line-height: 1.15;
	color: #fff; margin: 0 0 16px;
}
.katana-landing .kl-section-head { max-width: 720px; margin: 0 auto 40px; text-align: center; }
.katana-landing .kl-section-lede { color: var(--kl-text-soft); font-size: 16px; line-height: 1.6; margin: 0; }
.katana-landing .kl-sr {
	position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.katana-landing .kl-btn {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 14px 24px; border-radius: 10px; font-size: 14.5px; font-weight: 700; letter-spacing: 0.02em;
	text-decoration: none; transition: background .25s ease, border-color .25s ease, color .25s ease, transform .25s ease;
	border: 1px solid transparent; line-height: 1; cursor: pointer;
}
.katana-landing .kl-btn--primary { background: var(--kl-gold); color: #111; border-color: var(--kl-gold); }
.katana-landing .kl-btn--primary:hover { background: var(--kl-gold-hover); border-color: var(--kl-gold-hover); color: #111; transform: translateY(-1px); }
.katana-landing .kl-btn--ghost { background: transparent; color: var(--kl-text); border-color: var(--kl-line-strong); }
.katana-landing .kl-btn--ghost:hover { background: rgba(229, 192, 113, 0.08); border-color: var(--kl-gold); color: var(--kl-gold); }
.katana-landing .kl-cta-row { margin-top: 32px; text-align: center; }

/* Hero */
.katana-landing .kl-hero { position: relative; min-height: 78vh; display: flex; align-items: center; overflow: hidden; margin: 0; }
.katana-landing .kl-hero__media { position: absolute; inset: 0; }
.katana-landing .kl-hero__media img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.katana-landing .kl-hero__overlay {
	position: absolute; inset: 0;
	background:
		linear-gradient(180deg, rgba(10,10,10,0.35) 0%, rgba(10,10,10,0.70) 70%, rgba(10,10,10,0.95) 100%),
		linear-gradient(90deg, rgba(10,10,10,0.85) 0%, rgba(10,10,10,0.20) 60%, rgba(10,10,10,0) 100%);
}
.katana-landing .kl-hero__inner { position: relative; max-width: 1200px; width: 100%; margin: 0 auto; padding: 96px 24px 72px; }
.katana-landing .kl-hero__title {
	font-size: clamp(30px, 3.4vw, 46px); font-weight: 800; line-height: 1.08; letter-spacing: -0.02em;
	color: #fff; margin: 0 0 18px; max-width: 18ch;
}
.katana-landing .kl-hero__title span { color: var(--kl-gold); }
.katana-landing .kl-hero__lede { color: var(--kl-text-soft); font-size: clamp(15px, 1.4vw, 18px); line-height: 1.6; max-width: 52ch; margin: 0 0 32px; }
.katana-landing .kl-hero__cta { display: flex; flex-wrap: wrap; gap: 12px; }

/* Trust */
.katana-landing .kl-trust { border-top: 1px solid var(--kl-line); border-bottom: 1px solid var(--kl-line); padding: 22px 0; background: rgba(255,255,255,0.015); }
.katana-landing .kl-trust__grid { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.katana-landing .kl-trust__item { display: flex; align-items: center; gap: 14px; }
.katana-landing .kl-trust__icon { flex: 0 0 28px; color: var(--kl-gold); stroke: currentColor; }
.katana-landing .kl-trust__h { display: block; color: #fff; font-size: 14px; font-weight: 700; letter-spacing: 0.01em; }
.katana-landing .kl-trust__p { display: block; color: var(--kl-text-meta); font-size: 12.5px; margin-top: 2px; }
@media (max-width: 900px) { .katana-landing .kl-trust__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .katana-landing .kl-trust__grid { grid-template-columns: 1fr; } }

/* Featured carousel */
.katana-landing .kl-featured { padding: 56px 0 48px; }
.katana-landing .kl-carousel { position: relative; margin: 24px 0 0; }
.katana-landing .kl-product-grid {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: nowrap; gap: 18px;
	overflow-x: auto; overflow-y: visible;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none; -ms-overflow-style: none;
	padding: 6px 4px 8px;
	scroll-padding-left: 4px;
}
.katana-landing .kl-product-grid::-webkit-scrollbar { display: none; width: 0; height: 0; }

.katana-landing .kl-product {
	flex: 0 0 clamp(220px, 22vw, 280px);
	scroll-snap-align: start;
	background: var(--kl-surface); border: 1px solid var(--kl-line);
	border-radius: var(--kl-radius); overflow: hidden;
	display: flex; flex-direction: column;
	transition: border-color .25s ease, transform .25s ease, box-shadow .25s ease;
}
@media (max-width: 720px) { .katana-landing .kl-product { flex-basis: clamp(180px, 64vw, 240px); } }

/* On mobile, escape the .kl-container 24 px horizontal padding so the
 * carousel viewport runs all the way to both edges of the screen. The
 * first card keeps a 16 px left gutter (so it lines up nicely with the
 * section header), but the right side is cut by the screen edge — peek
 * cards reach the actual viewport boundary instead of the inner padding. */
@media (max-width: 900px) {
	.katana-landing .kl-featured .kl-carousel {
		margin-left:  -24px;
		margin-right: -24px;
	}
	.katana-landing .kl-featured .kl-product-grid {
		padding-left:  16px;
		padding-right: 16px;
		scroll-padding-left: 16px;
	}
}
.katana-landing .kl-product:hover {
	border-color: rgba(229, 192, 113, 0.55); transform: translateY(-3px);
	box-shadow: 0 12px 32px rgba(0,0,0,0.55), 0 0 0 1px rgba(229, 192, 113, 0.15);
}
.katana-landing .kl-product__media { position: relative; display: block; background: #0c0c0e; aspect-ratio: 1 / 1; overflow: hidden; }
.katana-landing .kl-product__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.katana-landing .kl-product:hover .kl-product__media img { transform: scale(1.04); }
.katana-landing .kl-badge {
	position: absolute; top: 12px; left: 12px;
	padding: 4px 10px; border-radius: 999px;
	background: var(--kl-gold); color: #111;
	font-size: 11px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
}
.katana-landing .kl-product__body { padding: 16px 16px 18px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.katana-landing .kl-product__title { margin: 0; font-size: 14.5px; font-weight: 700; line-height: 1.35; }
.katana-landing .kl-product__title a { color: #fff; text-decoration: none; }
.katana-landing .kl-product__title a:hover { color: var(--kl-gold); }
.katana-landing .kl-product__price { margin-top: auto; color: #fff; font-size: 15px; font-weight: 700; }
.katana-landing .kl-product__price .woocommerce-Price-amount,
.katana-landing .kl-product__price bdi,
.katana-landing .kl-product__price ins .woocommerce-Price-amount { color: #fff !important; }
.katana-landing .kl-product__price del { opacity: .55; margin-right: 6px; }

.katana-landing .kl-carousel__nav {
	position: absolute; top: 50%; transform: translateY(-50%);
	width: 44px; height: 44px;
	display: inline-flex; align-items: center; justify-content: center;
	background: var(--kl-surface); color: #fff;
	border: 1px solid var(--kl-line-strong); border-radius: 999px;
	cursor: pointer; z-index: 3;
	box-shadow: 0 6px 18px rgba(0,0,0,0.55);
	transition: background .2s ease, border-color .2s ease, color .2s ease, transform .2s ease, opacity .2s ease;
	padding: 0;
}
.katana-landing .kl-carousel__nav:hover { background: var(--kl-surface-2); border-color: rgba(229, 192, 113, 0.55); color: var(--kl-gold); }
.katana-landing .kl-carousel__nav:disabled { opacity: 0.35; cursor: not-allowed; transform: translateY(-50%) scale(0.96); }
.katana-landing .kl-carousel__nav svg { display: block; }
.katana-landing .kl-carousel__nav--prev { left: -22px; }
.katana-landing .kl-carousel__nav--next { right: -22px; }
@media (max-width: 900px) { .katana-landing .kl-carousel__nav { display: none; } }

.katana-landing .kl-product__rating { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--kl-text-meta); margin-top: -2px; }
.katana-landing .kl-stars {
	position: relative; display: inline-block; font-size: 13px; line-height: 1; letter-spacing: 1px;
	height: 1em; color: rgba(255, 255, 255, 0.18);
}
.katana-landing .kl-stars__row { display: inline-block; }
.katana-landing .kl-stars__row--fg {
	position: absolute; left: 0; top: 0;
	/* Trustpilot green to match the reviews block above. */
	color: #00b67a;
	overflow: hidden; white-space: nowrap;
	width: var(--kl-rating-pct, 0%);
}
.katana-landing .kl-product__rating-count { color: var(--kl-text-meta); font-weight: 500; }

/* Story */
.katana-landing .kl-story { padding: 56px 0; }
.katana-landing .kl-story__inner { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr); gap: 56px; align-items: center; }
@media (max-width: 900px) { .katana-landing .kl-story__inner { grid-template-columns: 1fr; gap: 32px; } }
.katana-landing .kl-story__media img { width: 100%; border-radius: var(--kl-radius); box-shadow: 0 12px 40px rgba(0,0,0,0.55); border: 1px solid var(--kl-line); }
.katana-landing .kl-story__copy h2 { font-size: clamp(28px, 3.4vw, 42px); }
.katana-landing .kl-story__copy p { color: var(--kl-text-soft); margin: 0 0 14px; line-height: 1.7; }
.katana-landing .kl-story__pillars { margin: 24px 0 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.katana-landing .kl-story__pillars li { color: var(--kl-text); padding-left: 22px; position: relative; font-size: 14.5px; }
.katana-landing .kl-story__pillars li::before { content: ""; position: absolute; left: 0; top: 0.5em; width: 12px; height: 2px; background: var(--kl-gold); border-radius: 1px; }
.katana-landing .kl-story__pillars strong { color: #fff; }

/* Customizer — capped at 1200 px and centered so it doesn't stretch
 * full-screen on wide viewports (the parent .katana-landing is 100vw). */
.katana-landing .kl-customizer { position: relative; min-height: 460px; display: flex; align-items: center; max-width: 1200px; width: calc(100% - 48px); margin: 24px auto; border-radius: 18px; overflow: hidden; }
.katana-landing .kl-customizer__media { position: absolute; inset: 0; background-size: cover; background-position: center; }
.katana-landing .kl-customizer__overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(10,10,10,0.92) 0%, rgba(10,10,10,0.60) 50%, rgba(10,10,10,0.30) 100%); }
.katana-landing .kl-customizer__inner { position: relative; max-width: 580px; padding: 56px 48px; color: #fff; }
.katana-landing .kl-customizer__inner p { color: var(--kl-text-soft); margin: 0 0 24px; line-height: 1.6; }
@media (max-width: 600px) { .katana-landing .kl-customizer { margin: 16px; } .katana-landing .kl-customizer__inner { padding: 36px 24px; } }

/* Categories */
.katana-landing .kl-categories { padding: 56px 0; }
.katana-landing .kl-cat-grid { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 820px) { .katana-landing .kl-cat-grid { grid-template-columns: 1fr; } }
.katana-landing .kl-cat__link { position: relative; display: block; overflow: hidden; border-radius: var(--kl-radius); border: 1px solid var(--kl-line); aspect-ratio: 4 / 3; color: #fff; text-decoration: none; transition: border-color .25s ease, transform .25s ease; }
.katana-landing .kl-cat__link:hover { border-color: rgba(229, 192, 113, 0.55); transform: translateY(-3px); }
.katana-landing .kl-cat__link img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.katana-landing .kl-cat__link:hover img { transform: scale(1.06); }
.katana-landing .kl-cat__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0) 35%, rgba(0,0,0,0.85) 100%); }
.katana-landing .kl-cat__copy { position: absolute; left: 22px; right: 22px; bottom: 18px; }
.katana-landing .kl-cat__name { color: #fff; margin: 0; font-size: 21px; font-weight: 800; letter-spacing: -0.01em; }
.katana-landing .kl-cat__count { color: var(--kl-text-meta); font-size: 12.5px; margin-top: 4px; display: block; }

/* FAQ */
.katana-landing .kl-faq { padding: 56px 0; }
.katana-landing .kl-faq__list { max-width: 820px; margin: 0 auto; }
.katana-landing .kl-faq__item { border: 1px solid var(--kl-line); border-radius: 12px; margin-bottom: 12px; background: rgba(255,255,255,0.015); overflow: hidden; transition: border-color .25s ease, background .25s ease; }
.katana-landing .kl-faq__item[open] { border-color: rgba(229, 192, 113, 0.45); background: rgba(229, 192, 113, 0.04); }
.katana-landing .kl-faq__q { font-weight: 700; font-size: 15.5px; color: #fff; padding: 18px 22px; cursor: pointer; list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.katana-landing .kl-faq__q::-webkit-details-marker { display: none; }
.katana-landing .kl-faq__chev { color: var(--kl-gold); transition: transform .25s ease; flex-shrink: 0; }
.katana-landing .kl-faq__item[open] .kl-faq__chev { transform: rotate(180deg); }
.katana-landing .kl-faq__a { padding: 0 22px 20px; color: var(--kl-text-soft); line-height: 1.65; }
.katana-landing .kl-faq__a p { margin: 0; }

/* Newsletter */
.katana-landing .kl-newsletter { padding: 56px 0 60px; background: linear-gradient(180deg, rgba(229, 192, 113, 0.04) 0%, rgba(229, 192, 113, 0) 100%); border-top: 1px solid var(--kl-line); }
.katana-landing .kl-newsletter__inner { display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, 460px); gap: 56px; align-items: center; }
@media (max-width: 820px) { .katana-landing .kl-newsletter__inner { grid-template-columns: 1fr; gap: 28px; } }
.katana-landing .kl-newsletter p { color: var(--kl-text-soft); margin: 0; line-height: 1.6; }
.katana-landing .kl-newsletter__form { display: grid; grid-template-columns: 1fr auto; gap: 10px; }
.katana-landing .kl-newsletter__form input[type="email"] {
	background: var(--kl-surface); border: 1px solid var(--kl-line-strong); color: #fff;
	padding: 14px 18px; border-radius: 10px; font-size: 14.5px; width: 100%; transition: border-color .25s ease;
}
.katana-landing .kl-newsletter__form input[type="email"]:focus { outline: none; border-color: var(--kl-gold); }
.katana-landing .kl-newsletter__form input[type="email"]::placeholder { color: var(--kl-text-meta); }
.katana-landing .kl-newsletter__form button { white-space: nowrap; }
.katana-landing .kl-newsletter__legal { grid-column: 1 / -1; color: var(--kl-text-meta); font-size: 12px; margin: 0; }
@media (max-width: 520px) { .katana-landing .kl-newsletter__form { grid-template-columns: 1fr; } }

/* ── Guide d'achat (SEO) ─────────────────────────────────── */
.katana-landing .kl-guide { padding: 56px 0; border-top: 1px solid var(--kl-line); }
.katana-landing .kl-guide__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; margin-top: 40px; align-items: start; }
.katana-landing .kl-guide__col { min-width: 0; }
@media (max-width: 900px) { .katana-landing .kl-guide__inner { grid-template-columns: 1fr; gap: 36px; } }
.katana-landing .kl-guide__h3 { font-size: 11.5px; font-weight: 800; color: var(--kl-gold); margin: 0 0 18px; letter-spacing: 0.09em; text-transform: uppercase; }

/* Tableau aciers */
.katana-landing .kl-table-wrap { overflow-x: auto; margin-bottom: 36px; border-radius: 12px; border: 1px solid var(--kl-line); }
.katana-landing .kl-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.katana-landing .kl-table thead th { background: rgba(229,192,113,0.07); color: var(--kl-gold); font-weight: 700; padding: 11px 13px; text-align: left; white-space: nowrap; border-bottom: 1px solid var(--kl-line); font-size: 12px; text-transform: uppercase; letter-spacing: 0.05em; }
.katana-landing .kl-table tbody tr { border-bottom: 1px solid var(--kl-line); transition: background .2s; }
.katana-landing .kl-table tbody tr:last-child { border-bottom: none; }
.katana-landing .kl-table tbody tr:hover { background: rgba(255,255,255,0.025); }
.katana-landing .kl-table td { padding: 11px 13px; color: var(--kl-text-soft); vertical-align: middle; line-height: 1.4; }
.katana-landing .kl-table td:first-child { color: var(--kl-text); font-weight: 600; white-space: nowrap; }
.katana-landing .kl-table td:last-child { color: var(--kl-text-meta); white-space: nowrap; }

/* Grille de prix */
.katana-landing .kl-price-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
@media (max-width: 520px) { .katana-landing .kl-price-grid { grid-template-columns: 1fr; gap: 8px; } }
.katana-landing .kl-price-card { background: var(--kl-surface); border: 1px solid var(--kl-line); border-radius: 12px; padding: 18px 16px; }
.katana-landing .kl-price-card--mid { border-color: rgba(229,192,113,0.45); background: rgba(229,192,113,0.04); }
.katana-landing .kl-price-card__label { display: block; font-size: 10.5px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.09em; color: var(--kl-gold); margin-bottom: 6px; }
.katana-landing .kl-price-card__range { display: block; font-size: 20px; font-weight: 800; color: var(--kl-text); margin-bottom: 8px; line-height: 1.2; }
.katana-landing .kl-price-card p { font-size: 12.5px; color: var(--kl-text-soft); margin: 0; line-height: 1.5; }
/* ===== Katana Kard — Homepage reviews (Trustpilot style) ===== */

.ku-hp-reviews {
    --ku-hpr-green:        #00b67a;
    --ku-hpr-green-dark:   #009966;
    --ku-hpr-ink:          #191919;
    --ku-hpr-muted:        #67717b;
    --ku-hpr-line:         #e6e9ed;
    --ku-hpr-line-strong:  #d0d5dc;
    --ku-hpr-bg-soft:      #f8f9fb;

    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    color: var(--ku-hpr-ink);
    background: #fff;
    padding: 40px 20px 44px;
    margin: 0;
}

.ku-hp-reviews-inner {
    max-width: 1360px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(220px, 260px) 1fr;
    gap: 36px;
    align-items: center;
}

@media (max-width: 900px) {
    .ku-hp-reviews-inner { grid-template-columns: 1fr; gap: 22px; }
}

/* ---------- Left summary panel ---------- */
.ku-hp-reviews-summary {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding-right: 8px;
}
.ku-hpr-label {
    display: inline-flex;
    align-items: center;
    font-size: 30px;
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.4px;
    color: var(--ku-hpr-ink);
}
.ku-hpr-score {
    font-size: 15px;
    color: var(--ku-hpr-muted);
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.ku-hpr-score strong {
    color: var(--ku-hpr-ink);
    font-weight: 700;
}
.ku-hpr-dot { color: var(--ku-hpr-muted); }
/* ---------- Stars (square Trustpilot style) ---------- */
.ku-hpr-stars {
    position: relative;
    display: inline-flex;
    vertical-align: middle;
    line-height: 0;
    --ku-hpr-star-size: 28px;
}
.ku-hpr-star-row {
    display: inline-flex;
    gap: 3px;
    line-height: 0;
}
.ku-hpr-star-row-fill {
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
    white-space: nowrap;
}
.ku-hpr-star-cell {
    display: inline-flex;
    width: var(--ku-hpr-star-size);
    height: var(--ku-hpr-star-size);
    padding: 3px;
    box-sizing: content-box;
    background: #dcdce6;
    border-radius: 2px;
    line-height: 0;
}
.ku-hpr-star-row-fill .ku-hpr-star-cell { background: var(--ku-hpr-green); }
.ku-hpr-star-cell svg { width: 100%; height: 100%; display: block; }

/* ---------- Right: slider wrapper ---------- */
.ku-hp-reviews-slider-wrap {
    position: relative;
    min-width: 0;
}
.ku-hp-reviews-slider-wrap .cr-reviews-slider {
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

/* Override the plugin's inline wrapper color — only on the outer slider,
   NOT on the card inner (the card needs its own visible border). */
.ku-hp-reviews-slider-wrap .cr-reviews-slider {
    background-color: transparent !important;
    border-color: transparent !important;
}

/* Card shell */
.ku-hp-reviews-slider-wrap .cr-review-card {
    padding: 0 10px !important;
    box-sizing: border-box;
}
/* Card outline — darker than the Trustpilot stock, matches the screenshot. */
.ku-hp-reviews-slider-wrap .cr-reviews-slider .cr-review-card-inner,
.ku-hp-reviews-slider-wrap .cr-review-card-inner {
    background: #fff !important;
    border: 1px solid #b0b7bd !important;
    border-radius: 12px !important;
    padding: 14px 18px 12px !important;
    box-shadow: 0 2px 10px rgba(25,25,25,0.05);
    display: flex;
    flex-direction: column;
    gap: 6px;
}

/* Top row: (plugin outputs avatar + reviewer block). We hide duplicate avatar — our layout puts it at bottom-left like Trustpilot. */
.ku-hp-reviews-slider-wrap .cr-review-card .top-row {
    order: 5; /* push the reviewer block (which contains name + verified) to the bottom */
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: auto;
    padding-top: 8px;
    border-top: 1px solid var(--ku-hpr-line);
}
.ku-hp-reviews-slider-wrap .cr-review-card .review-thumbnail {
    flex: 0 0 32px;
    width: 32px;
    height: 32px;
    margin: 0 !important;
    padding: 0 !important;
}
.ku-hp-reviews-slider-wrap .cr-review-card .review-thumbnail img,
.ku-hp-reviews-slider-wrap .cr-review-card .review-thumbnail .ku-hpr-initials {
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    object-fit: cover;
    border: 1px solid var(--ku-hpr-line);
    box-shadow: none;
    display: block;
}
.ku-hp-reviews-slider-wrap .cr-review-card .review-thumbnail .ku-hpr-initials {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.3px;
    border: none;
}

.ku-hp-reviews-slider-wrap .cr-review-card .reviewer {
    min-width: 0;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.ku-hp-reviews-slider-wrap .cr-review-card .reviewer-name {
    font-size: 13px !important;
    font-weight: 700 !important;
    color: var(--ku-hpr-ink) !important;
    line-height: 1.2;
    letter-spacing: -0.1px;
    display: flex;
    align-items: center;
    gap: 6px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ku-hp-reviews-slider-wrap .cr-review-card .reviewer-name img.ivole-grid-country-icon {
    width: 14px !important;
    height: 10px !important;
    border-radius: 1px;
}
.ku-hp-reviews-slider-wrap .cr-review-card .reviewer-verified {
    font-size: 11px;
    color: var(--ku-hpr-green);
    font-weight: 600;
    letter-spacing: 0.2px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
}
.ku-hp-reviews-slider-wrap .cr-review-card .reviewer-verified img.cr-reviewer-verified {
    display: none !important;
}
.ku-hp-reviews-slider-wrap .cr-review-card .reviewer-verified::before {
    content: '';
    display: inline-block;
    width: 12px;
    height: 12px;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2300b67a'><path d='M12 2a10 10 0 1 0 10 10A10.01 10.01 0 0 0 12 2zm-1 14.5l-4.5-4.5 1.41-1.41L11 13.67l6.59-6.59L19 8.5z'/></svg>");
    background-size: contain;
    background-repeat: no-repeat;
}

/* Rating row + date — move date to the top row, right side, like Trustpilot */
.ku-hp-reviews-slider-wrap .cr-review-card .rating-row {
    order: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin: 0 !important;
    padding: 0 !important;
}
.ku-hp-reviews-slider-wrap .cr-review-card .rating-row .rating { order: 1; }
.ku-hp-reviews-slider-wrap .cr-review-card .rating-row .rating-label { display: none !important; } /* "5/5" text duplicated with stars */

/* Date lives inside middle-row .datetime — pull it out visually */
.ku-hp-reviews-slider-wrap .cr-review-card .middle-row {
    order: 3;
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1 1 auto;
}
.ku-hp-reviews-slider-wrap .cr-review-card .middle-row .datetime {
    order: -1;
    font-size: 11px;
    color: var(--ku-hpr-muted);
    font-weight: 500;
    margin-top: -2px;
}

/* Trustpilot-look star squares inside the card */
.ku-hp-reviews-slider-wrap .cr-review-card .crstar-rating-svg {
    position: relative;
    display: inline-flex;
    line-height: 0;
    vertical-align: middle;
    margin: 0 !important;
}
.ku-hp-reviews-slider-wrap .cr-review-card .crstar-rating-svg .cr-rating-icon-base,
.ku-hp-reviews-slider-wrap .cr-review-card .crstar-rating-svg .cr-rating-icon-frnt {
    display: inline-flex;
    gap: 3px;
    line-height: 0;
}
.ku-hp-reviews-slider-wrap .cr-review-card .crstar-rating-svg .cr-rating-icon-frnt {
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
    white-space: nowrap;
}
.ku-hp-reviews-slider-wrap .cr-review-card .crstar-rating-svg svg {
    width: 16px !important;
    height: 16px !important;
    padding: 2px !important;
    box-sizing: content-box !important;
    display: block !important;
    border-radius: 0;
}
.ku-hp-reviews-slider-wrap .cr-review-card .crstar-rating-svg .cr-rating-icon-base svg { background: #dcdce6; }
.ku-hp-reviews-slider-wrap .cr-review-card .crstar-rating-svg .cr-rating-icon-frnt svg { background: var(--ku-hpr-green); }
.ku-hp-reviews-slider-wrap .cr-review-card .crstar-rating-svg svg path:last-child {
    fill: #fff !important;
    stroke: none !important;
}
.ku-hp-reviews-slider-wrap .cr-review-card .crstar-rating-svg svg path:first-child { fill: none !important; }

/* Review title */
.ku-hp-reviews-slider-wrap .cr-review-card .cr-comment-head-text {
    order: 2;
    font-size: 14px;
    font-weight: 700;
    color: var(--ku-hpr-ink);
    line-height: 1.25;
    margin: 0 !important;
    letter-spacing: -0.1px;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Review text — clamp to 3 lines so cards stay compact/horizontal */
.ku-hp-reviews-slider-wrap .cr-review-card .review-content,
.ku-hp-reviews-slider-wrap .cr-review-card .review-text {
    font-size: 13px;
    line-height: 1.45;
    color: var(--ku-hpr-ink);
    margin: 0 !important;
    padding: 0 !important;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.ku-hp-reviews-slider-wrap .cr-review-card .review-text p {
    margin: 0 !important;
    color: inherit;
}

/* Hide product attribution, incentivized rows, verified-badge row on the homepage */
.ku-hp-reviews-slider-wrap .cr-review-card .review-product,
.ku-hp-reviews-slider-wrap .cr-review-card .cr-incentivized-row,
.ku-hp-reviews-slider-wrap .cr-review-card .verified-review-row { display: none !important; }

/* ---------- Slick nav — green arrows outside the track ---------- */
/* Give the card's bottom border + shadow room to render inside .slick-list's clip box.
   box-sizing:content-box is critical: Slick sets .slick-list { height: <slide outerHeight> }
   inline when adaptiveHeight + slidesToShow:1 (mobile). With border-box, the padding is
   subtracted from that height and the slide's bottom border gets clipped. */
.ku-hp-reviews-slider-wrap .slick-list {
    padding: 4px 0 14px !important;
    overflow: hidden;
    box-sizing: content-box !important;
}
.ku-hp-reviews-slider-wrap .slick-prev,
.ku-hp-reviews-slider-wrap .slick-next {
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    background: #fff !important;
    border: 1px solid var(--ku-hpr-line) !important;
    box-shadow: 0 2px 8px rgba(25,25,25,0.06) !important;
    z-index: 2 !important;
    top: 50% !important;
    transform: translateY(-50%);
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    transition: border-color .15s ease, background .15s ease, color .15s ease;
}
.ku-hp-reviews-slider-wrap .slick-prev { left: -44px !important; }
.ku-hp-reviews-slider-wrap .slick-next { right: -44px !important; }
.ku-hp-reviews-slider-wrap .slick-prev::before,
.ku-hp-reviews-slider-wrap .slick-next::before {
    font-family: inherit !important;
    font-size: 20px !important;
    line-height: 1 !important;
    color: var(--ku-hpr-ink) !important;
    opacity: 1 !important;
    content: '' !important;
    width: 10px;
    height: 10px;
    border-top: 2px solid currentColor;
    border-right: 2px solid currentColor;
    display: inline-block;
    vertical-align: middle;
}
.ku-hp-reviews-slider-wrap .slick-prev::before { transform: rotate(-135deg); margin-left: 4px; }
.ku-hp-reviews-slider-wrap .slick-next::before { transform: rotate(45deg);   margin-right: 4px; }
.ku-hp-reviews-slider-wrap .slick-prev:hover,
.ku-hp-reviews-slider-wrap .slick-next:hover {
    border-color: var(--ku-hpr-green) !important;
    color: var(--ku-hpr-green) !important;
    background: #fff !important;
}
.ku-hp-reviews-slider-wrap .slick-prev:hover::before,
.ku-hp-reviews-slider-wrap .slick-next:hover::before { color: var(--ku-hpr-green) !important; }

/* Dots */
.ku-hp-reviews-slider-wrap .slick-dots { bottom: -30px !important; }
.ku-hp-reviews-slider-wrap .slick-dots li button:before {
    font-size: 10px !important;
    color: var(--ku-hpr-line-strong) !important;
    opacity: 1 !important;
}
.ku-hp-reviews-slider-wrap .slick-dots li.slick-active button:before {
    color: var(--ku-hpr-green) !important;
    opacity: 1 !important;
}

/* ---------- Responsive ---------- */
@media (max-width: 1200px) {
    .ku-hp-reviews-slider-wrap .slick-prev { left: 4px !important; }
    .ku-hp-reviews-slider-wrap .slick-next { right: 4px !important; }
}
@media (max-width: 900px) {
    .ku-hp-reviews { padding: 28px 16px 36px; }
    .ku-hp-reviews-summary { padding-right: 0; align-items: flex-start; }
    .ku-hpr-label { font-size: 24px; }
    .ku-hp-reviews-slider-wrap .cr-review-card-inner { padding: 14px 16px 12px !important; }
}

/* ---------- Mobile stacked layout (screenshot) ---------- */
@media (max-width: 640px) {
    /* Tight band below the card for the nav arrows (arrows end ~28px below the slider). */
    .ku-hp-reviews { padding: 20px 16px 30px; }
    .ku-hp-reviews-inner { gap: 14px; }

    /* Slick list already reserves room at the bottom — collapse it on mobile. */
    .ku-hp-reviews-slider-wrap .slick-list { padding: 2px 0 4px !important; }

    /* Summary panel — centered above the carousel */
    .ku-hp-reviews-summary {
        align-items: center !important;
        text-align: center;
        gap: 8px;
    }
    .ku-hpr-label { font-size: 22px; }
    .ku-hpr-score { justify-content: center; }

    /* Carousel text sizes */
    .ku-hp-reviews-slider-wrap .cr-review-card .cr-comment-head-text { font-size: 13.5px; }
    .ku-hp-reviews-slider-wrap .cr-review-card .review-text { font-size: 12.5px; }

    /* Nav arrows: move under the card, centered side-by-side.
       Slick's built-in <450px breakpoint hides them, so force them visible. */
    .ku-hp-reviews-slider-wrap .slick-prev,
    .ku-hp-reviews-slider-wrap .slick-next {
        display: flex !important;
        top: auto !important;
        bottom: -28px !important;
        transform: none !important;
        width: 30px !important;
        height: 30px !important;
    }
    .ku-hp-reviews-slider-wrap .slick-prev { left: calc(50% - 36px) !important; right: auto !important; }
    .ku-hp-reviews-slider-wrap .slick-next { left: calc(50% + 6px) !important; right: auto !important; }

    /* Dots duplicate the arrows on this layout — hide them */
    .ku-hp-reviews-slider-wrap .slick-dots { display: none !important; }
}

/* ===== Katana Homepage Recent Posts ===== */
.katana-hrp{
	background: #0a0a0a;
	background: linear-gradient(180deg, #0a0a0a 0%, #141414 100%);
	color: #f4f4f4;
	padding: 72px 20px 88px;
	box-sizing: border-box;
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", Helvetica, Arial, sans-serif;
}
.katana-hrp *,
.katana-hrp *::before,
.katana-hrp *::after{
	box-sizing: border-box;
}
.katana-hrp__inner{
	max-width: 1200px;
	margin: 0 auto;
}
.katana-hrp__header{
	text-align: center;
	margin: 0 0 48px;
}
.katana-hrp__title{
	color: #ffffff;
	font-size: clamp(26px, 3.2vw, 38px);
	font-weight: 800;
	letter-spacing: -0.01em;
	margin: 0 0 12px;
	line-height: 1.15;
	text-transform: none;
}
.katana-hrp__title-underline{
	display: inline-block;
	width: 56px;
	height: 3px;
	background: linear-gradient(90deg, transparent, #e5c071 20%, #e5c071 80%, transparent);
	border-radius: 2px;
}
.katana-hrp__grid{
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 22px;
}
.katana-hrp__grid[data-count="3"]{
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 28px;
}
.katana-hrp__grid[data-count="2"]{
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 28px;
	max-width: 820px;
	margin-left: auto;
	margin-right: auto;
}
.katana-hrp__grid[data-count="1"]{
	grid-template-columns: minmax(0, 1fr);
	max-width: 420px;
	margin-left: auto;
	margin-right: auto;
}
@media (max-width: 1100px){
	.katana-hrp__grid,
	.katana-hrp__grid[data-count="3"]{ grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; }
	.katana-hrp__grid[data-count="3"] > .katana-hrp__card:nth-child(3){ grid-column: 1 / -1; max-width: 520px; margin: 0 auto; }
}
@media (max-width: 640px){
	.katana-hrp{ padding: 56px 18px 64px; }
	.katana-hrp__grid,
	.katana-hrp__grid[data-count="3"],
	.katana-hrp__grid[data-count="2"],
	.katana-hrp__grid[data-count="1"]{ grid-template-columns: 1fr; gap: 22px; max-width: none; }
	.katana-hrp__grid[data-count="3"] > .katana-hrp__card:nth-child(3){ max-width: none; margin: 0; }
	.katana-hrp__header{ margin-bottom: 32px; }
}

.katana-hrp__card{
	background: #17181c;
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: 14px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform .35s ease, border-color .35s ease, box-shadow .35s ease;
	box-shadow: 0 4px 16px rgba(0,0,0,0.35);
}
.katana-hrp__card:hover{
	transform: translateY(-4px);
	border-color: rgba(229, 192, 113, 0.55);
	box-shadow: 0 10px 32px rgba(0,0,0,0.6), 0 0 0 1px rgba(229, 192, 113, 0.15);
}

.katana-hrp__media{
	position: relative;
	display: block;
	width: 100%;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	text-decoration: none;
}
.katana-hrp__img{
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	transform: scale(1.02);
	transition: transform .6s ease;
}
.katana-hrp__img--placeholder{
	background: linear-gradient(135deg, #1f1f24 0%, #2a2a30 50%, #1f1f24 100%);
}
.katana-hrp__card:hover .katana-hrp__img{
	transform: scale(1.08);
}
.katana-hrp__media::after{
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,0.55) 100%);
	pointer-events: none;
}
.katana-hrp__cat{
	position: absolute;
	top: 14px;
	left: 14px;
	z-index: 2;
	display: inline-block;
	padding: 4px 10px;
	border-radius: 999px;
	background: rgba(229, 192, 113, 0.92);
	color: #111;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	backdrop-filter: blur(6px);
}

.katana-hrp__body{
	padding: 22px 22px 24px;
	display: flex;
	flex-direction: column;
	flex: 1;
}
.katana-hrp__meta{
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px;
	font-size: 12.5px;
	color: #9a9ba1;
	margin: 0 0 10px;
	text-transform: none;
	letter-spacing: 0.02em;
}
.katana-hrp__dot{ opacity: 0.55; }
.katana-hrp__post-title{
	margin: 0 0 10px;
	font-size: 19px;
	font-weight: 700;
	line-height: 1.35;
	letter-spacing: -0.005em;
}
.katana-hrp__post-title a{
	color: #ffffff;
	text-decoration: none;
	background-image: linear-gradient(currentColor, currentColor);
	background-size: 0% 1px;
	background-repeat: no-repeat;
	background-position: 0 100%;
	transition: color .25s ease, background-size .35s ease;
}
.katana-hrp__post-title a:hover{
	color: #e5c071;
	background-size: 100% 1px;
}
.katana-hrp__excerpt{
	margin: 0 0 18px;
	color: #b9bac0;
	font-size: 14px;
	line-height: 1.6;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.katana-hrp__cta{
	margin-top: auto;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 9px 14px;
	border-radius: 8px;
	background: transparent;
	color: #e5c071;
	border: 1px solid rgba(229, 192, 113, 0.45);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.02em;
	text-decoration: none;
	align-self: flex-start;
	transition: background .25s ease, border-color .25s ease, color .25s ease, transform .25s ease;
}
.katana-hrp__cta-arrow{
	transition: transform .25s ease;
}
.katana-hrp__cta:hover{
	background: rgba(229, 192, 113, 0.12);
	border-color: rgba(229, 192, 113, 0.85);
	color: #ffd990;
}
.katana-hrp__cta:hover .katana-hrp__cta-arrow{
	transform: translateX(3px);
}

.katana-hrp__footer{
	text-align: center;
	margin-top: 48px;
}
.katana-hrp__view-all{
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 22px;
	background: transparent;
	border: 1px solid rgba(255,255,255,0.25);
	border-radius: 999px;
	color: #ffffff;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.03em;
	text-decoration: none;
	transition: background .25s ease, border-color .25s ease, transform .25s ease;
}
.katana-hrp__view-all:hover{
	background: rgba(229, 192, 113, 0.12);
	border-color: rgba(229, 192, 113, 0.85);
	color: #ffd990;
}
.katana-hrp__view-all svg{
	transition: transform .25s ease;
}
.katana-hrp__view-all:hover svg{
	transform: translateX(3px);
}

/* Kill Elementor/theme heading defaults that would hijack colors. */
.katana-hrp h2.katana-hrp__title,
.katana-hrp h3.katana-hrp__post-title{
	color: inherit;
	font-family: inherit;
}
.katana-hrp a{
	box-shadow: none;
}
body.kl-landing-active .ku-hp-reviews {
	background: transparent !important;
	color: #f4f4f4 !important;
	padding: 36px 20px 36px !important;
}
body.kl-landing-active .ku-hp-reviews .ku-hpr-label { color: #ffffff !important; }
body.kl-landing-active .ku-hp-reviews .ku-hpr-score { color: #9a9ba1 !important; }
body.kl-landing-active .ku-hp-reviews .ku-hpr-score strong { color: #ffffff !important; }
body.kl-landing-active .ku-hp-reviews .ku-hpr-dot { color: #5a5b62 !important; }
body.kl-landing-active .ku-hp-reviews .ku-hpr-star-row-base .ku-hpr-star-cell { background: #2a2b30 !important; }
body.kl-landing-active .ku-hp-reviews .ku-hpr-star-row-fill .ku-hpr-star-cell { background: var(--ku-hpr-green, #00b67a) !important; }

body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-reviews-slider .cr-review-card-inner,
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card-inner,
body.kl-landing-active .ku-hp-reviews-slider-wrap .cr-reviews-slider .cr-review-card-inner,
body.kl-landing-active .ku-hp-reviews-slider-wrap .cr-review-card-inner,
body.kl-landing-active .ku-hp-reviews .cr-review-card-inner[style],
body.kl-landing-active .ku-hp-reviews-slider-wrap .cr-review-card-inner[style*="background"] {
	background: #17181c !important;
	background-color: #17181c !important;
	border: 1px solid rgba(255, 255, 255, 0.08) !important;
	border-color: rgba(255, 255, 255, 0.08) !important;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.35) !important;
}

body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .middle-row,
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .review-content,
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .review-text,
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .review-text p,
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .review-content p,
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .cr-slider-details {
	background: #17181c !important;
	background-color: #17181c !important;
	background-image: none !important;
}

body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .reviewer-name { color: #ffffff !important; }
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .top-row { border-top-color: rgba(255, 255, 255, 0.12) !important; }
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .cr-comment-head-text { color: #ffffff !important; }
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .review-content,
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .review-text,
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .review-text p,
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .review-content p { color: #ffffff !important; }
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .middle-row .datetime { color: #c8c9cf !important; }
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .review-thumbnail img {
	border: 1px solid rgba(255, 255, 255, 0.08) !important;
}
body.kl-landing-active .ku-hp-reviews .ku-hp-reviews-slider-wrap .cr-review-card .crstar-rating-svg .cr-rating-icon-base svg {
	background: #2a2b30 !important;
}
body.kl-landing-active .ku-hp-reviews-slider-wrap .slick-prev,
body.kl-landing-active .ku-hp-reviews-slider-wrap .slick-next {
	background: #17181c !important;
	border: 1px solid rgba(255, 255, 255, 0.18) !important;
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.45) !important;
}
body.kl-landing-active .ku-hp-reviews-slider-wrap .slick-prev::before,
body.kl-landing-active .ku-hp-reviews-slider-wrap .slick-next::before { color: #ffffff !important; }
body.kl-landing-active .ku-hp-reviews-slider-wrap .slick-prev:hover,
body.kl-landing-active .ku-hp-reviews-slider-wrap .slick-next:hover {
	background: #1d1e23 !important;
	border-color: rgba(229, 192, 113, 0.55) !important;
	color: #e5c071 !important;
}
body.kl-landing-active .ku-hp-reviews-slider-wrap .slick-prev:hover::before,
body.kl-landing-active .ku-hp-reviews-slider-wrap .slick-next:hover::before { color: #e5c071 !important; }
body.kl-landing-active .ku-hp-reviews-slider-wrap .slick-dots li button:before { color: rgba(255, 255, 255, 0.25) !important; }
body.kl-landing-active .ku-hp-reviews-slider-wrap .slick-dots li.slick-active button:before { color: #e5c071 !important; }

body.kl-landing-active .kl-reviews-wrap { padding: 16px 0 0; border-bottom: 1px solid rgba(255,255,255,0.06); }
body.kl-landing-active .kl-recent-posts-wrap { padding: 0; }
body.kl-landing-active .kl-recent-posts-wrap .katana-hrp { background: transparent !important; padding: 48px 20px 48px !important; }
@media (max-width: 640px) {
	body.kl-landing-active .kl-recent-posts-wrap .katana-hrp { padding: 36px 16px !important; }
}
body.kl-landing-active #katana-hrp-staging { display: none !important; }

/* Reviews carousel mobile guard.
 *
 * On mobile, Slick.js sometimes initializes the cusrev slider while the
 * landing's full-bleed parent is still being measured, which leaves
 * .cr-review-card with a near-zero width inline style and the cards
 * collapse to ~30 px wide (text wraps to one character per line).
 *
 * The fix has two parts:
 *   1. Force a sane minimum width on each card so even if Slick miscomputes
 *      its width, cards still take up the full mobile viewport.
 *   2. Override Slick's inline width for .slick-slide and .cr-review-card
 *      using `width: auto` + `min-width` — the slider track flexes
 *      naturally and the cards stay readable.
 *
 * The slick-track is also given `display: flex` so the cards sit in a
 * row and Slick's transform scrolling keeps working.
 */
@media (max-width: 900px) {
	/* Section: zero L+R padding so the slider bleeds to the screen edges. */
	body.kl-landing-active .ku-hp-reviews { padding: 24px 0 28px !important; }
	body.kl-landing-active .ku-hp-reviews-slider-wrap { width: 100%; max-width: 100%; }
	body.kl-landing-active .ku-hp-reviews-slider-wrap .cr-reviews-slider { width: 100%; max-width: 100%; }

	/* Drop cusrev's per-card 10 px gutter and the Slick list's stock padding
	 * so the slide track runs flush with the section. */
	body.kl-landing-active .ku-hp-reviews-slider-wrap .cr-review-card { padding: 0 !important; }
	body.kl-landing-active .ku-hp-reviews-slider-wrap .slick-list {
		overflow: hidden !important;
		width: 100% !important;
		padding: 0 !important;
		margin: 0 !important;
	}
	body.kl-landing-active .ku-hp-reviews-slider-wrap .slick-track { display: flex !important; }

	/* Each slide takes the full viewport width (no inner margin from
	 * Slick / cusrev). The visual card padding is provided by the
	 * .cr-review-card-inner margin below — same edge-to-edge bleed
	 * treatment as the product carousel above. */
	body.kl-landing-active .ku-hp-reviews-slider-wrap .slick-slide,
	body.kl-landing-active .ku-hp-reviews-slider-wrap .cr-review-card {
		min-width: 100vw !important;
		max-width: 100vw !important;
		width: 100vw !important;
		flex: 0 0 100vw !important;
		box-sizing: border-box !important;
	}

	/* Card inner: 16 px symmetric breathing room from each screen edge. */
	body.kl-landing-active .ku-hp-reviews-slider-wrap .cr-review-card-inner {
		margin: 0 16px !important;
		max-width: calc(100% - 32px) !important;
		min-height: 180px;
	}
}