/* =========================================================================
   KeepSeal Neo — single product (gallery, header, buy box, sticky cart)
   Light & dark via tokens. Performance-minded (no per-element filters).
   ========================================================================= */
.ksn-product-note {
	padding: 16px;
	border: 1px dashed var(--ksn-line);
	border-radius: var(--ksn-radius);
	color: var(--ksn-muted);
	text-align: center;
}


/* =========================================================================
   Gallery (ksn-gal) — single flex-centred image. Cannot be off-centre.
   ========================================================================= */
.ksn-gal {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 14px;
	width: 100%;
	max-width: 100%;
}
.ksn-gal__stage { position: relative; width: 100%; min-width: 0; }

.ksn-gal--thumbs-right { grid-template-columns: minmax(0, 1fr) 90px; }
.ksn-gal--thumbs-left  { grid-template-columns: 90px minmax(0, 1fr); }
.ksn-gal--thumbs-left  .ksn-gal__stage  { order: 2; }
.ksn-gal--thumbs-left  .ksn-gal__thumbs { order: 1; }

/* viewport: a square that flex-centres the single image */
.ksn-gal__viewport {
	position: relative;
	width: 100%;
	aspect-ratio: 1 / 1;
	display: flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	padding: 18px;
	overflow: hidden;
	background: var(--ksn-surface-2);
}
.ksn-gal__img {
	display: block !important;
	max-width: 100% !important;
	max-height: 100% !important;
	width: auto !important;
	height: auto !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	object-fit: contain;
	user-select: none;
	transition: opacity .3s ease, transform .4s cubic-bezier(.16,1,.3,1);
}
.ksn-gal.is-changing .ksn-gal__img { opacity: 0; }
.ksn-gal--trans-zoom.is-changing  .ksn-gal__img { transform: scale(.92); }
.ksn-gal--trans-slide.is-changing .ksn-gal__img { transform: translateX(7%); }
[dir="rtl"] .ksn-gal--trans-slide.is-changing .ksn-gal__img { transform: translateX(-7%); }

.ksn-gal--zoom .ksn-gal__viewport:hover { cursor: zoom-in; }
.ksn-gal--zoom .ksn-gal__viewport.is-zooming .ksn-gal__img { transform: scale(1.9); transition: transform .15s ease; }

/* frame styles */
.ksn-gal--frame-soft .ksn-gal__viewport { border-radius: calc(var(--ksn-radius) + 10px); box-shadow: 0 30px 60px -34px rgba(13,27,52,.5); }
.ksn-gal--frame-bordered .ksn-gal__viewport { border-radius: calc(var(--ksn-radius) + 6px); border: 1px solid var(--ksn-line); }
.ksn-gal--frame-minimal .ksn-gal__viewport { border-radius: var(--ksn-radius); background: transparent; }
.ksn-gal--frame-glass .ksn-gal__viewport {
	border-radius: calc(var(--ksn-radius) + 10px);
	border: 1px solid rgba(255,255,255,.25);
	background: color-mix(in srgb, var(--ksn-surface) 60%, transparent);
	backdrop-filter: blur(10px);
}
.ksn-gal--frame-stamp .ksn-gal__viewport {
	border-top: 3px solid var(--ksn-heat);
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 30px), calc(100% - 30px) 100%, 0 100%);
}
.ksn-gal--frame-stamp .ksn-gal__stage { filter: drop-shadow(0 14px 26px rgba(13,27,52,.18)); }
.ksn-dark .ksn-gal--frame-stamp .ksn-gal__stage,
html.ksn-dark .ksn-gal--frame-stamp .ksn-gal__stage { filter: drop-shadow(0 16px 28px rgba(0,0,0,.55)); }
.ksn-gal--frame-boxed {
	background: var(--ksn-surface);
	border: 1px solid var(--ksn-line);
	border-radius: calc(var(--ksn-radius) + 12px);
	padding: 16px;
	box-shadow: 0 26px 54px -36px rgba(13,27,52,.4);
}
.ksn-gal--frame-boxed .ksn-gal__viewport { background: transparent; border-radius: var(--ksn-radius); }
.ksn-gal--frame-boxed .ksn-gal__thumb { border-color: transparent; background: transparent; opacity: .55; }
.ksn-gal--frame-boxed .ksn-gal__thumb.is-active,
.ksn-gal--frame-boxed .ksn-gal__thumb:hover { opacity: 1; }
.ksn-gal--frame-boxed .ksn-gal__thumb.is-active { border-color: var(--ksn-heat); }

/* nav / expand / badge / dots */
.ksn-gal__nav {
	position: absolute; top: 50%; transform: translateY(-50%); z-index: 4;
	width: 44px; height: 44px; display: grid; place-items: center;
	border: none; border-radius: 50%;
	background: var(--ksn-surface); color: var(--ksn-ink);
	box-shadow: 0 8px 20px -8px rgba(13,27,52,.45);
	cursor: pointer; opacity: 0;
	transition: opacity .25s ease, background .15s ease, color .15s ease;
}
.ksn-gal__stage:hover .ksn-gal__nav { opacity: 1; }
.ksn-gal__nav:hover { background: var(--ksn-primary); color: #fff; }
.ksn-gal__nav--prev { inset-inline-start: 12px; }
.ksn-gal__nav--next { inset-inline-end: 12px; }

.ksn-gal__expand {
	position: absolute; top: 12px; inset-inline-end: 12px; z-index: 4;
	width: 42px; height: 42px; display: grid; place-items: center;
	border: none; border-radius: 13px;
	background: var(--ksn-surface); color: var(--ksn-ink);
	box-shadow: 0 6px 16px -8px rgba(13,27,52,.4);
	cursor: pointer; transition: color .15s ease, transform .15s ease;
}
.ksn-gal__expand:hover { color: var(--ksn-accent); transform: scale(1.08); }

.ksn-gal__badge {
	position: absolute; top: 12px; inset-inline-start: 12px; z-index: 4;
	padding: 6px 14px; border-radius: 999px;
	background: var(--ksn-accent); color: #fff;
	font-weight: 900; font-size: 0.85rem;
	box-shadow: 0 8px 18px -8px rgba(var(--ksn-accent-rgb), .6);
}

.ksn-gal__dots {
	position: absolute; bottom: 12px; inset-inline: 0; z-index: 3;
	display: flex; justify-content: center; gap: 7px;
}
.ksn-gal__dot { width: 7px; height: 7px; border-radius: 999px; background: rgba(var(--ksn-primary-rgb), .35); transition: width .25s ease, background .25s ease; }
.ksn-gal__dot.is-active { width: 22px; background: var(--ksn-heat); }

/* thumbnails */
.ksn-gal__thumbs {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: 76px;
	gap: 10px;
	overflow-x: auto;
	overflow-y: hidden;
	scrollbar-width: thin;
}
.ksn-gal--thumbs-right .ksn-gal__thumbs,
.ksn-gal--thumbs-left .ksn-gal__thumbs {
	grid-auto-flow: row;
	grid-auto-columns: auto;
	overflow-x: hidden;
	overflow-y: auto;
}
.ksn-gal__thumb {
	border: 2px solid var(--ksn-line);
	border-radius: 12px;
	overflow: hidden;
	background: var(--ksn-surface);
	cursor: pointer;
	padding: 0;
	aspect-ratio: 1;
	transition: border-color .18s ease, transform .18s ease, box-shadow .18s ease;
}
.ksn-gal--thumb-circle .ksn-gal__thumb { border-radius: 50%; }
.ksn-gal--thumb-square .ksn-gal__thumb { border-radius: 4px; }
.ksn-gal__thumb img {
	width: 100% !important; height: 100% !important; max-width: none !important;
	object-fit: cover; display: block !important; float: none !important; margin: 0 !important;
}
.ksn-gal__thumb:hover { transform: translateY(-3px); }
.ksn-gal__thumb.is-active { border-color: var(--ksn-primary); box-shadow: 0 0 0 3px rgba(var(--ksn-primary-rgb), .18); }

/* mobile */
@media (max-width: 768px) {
	.ksn-gal--thumbs-right,
	.ksn-gal--thumbs-left { grid-template-columns: minmax(0, 1fr); }
	.ksn-gal--thumbs-left .ksn-gal__stage { order: 0; }
	.ksn-gal--thumbs-left .ksn-gal__thumbs { order: 2; }
	.ksn-gal--thumbs-right .ksn-gal__thumbs,
	.ksn-gal--thumbs-left .ksn-gal__thumbs {
		grid-auto-flow: column; grid-auto-columns: 60px; overflow-x: auto; overflow-y: hidden;
	}
	.ksn-gal__viewport { padding: 10px; touch-action: pan-y; }
	.ksn-gal--frame-boxed { padding: 10px; }
	.ksn-gal__nav { opacity: 1; width: 38px; height: 38px; }
	.ksn-gal__nav--prev { inset-inline-start: 8px; }
	.ksn-gal__nav--next { inset-inline-end: 8px; }
	.ksn-gal__expand { width: 38px; height: 38px; top: 8px; inset-inline-end: 8px; }
	.ksn-gal__badge { top: 8px; inset-inline-start: 8px; }
	.ksn-gal__stage { cursor: grab; }
}
@media (max-width: 420px) {
	.ksn-gal__thumbs { grid-auto-columns: 52px; }
}

/* =========================================================================
   Lightbox (animated)
   ========================================================================= */
.ksn-lightbox {
	position: fixed; inset: 0; z-index: 99999;
	display: grid; place-items: center;
	background: rgba(5, 12, 26, .92);
	padding: 24px; opacity: 0;
	transition: opacity .3s ease;
}
.ksn-lightbox.is-open { opacity: 1; }
.ksn-lightbox__img {
	max-width: 92vw; max-height: 84vh; object-fit: contain;
	border-radius: 10px; transform: scale(.9);
	transition: transform .35s cubic-bezier(.16,1,.3,1);
	user-select: none;
}
.ksn-lightbox.is-open .ksn-lightbox__img { transform: scale(1); }
.ksn-lightbox__close,
.ksn-lightbox__lnav {
	position: absolute; width: 52px; height: 52px;
	display: grid; place-items: center;
	border: none; border-radius: 50%;
	background: rgba(255,255,255,.12); color: #fff;
	cursor: pointer; transition: background .15s ease, transform .15s ease;
}
.ksn-lightbox__close { top: 20px; inset-inline-end: 20px; font-size: 26px; }
.ksn-lightbox__close:hover,
.ksn-lightbox__lnav:hover { background: rgba(255,255,255,.25); transform: scale(1.08); }
.ksn-lightbox__lnav { top: 50%; transform: translateY(-50%); }
.ksn-lightbox__lnav--prev { inset-inline-start: 20px; }
.ksn-lightbox__lnav--next { inset-inline-end: 20px; }
.ksn-lightbox__counter { position: absolute; bottom: 22px; inset-inline: 0; text-align: center; color: rgba(255,255,255,.75); font-weight: 700; font-size: 0.9rem; }
@media (prefers-reduced-motion: reduce) {
	.ksn-gal__img, .ksn-lightbox, .ksn-lightbox__img { transition: none !important; }
}

/* =========================================================================
   Product header
   ========================================================================= */
.ksn-phead__cat {
	display: inline-flex; align-items: center; gap: 8px;
	font-size: 0.85rem; font-weight: 800;
	color: var(--ksn-accent); text-decoration: none;
	margin-bottom: 10px;
}
.ksn-phead__title { font-size: clamp(1.5rem, 1.1rem + 1.6vw, 2.4rem); margin: 0 0 14px; color: var(--ksn-ink); }
.ksn-phead__rating { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.ksn-phead__rating .star-rating { color: var(--ksn-heat); }
.ksn-phead__reviews { font-size: 0.86rem; color: var(--ksn-muted); }
.ksn-phead__price { font-size: 1.6rem; font-weight: 900; color: var(--ksn-ink); margin-bottom: 14px; }
.ksn-phead__price del { color: var(--ksn-muted); font-weight: 500; font-size: 1.1rem; margin-inline-end: 8px; }
.ksn-phead__price ins { text-decoration: none; color: var(--ksn-accent); }
.ksn-phead__desc { color: var(--ksn-muted); line-height: 2; margin-bottom: 14px; }
.ksn-phead__meta { display: flex; flex-wrap: wrap; gap: 16px; font-size: 0.88rem; color: var(--ksn-muted); border-top: 1px solid var(--ksn-line); padding-top: 14px; }
.ksn-phead__meta b { color: var(--ksn-ink); }
.ksn-phead__meta a { color: var(--ksn-primary); text-decoration: none; }

/* rating & chips as inline-flex so the alignment control can centre them */
.ksn-phead__rating { display: inline-flex; }
.ksn-phead__chips { display: inline-flex; flex-wrap: wrap; gap: 8px; margin: 0 0 14px; }
.ksn-phead__chips .ksn-chip-tag {
	display: inline-flex; align-items: center;
	padding: 5px 13px;
	font-size: 0.8rem; font-weight: 600;
	color: var(--ksn-muted);
	background: var(--ksn-surface-2);
	border: 1px solid var(--ksn-line);
	border-radius: 999px; text-decoration: none;
	transition: color .15s ease, background .15s ease, border-color .15s ease, transform .15s ease;
}
.ksn-phead__chips .ksn-chip-tag:hover { color: #fff; background: var(--ksn-primary); border-color: transparent; transform: translateY(-1px); }

/* breadcrumb */
.ksn-phead__crumb { font-size: 0.8rem; color: var(--ksn-muted); margin-bottom: 12px; }
.ksn-phead__crumb a { color: var(--ksn-muted); text-decoration: none; }
.ksn-phead__crumb a:hover { color: var(--ksn-accent); }
.ksn-phead__crumb-sep { margin: 0 6px; opacity: .55; }

/* ---- header style variants ---- */
.ksn-phead--card {
	background: var(--ksn-surface);
	border: 1px solid var(--ksn-line);
	border-radius: calc(var(--ksn-radius) + 8px);
	box-shadow: var(--ksn-shadow);
	padding: clamp(20px, 3vw, 30px);
}
.ksn-phead--glass {
	background: color-mix(in srgb, var(--ksn-surface) 60%, transparent);
	border: 1px solid rgba(255,255,255,.22);
	border-radius: calc(var(--ksn-radius) + 8px);
	backdrop-filter: blur(12px) saturate(1.3);
	-webkit-backdrop-filter: blur(12px) saturate(1.3);
	padding: clamp(20px, 3vw, 30px);
}
.ksn-phead--bar {
	position: relative;
	background: var(--ksn-surface);
	border: 1px solid var(--ksn-line);
	border-radius: calc(var(--ksn-radius) + 8px);
	overflow: hidden;
	padding: clamp(22px, 3vw, 32px) clamp(20px, 3vw, 30px) clamp(20px, 3vw, 30px);
}
.ksn-phead--bar::before {
	content: "";
	position: absolute; inset: 0 0 auto 0; height: 4px;
	background: linear-gradient(90deg, var(--ksn-primary), var(--ksn-accent), var(--ksn-heat));
}
.ksn-phead--stamp {
	background: var(--ksn-surface);
	border-top: 3px solid var(--ksn-heat);
	padding: clamp(20px, 3vw, 30px);
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 28px), calc(100% - 28px) 100%, 0 100%);
	filter: drop-shadow(0 12px 22px rgba(13,27,52,.16));
}
.ksn-dark .ksn-phead--stamp, html.ksn-dark .ksn-phead--stamp { filter: drop-shadow(0 14px 24px rgba(0,0,0,.5)); }

/* =========================================================================
   Buy Box (ksn-bb) — rebuilt
   ========================================================================= */
.ksn-bb {
	--bb-accent: var(--ksn-primary);
	--bb-accent-rgb: var(--ksn-primary-rgb);
	padding: 0;
}
.ksn-bb--accent-accent  { --bb-accent: var(--ksn-accent); --bb-accent-rgb: var(--ksn-accent-rgb); }
.ksn-bb--accent-heat    { --bb-accent: var(--ksn-heat);   --bb-accent-rgb: var(--ksn-heat-rgb); }
.ksn-bb--accent-emerald { --bb-accent: #16c79a; --bb-accent-rgb: 22, 199, 154; }

/* ---- container styles ---- */
.ksn-bb--card {
	background: var(--ksn-surface);
	border: 1px solid var(--ksn-line);
	border-radius: calc(var(--ksn-radius) + 8px);
	box-shadow: var(--ksn-shadow);
	padding: 22px;
}
.ksn-bb--stamp {
	background: var(--ksn-surface);
	border-top: 3px solid var(--ksn-heat);
	padding: 22px;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 28px), calc(100% - 28px) 100%, 0 100%);
	filter: drop-shadow(0 12px 22px rgba(13,27,52,.16));
}
.ksn-dark .ksn-bb--stamp, html.ksn-dark .ksn-bb--stamp { filter: drop-shadow(0 14px 24px rgba(0,0,0,.5)); }
.ksn-bb--minimal { padding: 4px 0; }
.ksn-bb--minimal .ksn-bb__price { padding-bottom: 14px; border-bottom: 1px solid var(--ksn-line); }
.ksn-bb--blocks { background: transparent; padding: 0; }
.ksn-bb--blocks .ksn-bb__price,
.ksn-bb--blocks .ksa-addon-group {
	background: var(--ksn-surface);
	border: 1px solid var(--ksn-line);
	border-radius: 16px;
	padding: 16px 18px;
	margin: 0 0 14px;
}
.ksn-bb--blocks .ksn-bb__trust {
	background: var(--ksn-surface);
	border: 1px solid var(--ksn-line);
	border-radius: 16px;
	padding: 16px 18px;
	margin-top: 14px;
}

/* ---- price ---- */
.ksn-bb__price { font-size: 1.7rem; font-weight: 900; color: var(--ksn-ink); margin-bottom: 16px; }
.ksn-bb__price del { color: var(--ksn-muted); font-weight: 500; font-size: 1.1rem; margin-inline-end: 8px; }
.ksn-bb__price ins { text-decoration: none; color: var(--ksn-accent); }

/* ---- WooCommerce add-to-cart form — everything stacked vertically ---- */
.ksn-bb__form form.cart {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 14px;
	margin: 0;
}

/* quantity discount table (AIO .ksa-qd-table) — always at the top */
.ksn-bb .ksa-qd-table {
	width: 100% !important;
	border-collapse: separate !important;
	border-spacing: 0 !important;
	margin: 0 0 4px !important;
	font-size: 0.9rem !important;
	border-radius: 14px;
	overflow: hidden;
	border: 1px solid var(--ksn-line);
}
.ksn-bb .ksa-qd-table th,
.ksn-bb .ksa-qd-table td {
	border: none !important;
	border-bottom: 1px solid var(--ksn-line) !important;
	padding: 10px 12px !important;
	text-align: center !important;
	color: var(--ksn-ink);
}
.ksn-bb .ksa-qd-table thead {
	background: var(--ksn-primary) !important;
}
.ksn-bb .ksa-qd-table thead th { color: #fff !important; font-weight: 800 !important; }
.ksn-bb .ksa-qd-table tbody tr:nth-child(even) { background: var(--ksn-surface-2); }
.ksn-bb .ksa-qd-table tbody tr:last-child td { border-bottom: none !important; }

/* ---- quantity box: roomy (fits 6 digits), beautiful ---- */
.ksn-bb__form .quantity {
	display: flex;
	align-items: stretch;
	width: 100%;
	height: 56px;
	border: 1.5px solid var(--ksn-line);
	border-radius: 14px;
	overflow: hidden;
	background: var(--ksn-surface-2);
}
.ksn-bb__form .quantity .qty {
	flex: 1;
	min-width: 0;
	width: 100%;
	border: none;
	background: transparent;
	text-align: center;
	font-family: var(--ksn-font);
	font-weight: 800;
	font-size: 1.2rem;
	letter-spacing: .02em;
	color: var(--ksn-ink);
	-moz-appearance: textfield;
}
.ksn-bb__form .quantity .qty::-webkit-outer-spin-button,
.ksn-bb__form .quantity .qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.ksn-qty-btn {
	flex: none;
	width: 58px;
	border: none;
	background: transparent;
	color: var(--ksn-ink);
	font-size: 24px;
	cursor: pointer;
	transition: background .15s ease, color .15s ease;
}
.ksn-qty-btn:hover { background: rgba(var(--bb-accent-rgb), .12); color: var(--bb-accent); }
.ksn-qty-btn--minus { border-inline-end: 1px solid var(--ksn-line); }
.ksn-qty-btn--plus { border-inline-start: 1px solid var(--ksn-line); }

.ksn-bb__form .single_add_to_cart_button,
.ksn-bb__form button[type="submit"],
.ksn-bb__form button.button {
	flex: 0 0 auto;
	width: 100%;
	display: inline-flex; align-items: center; justify-content: center; gap: 8px;
	height: 56px; padding: 0 26px; margin-top: 4px;
	font-family: var(--ksn-font); font-weight: 900; font-size: 1.05rem;
	color: #fff !important;
	border: none; border-radius: 15px; cursor: pointer;
	box-shadow: 0 16px 34px -16px rgba(var(--bb-accent-rgb), .7);
	transition: background-position .4s ease, transform .18s ease, box-shadow .18s ease, background .2s ease;
}
.ksn-bb--cta-gradient .ksn-bb__form .single_add_to_cart_button,
.ksn-bb--cta-gradient .ksn-bb__form button[type="submit"] {
	background: linear-gradient(120deg, var(--ksn-primary), var(--ksn-accent)) !important;
	background-size: 160% 160%;
}
.ksn-bb--cta-solid .ksn-bb__form .single_add_to_cart_button,
.ksn-bb--cta-solid .ksn-bb__form button[type="submit"] { background: var(--bb-accent) !important; }
.ksn-bb__form .single_add_to_cart_button:hover,
.ksn-bb__form button[type="submit"]:hover {
	background-position: 100% 0;
	transform: translateY(-2px);
	box-shadow: 0 22px 44px -16px rgba(var(--ksn-accent-rgb), .65);
}
.ksn-bb__form .added_to_cart { display: block; margin-top: 8px; text-align: center; font-weight: 700; color: var(--bb-accent); text-decoration: none; }

/* ---- bulk order — a separate, smaller, quieter box ---- */
.ksn-bb__bulk-box {
	margin-top: 18px;
	padding-top: 16px;
	border-top: 1px dashed var(--ksn-line);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
}
.ksn-bb__bulk {
	display: inline-flex; align-items: center; justify-content: center;
	height: 42px; padding: 0 22px;
	font-family: var(--ksn-font); font-weight: 700; font-size: 0.85rem;
	color: var(--ksn-muted);
	background: transparent;
	border: 1px solid var(--ksn-line);
	border-radius: 12px; cursor: pointer;
	transition: border-color .18s ease, color .18s ease;
}
.ksn-bb__bulk:hover { border-color: var(--bb-accent); color: var(--bb-accent); }

/* small centered notes (min print qty, min bulk qty, etc.) */
.ksn-bb__bulk-note,
.ksn-bb__moq,
.ksn-bb .ksa-print-moq-alert,
.ksn-bb .print-moq-alert,
.ksn-bb .ksa-moq-note,
.ksn-bb .ksa-min-note {
	display: block;
	text-align: center;
	margin: 6px auto 0;
	font-size: 0.74rem;
	font-weight: 600;
	color: var(--ksn-muted);
	background: rgba(var(--ksn-primary-rgb), .06);
	padding: 6px 12px;
	border-radius: 999px;
	width: fit-content;
	max-width: 100%;
}

/* AIO per-group video — a polished horizontal card (thumbnail + caption) */
.ksn-bb .ksa-addon-video {
	display: flex !important;
	flex-direction: row-reverse;   /* caption on the right (like titles), thumb on the left */
	align-items: center;
	gap: 12px;
	width: 100% !important;
	max-width: 100% !important;
	box-sizing: border-box !important;
	margin: 8px 0 0 !important;     /* sits below all options, same width */
	padding: 9px 18px 9px 9px;
	border: 1.5px solid var(--ksn-line);
	border-radius: 16px;
	background: var(--ksn-surface-2);
	cursor: pointer;
	transition: border-color .18s ease, transform .15s ease, box-shadow .18s ease;
}
.ksn-bb .ksa-addon-video:hover {
	border-color: rgba(var(--bb-accent-rgb), .5);
	transform: translateY(-2px);
	box-shadow: 0 14px 30px -20px rgba(13,27,52,.4);
}
.ksn-bb .ksa-video-thumb {
	display: block;
	flex: none;
	width: 62px;
	height: 38px;
	aspect-ratio: auto;
	max-width: none;
	border-radius: 11px;
	overflow: hidden;
	cursor: pointer;
	position: relative;
	background: var(--ksn-primary-dark);
}
.ksn-bb .ksa-video-thumb img { width: 100% !important; height: 100% !important; object-fit: cover; display: block; }
.ksn-bb .ksa-video-thumb::before {
	content: ""; position: absolute; inset: 0;
	background: rgba(8,16,32,.28); transition: background .2s ease;
}
.ksn-bb .ksa-addon-video:hover .ksa-video-thumb::before { background: rgba(8,16,32,.12); }
.ksn-bb .ksa-video-thumb::after {
	content: "";
	position: absolute; inset: 0; margin: auto;
	width: 24px; height: 24px;
	border-radius: 50%;
	background: rgba(255,255,255,.92) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2310326a'%3E%3Cpath d='M8 5v14l11-7z'/%3E%3C/svg%3E") center/11px no-repeat;
	box-shadow: 0 6px 16px -4px rgba(0,0,0,.5);
	transition: transform .2s ease;
}
.ksn-bb .ksa-addon-video:hover .ksa-video-thumb::after { transform: scale(1.12); }
/* the caption text next to the thumbnail */
.ksn-bb .ksa-addon-video > *:not(.ksa-video-thumb),
.ksn-bb .ksa-video-caption {
	flex: 1; min-width: 0;
	font-weight: 800; font-size: 1rem; color: var(--ksn-ink); text-align: start; line-height: 1.5;
}

/* ---- trust ---- */
.ksn-bb__trust { list-style: none; margin: 16px 0 0; padding: 16px 0 0; border-top: 1px solid var(--ksn-line); display: grid; gap: 10px; }
.ksn-bb--blocks .ksn-bb__trust { border-top: none; padding-top: 0; margin: 14px 0 0; }
.ksn-bb__trust li { display: flex; align-items: center; gap: 10px; font-size: 0.9rem; color: var(--ksn-muted); }
.ksn-bb__trust-ico { color: var(--ksn-heat); display: inline-flex; flex: none; }
.ksn-bb__trust-ico svg, .ksn-bb__trust-ico i { width: 18px; height: 18px; font-size: 18px; }

/* =========================================================================
   AIO addon fields inside the buy box — premium selectable cards
   ========================================================================= */
.ksn-bb .ksa-addon-group { margin: 10px 0; }
.ksn-bb .ksa-addon-group:first-child { margin-top: 0; }
.ksn-bb .ksa-addon-title { display: block; font-weight: 800; font-size: 0.98rem; color: var(--ksn-ink); margin-bottom: 8px; }
/* tighter form spacing overall */
.ksn-bb__form form.cart { gap: 10px; }
.ksn-bb .ksa-req { color: var(--ksn-accent); }
/* options stacked vertically (one below another) */
.ksn-bb .ksa-addon-options { display: grid; grid-template-columns: 1fr; gap: 8px; }
/* an option = a full-width selectable card (matches the reference) */
.ksn-bb .ksa-addon-option {
	position: relative;
	display: flex;
	align-items: center;
	gap: 14px;
	margin: 0;
	padding: 16px 18px;
	border: 1.5px solid var(--ksn-line);
	border-radius: 16px;
	background: var(--ksn-surface-2);
	cursor: pointer;
	transition: border-color .2s ease, background .2s ease, box-shadow .2s ease, transform .15s ease;
}
.ksn-bb .ksa-addon-option:hover { transform: translateY(-2px); border-color: rgba(var(--bb-accent-rgb), .45); }
.ksn-bb .ksa-addon-option input.ksa-addon-input { position: absolute; opacity: 0; width: 1px; height: 1px; pointer-events: none; }
.ksn-bb select.ksa-addon-input {
	width: 100%; height: 48px; padding: 0 14px;
	border: 1.5px solid var(--ksn-line); border-radius: 14px;
	background: var(--ksn-surface-2); color: var(--ksn-ink);
	font-family: var(--ksn-font); font-weight: 700;
}

/* title (bold) at the start (right in RTL) + price chip pushed to the other end */
.ksn-bb .ksa-addon-label {
	display: flex; align-items: center; justify-content: space-between; gap: 12px;
	flex: 1; min-width: 0;
	font-weight: 800; font-size: 1.05rem; color: var(--ksn-ink); line-height: 1.35;
}
.ksn-bb .ksa-addon-label small {
	font-size: 0.78rem; font-weight: 700;
	color: var(--ksn-muted);
	background: rgba(var(--ksn-primary-rgb), .08);
	padding: 4px 11px; border-radius: 999px;
}

/* clean radio at the start (left in RTL) */
.ksn-bb .ksa-addon-option::after {
	content: ""; flex: none; order: 9;
	width: 24px; height: 24px; border-radius: 50%;
	border: 2px solid var(--ksn-line); background: var(--ksn-surface);
	transition: border-color .2s ease, box-shadow .2s ease;
}

/* selected: accent border + soft glow + filled radio (like the reference) */
.ksn-bb .ksa-addon-option:has(input:checked),
.ksn-bb .ksa-addon-option.is-selected {
	border-color: var(--bb-accent);
	background: rgba(var(--bb-accent-rgb), .08);
	box-shadow: 0 0 0 1px var(--bb-accent), 0 0 26px -6px rgba(var(--bb-accent-rgb), .55);
}
.ksn-bb .ksa-addon-option:has(input:checked)::after,
.ksn-bb .ksa-addon-option.is-selected::after {
	border-color: var(--bb-accent);
	background: radial-gradient(circle, var(--bb-accent) 0 46%, transparent 50%), var(--ksn-surface);
	box-shadow: 0 0 10px -1px rgba(var(--bb-accent-rgb), .7);
}
.ksn-bb .ksa-addon-option:has(input:checked) .ksa-addon-label small,
.ksn-bb .ksa-addon-option.is-selected .ksa-addon-label small {
	color: var(--bb-accent); background: rgba(var(--bb-accent-rgb), .15);
}
.ksn-bb .ksa-addon-upload { margin-top: 10px; padding: 12px; border: 1px dashed var(--ksn-line); border-radius: 14px; background: var(--ksn-surface-2); }

/* =========================================================================
   Cut-corner (stamp) option — applies to buttons & cards inside the buy box
   ========================================================================= */
.ksn-bb--corners-cut .single_add_to_cart_button,
.ksn-bb--corners-cut button.button,
.ksn-bb--corners-cut .ksn-bb__bulk,
.ksn-bb--corners-cut .ksa-addon-option,
.ksn-bb--corners-cut .ksa-addon-video,
.ksn-bb--corners-cut .ksn-bb__invoice,
.ksn-bb--corners-cut .ksa-qd-wrap,
.ksn-bb--corners-cut .ksn-bb__trust {
	border-radius: 0 !important;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 16px), calc(100% - 16px) 100%, 0 100%);
}
.ksn-bb--corners-cut .single_add_to_cart_button,
.ksn-bb--corners-cut .ksn-bb__bulk { --cut: 14px; }

/* =========================================================================
   DARK MODE — matches the reference: very dark clean panel, subtle cards,
   and a glowing accent border on the selected card (no heavy colour wash).
   ========================================================================= */
:root { --bbd-panel: #0d111c; --bbd-card: #161b29; --bbd-card-hi: #1c2233; --bbd-line: rgba(255,255,255,.07); }

.ksn-dark .ksn-bb,
html.ksn-dark .ksn-bb:not(.ksn-light) {
	background-color: var(--bbd-panel);
	background-image: none;          /* clean dark, no grid (like the reference) */
}

/* option / video / select cards — subtle, thin-bordered */
.ksn-dark .ksn-bb .ksa-addon-option,
.ksn-dark .ksn-bb .ksa-addon-video,
.ksn-dark .ksn-bb select.ksa-addon-input,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-option,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-video,
html.ksn-dark .ksn-bb:not(.ksn-light) select.ksa-addon-input {
	background: var(--bbd-card) !important;
	border: 1px solid var(--bbd-line) !important;
	color: #eef3fb !important;
}
.ksn-dark .ksn-bb .ksa-addon-option:hover,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-option:hover {
	background: var(--bbd-card-hi) !important;
	border-color: rgba(var(--bb-accent-rgb), .55) !important;
}

/* group titles — white, whatever element AIO uses for them */
.ksn-dark .ksn-bb .ksa-addon-group > *:not(.ksa-addon-options):not(.ksa-addon-option):not(.ksa-addon-video):not(.ksa-addon-upload):not(.ksn-bb__moq),
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-group > *:not(.ksa-addon-options):not(.ksa-addon-option):not(.ksa-addon-video):not(.ksa-addon-upload):not(.ksn-bb__moq),
.ksn-dark .ksn-bb .ksa-addon-title,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-title { color: var(--bb-accent) !important; }
.ksn-dark .ksn-bb .ksa-req,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-req { color: #ff7a7a !important; }

/* option label (white) + price chip (subtle, muted) */
.ksn-dark .ksn-bb .ksa-addon-label,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-label { color: #f2f5fb !important; }
.ksn-dark .ksn-bb .ksa-addon-label small,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-label small {
	color: #8a97ad !important; background: rgba(255,255,255,.05) !important;
	border: 1px solid rgba(255,255,255,.08) !important;
}

/* radio (unselected) */
.ksn-dark .ksn-bb .ksa-addon-option::after,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-option::after {
	border-color: rgba(255,255,255,.22) !important; background: var(--bbd-panel) !important;
}

/* SELECTED card — subtle tint + bright accent border + soft glow */
.ksn-dark .ksn-bb .ksa-addon-option:has(input:checked),
.ksn-dark .ksn-bb .ksa-addon-option.is-selected,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-option:has(input:checked),
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-option.is-selected {
	background: rgba(var(--bb-accent-rgb), .10) !important;
	border-color: var(--bb-accent) !important;
	box-shadow: 0 0 0 1px var(--bb-accent), 0 0 26px -8px rgba(var(--bb-accent-rgb), .75) !important;
}
.ksn-dark .ksn-bb .ksa-addon-option.is-selected::after,
.ksn-dark .ksn-bb .ksa-addon-option:has(input:checked)::after,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-option.is-selected::after,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-option:has(input:checked)::after {
	border-color: var(--bb-accent) !important;
	background: radial-gradient(circle, var(--bb-accent) 0 46%, transparent 50%), var(--bbd-panel) !important;
	box-shadow: 0 0 12px 0 rgba(var(--bb-accent-rgb), .9);
}
.ksn-dark .ksn-bb .ksa-addon-option.is-selected .ksa-addon-label,
.ksn-dark .ksn-bb .ksa-addon-option:has(input:checked) .ksa-addon-label,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-option.is-selected .ksa-addon-label,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-option:has(input:checked) .ksa-addon-label { color: #fff !important; }
.ksn-dark .ksn-bb .ksa-addon-option.is-selected .ksa-addon-label small,
.ksn-dark .ksn-bb .ksa-addon-option:has(input:checked) .ksa-addon-label small,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-option.is-selected .ksa-addon-label small,
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-option:has(input:checked) .ksa-addon-label small {
	color: var(--bb-accent) !important; background: rgba(var(--bb-accent-rgb), .16) !important; border-color: transparent !important;
}

/* disabled options (below min qty) — clearly dimmed but readable */
.ksn-dark .ksn-bb .ksa-addon-option:has(input:disabled),
html.ksn-dark .ksn-bb:not(.ksn-light) .ksa-addon-option:has(input:disabled) { opacity: .42; }

.ksn-bb .ksa-addon-upload label { display: block; font-weight: 700; color: var(--ksn-ink); margin-bottom: 6px; font-size: 0.88rem; }

/* =========================================================================
   Live mini-invoice (ours) + AIO live invoice + quantity price table
   ========================================================================= */
.ksn-bb__invoice {
	margin-top: 14px;
	padding: 16px 18px;
	border-radius: 18px;
	background: linear-gradient(150deg, var(--ksn-surface-2), var(--ksn-surface));
	border: 1px solid var(--ksn-line);
	box-shadow: inset 0 1px 0 rgba(255,255,255,.4);
}
.ksn-bb__invoice-title {
	display: flex; align-items: center; gap: 8px;
	font-weight: 800; font-size: 0.92rem; color: var(--bb-accent);
	margin-bottom: 12px;
}
.ksn-bb__invoice-title::before {
	content: ""; width: 18px; height: 18px; border-radius: 5px;
	background: var(--bb-accent); opacity: .85;
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'%3E%3Cpath d='M9 7h6M9 11h6M9 15h4'/%3E%3Crect x='5' y='3' width='14' height='18' rx='2'/%3E%3C/svg%3E") center/contain no-repeat;
	        mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'%3E%3Cpath d='M9 7h6M9 11h6M9 15h4'/%3E%3Crect x='5' y='3' width='14' height='18' rx='2'/%3E%3C/svg%3E") center/contain no-repeat;
}
.ksn-bb__invoice-row {
	display: flex; align-items: center; justify-content: space-between;
	padding: 5px 0; font-size: 0.9rem; color: var(--ksn-muted);
}
.ksn-bb__invoice-row b { color: var(--ksn-ink); font-weight: 800; }

/* selected-addon breakdown lines (very small) */
.ksn-bb__invoice-lines { display: grid; gap: 3px; margin: 4px 0; }
.ksn-bb__invoice-lines:empty { display: none; }
.ksn-bb__invoice-addon {
	display: flex; align-items: center; justify-content: space-between; gap: 8px;
	font-size: 0.72rem; color: var(--ksn-muted);
	padding: 2px 0 2px 10px;
	border-inline-start: 2px solid rgba(var(--bb-accent-rgb), .35);
}
.ksn-bb__invoice-addon span { display: inline-flex; gap: 5px; align-items: baseline; min-width: 0; }
.ksn-bb__invoice-addon i { font-style: normal; font-weight: 700; color: var(--ksn-ink); }
.ksn-bb__invoice-addon b { color: var(--ksn-heat); font-weight: 800; white-space: nowrap; }
.ksn-bb__invoice-unit { border-top: 1px dashed var(--ksn-line); margin-top: 6px; padding-top: 8px; }
.ksn-bb__invoice-unit b { color: var(--ksn-ink); }
.ksn-bb__invoice-total {
	display: flex; align-items: center; justify-content: space-between;
	margin-top: 10px; padding-top: 12px;
	border-top: 1px dashed var(--ksn-line);
	font-size: 1.05rem; font-weight: 800; color: var(--ksn-ink);
}
.ksn-bb__invoice-total b { color: var(--bb-accent); font-size: 1.25rem; font-weight: 900; }

/* AIO quantity-discount table — override its inline style, theme-aware.
   flex column + gap:0 forces the title to sit flush against the table. */
.ksn-bb .ksa-qd-wrap,
.ksn-bb__ptable {
	display: flex !important;
	flex-direction: column !important;
	gap: 0 !important;
	margin: 0 0 16px !important;
	border: 1px solid var(--ksn-line) !important;
	border-radius: 16px !important;
	overflow: hidden !important;
	box-shadow: var(--ksn-shadow) !important;
	background: var(--ksn-surface) !important;
}
.ksn-bb .ksa-qd-wrap > *,
.ksn-bb__ptable > * { margin: 0 !important; border-radius: 0 !important; }
.ksn-bb .ksa-qd-caption {
	background: linear-gradient(120deg, var(--ksn-primary-dark), var(--ksn-primary)) !important;
	color: #fff !important;
	font-weight: 800 !important;
	padding: 12px 16px !important;
	margin: 0 !important;            /* attach the title to the table (no gap) */
	border-radius: 0 !important;
	border: none !important;
}
/* kill any spacing between the wrap's children so it reads as one block */
.ksn-bb .ksa-qd-wrap > * { margin: 0 !important; }
.ksn-bb .ksa-qd-table { background: var(--ksn-surface) !important; margin: 0 !important; border-spacing: 0 !important; }
.ksn-bb .ksa-qd-table thead th {
	background: var(--ksn-surface-2) !important;
	color: var(--ksn-ink) !important;
	padding: 11px 10px !important;
	border: none !important;
}
.ksn-bb .ksa-qd-table td {
	padding: 11px 10px !important;
	border-top: 1px solid var(--ksn-line) !important;
	color: var(--ksn-muted) !important;
}
.ksn-bb .ksa-qd-table tbody tr:nth-child(even) { background: rgba(var(--ksn-primary-rgb), .04) !important; }
.ksn-bb .ksa-qd-table tbody tr:hover td { background: rgba(var(--bb-accent-rgb), .08) !important; color: var(--ksn-ink) !important; }
.ksn-bb .ksa-qd-table tbody tr td:last-child { font-weight: 800 !important; color: var(--ksn-ink) !important; }
.ksn-bb .ksa-qd-badge {
	background: rgba(var(--bb-accent-rgb), .12) !important;
	color: var(--bb-accent) !important;
	font-weight: 800 !important;
}
.ksn-bb .ksa-qd-table .ksa-qd-zero .ksa-qd-badge { background: rgba(var(--ksn-primary-rgb), .08) !important; color: var(--ksn-muted) !important; }

/* quantity price table (manual shortcode variant) */
.ksn-bb__ptable { margin-bottom: 16px; }
.ksn-bb__ptable table {
	width: 100%; border-collapse: separate; border-spacing: 0;
	border: 1px solid var(--ksn-line); border-radius: 14px; overflow: hidden;
	font-size: 0.88rem;
}
.ksn-bb__ptable th { background: var(--ksn-surface-2); color: var(--ksn-ink); font-weight: 800; padding: 10px 12px; }
.ksn-bb__ptable td { padding: 9px 12px; text-align: center; color: var(--ksn-muted); border-top: 1px solid var(--ksn-line); }
.ksn-bb__ptable tr:hover td { background: rgba(var(--bb-accent-rgb), .06); color: var(--ksn-ink); }

/* AIO live invoice — match the look */
.ksn-bb #ks-live-invoice {
	margin-top: 14px; padding: 16px 18px;
	border-radius: 18px; background: var(--ksn-surface-2); border: 1px solid var(--ksn-line);
}
.ksn-bb #ks-live-invoice .ks-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 7px 0; font-size: 0.9rem; color: var(--ksn-muted); }
.ksn-bb #ks-live-invoice .ks-row span:last-child { color: var(--ksn-ink); font-weight: 700; }
.ksn-bb #ks-live-invoice .ks-row.ks-plus span:last-child { color: var(--ksn-heat); }
.ksn-bb #ks-live-invoice .ks-row.ks-total { margin-top: 8px; padding-top: 14px; border-top: 1px solid var(--ksn-line); font-weight: 900; color: var(--ksn-ink); }
.ksn-bb #ks-live-invoice .ks-row.ks-total > span:first-child { font-size: 1rem; }
.ksn-bb #ks-live-invoice .ks-row.ks-total > span:last-child { color: var(--ksn-heat); font-size: 1.5rem; }
.ksn-bb #ks-live-invoice small { font-weight: 500; opacity: .8; }

/* =========================================================================
   Section video guide (packaging / print) — thumbnail + play, opens a modal
   ========================================================================= */
.ksn-bb__guides { display: none; }
.ksn-bb__guide {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: 12px;
	padding: 10px;
	border-radius: 14px;
	background: var(--ksn-surface-2);
	border: 1px solid var(--ksn-line);
	cursor: pointer;
	transition: border-color .18s ease, transform .18s ease;
}
.ksn-bb__guide:hover { border-color: var(--bb-accent); transform: translateY(-2px); }
.ksn-bb__guide-thumb {
	position: relative;
	flex: none;
	width: 92px; height: 58px;
	border-radius: 10px;
	overflow: hidden;
	background: var(--ksn-primary-dark);
}
.ksn-bb__guide-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ksn-bb__guide-thumb::after {
	content: "";
	position: absolute; inset: 0; margin: auto;
	width: 0; height: 0;
	border-style: solid;
	border-width: 9px 0 9px 15px;
	border-color: transparent transparent transparent #fff;
	filter: drop-shadow(0 0 6px rgba(0,0,0,.5));
}
.ksn-bb__guide-thumb::before {
	content: "";
	position: absolute; inset: 0;
	background: rgba(8,16,32,.35);
	transition: background .2s ease;
}
.ksn-bb__guide:hover .ksn-bb__guide-thumb::before { background: rgba(8,16,32,.15); }
.ksn-bb__guide-label { font-weight: 800; font-size: 0.92rem; color: var(--ksn-ink); }
.ksn-bb__guide-sub { display: block; font-weight: 500; font-size: 0.8rem; color: var(--ksn-muted); margin-top: 3px; }

/* video modal */
.ksn-vmodal {
	position: fixed; inset: 0; z-index: 99999;
	display: grid; place-items: center;
	background: rgba(5,12,26,.92);
	padding: 24px; opacity: 0;
	transition: opacity .3s ease;
}
.ksn-vmodal.is-open { opacity: 1; }
.ksn-vmodal__box {
	position: relative;
	width: min(900px, 94vw);
	aspect-ratio: 16 / 9;
	background: #000;
	border-radius: 14px;
	overflow: hidden;
	transform: scale(.94);
	transition: transform .3s cubic-bezier(.16,1,.3,1);
}
.ksn-vmodal.is-open .ksn-vmodal__box { transform: scale(1); }
.ksn-vmodal__box iframe,
.ksn-vmodal__box video { width: 100%; height: 100%; border: 0; display: block; }
.ksn-vmodal__close {
	position: absolute; top: -50px; inset-inline-end: 0;
	width: 44px; height: 44px;
	border: none; border-radius: 50%;
	background: rgba(255,255,255,.14); color: #fff;
	font-size: 24px; cursor: pointer;
}
.ksn-vmodal__close:hover { background: rgba(255,255,255,.28); }

@media (max-width: 480px) {
	.ksn-bb__form .quantity .qty { width: 48px; }
	.ksn-bb__guide-thumb { width: 80px; height: 50px; }
}

/* =========================================================================
   Sticky cart — styles: bar (full width) | floating (rounded) | pill (compact)
   positions: bottom | top. Light/dark via tokens.
   ========================================================================= */
.ksn-stickycart {
	position: fixed;
	inset-inline: 0;
	z-index: 9000;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	padding: 10px 16px;
	background: var(--ksn-surface);
	box-shadow: 0 10px 34px -14px rgba(13,27,52,.5);
	transition: transform .35s cubic-bezier(.2,.7,.2,1), opacity .3s ease;
	opacity: 0;
}
.ksn-stickycart--bottom { bottom: 0; border-top: 1px solid var(--ksn-line); transform: translateY(110%); }
.ksn-stickycart--top    { top: 0; border-bottom: 1px solid var(--ksn-line); transform: translateY(-110%); }
.ksn-stickycart.is-visible { transform: translateY(0); opacity: 1; }

/* floating — a rounded, inset bar */
.ksn-stickycart--floating {
	inset-inline: auto;
	left: 50%;
	width: min(720px, calc(100% - 28px));
	transform: translateX(-50%) translateY(140%);
	border: 1px solid var(--ksn-line);
	border-radius: 18px;
}
.ksn-stickycart--floating.ksn-stickycart--bottom { bottom: 14px; }
.ksn-stickycart--floating.ksn-stickycart--top { top: 14px; }
.ksn-stickycart--floating.ksn-stickycart--top { transform: translateX(-50%) translateY(-140%); }
.ksn-stickycart--floating.is-visible { transform: translateX(-50%) translateY(0); }

/* pill — compact, content-width */
.ksn-stickycart--pill {
	inset-inline: auto;
	left: 50%;
	width: auto; max-width: calc(100% - 28px);
	gap: 18px;
	padding: 8px 8px 8px 18px;
	border: 1px solid var(--ksn-line);
	border-radius: 999px;
	transform: translateX(-50%) translateY(140%);
}
.ksn-stickycart--pill.ksn-stickycart--bottom { bottom: 16px; }
.ksn-stickycart--pill.ksn-stickycart--top { top: 16px; transform: translateX(-50%) translateY(-140%); }
.ksn-stickycart--pill.is-visible { transform: translateX(-50%) translateY(0); }
.ksn-stickycart--pill .ksn-stickycart__btn { border-radius: 999px; }

.ksn-stickycart__info { display: flex; align-items: center; gap: 12px; min-width: 0; }
.ksn-stickycart__img img { width: 48px; height: 48px; border-radius: 10px; object-fit: cover; display: block; }
.ksn-stickycart__text { display: flex; flex-direction: column; min-width: 0; }
.ksn-stickycart__name { font-weight: 700; font-size: 0.9rem; color: var(--ksn-ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ksn-stickycart__price { font-weight: 900; color: var(--ksn-accent); font-size: 0.95rem; }

/* glass floating */
.ksn-stickycart--glass {
	inset-inline: auto; left: 50%;
	width: min(720px, calc(100% - 28px));
	transform: translateX(-50%) translateY(140%);
	border: 1px solid rgba(255,255,255,.25);
	border-radius: 18px;
	background: color-mix(in srgb, var(--ksn-surface) 58%, transparent);
	backdrop-filter: blur(16px) saturate(1.4);
	-webkit-backdrop-filter: blur(16px) saturate(1.4);
	box-shadow: 0 18px 50px -20px rgba(13,27,52,.5), inset 0 1px 0 rgba(255,255,255,.3);
}
.ksn-stickycart--glass.ksn-stickycart--bottom { bottom: 14px; }
.ksn-stickycart--glass.ksn-stickycart--top { top: 14px; transform: translateX(-50%) translateY(-140%); }
.ksn-stickycart--glass.is-visible { transform: translateX(-50%) translateY(0); }

/* split — info block + a full-height button block */
.ksn-stickycart--split {
	inset-inline: auto; left: 50%;
	width: min(720px, calc(100% - 28px));
	transform: translateX(-50%) translateY(140%);
	padding: 0; gap: 0;
	border: 1px solid var(--ksn-line);
	border-radius: 18px; overflow: hidden;
}
.ksn-stickycart--split.ksn-stickycart--bottom { bottom: 14px; }
.ksn-stickycart--split.ksn-stickycart--top { top: 14px; transform: translateX(-50%) translateY(-140%); }
.ksn-stickycart--split.is-visible { transform: translateX(-50%) translateY(0); }
.ksn-stickycart--split .ksn-stickycart__info { flex: 1; padding: 12px 16px; }
.ksn-stickycart--split .ksn-stickycart__btn { align-self: stretch; height: auto !important; border-radius: 0 !important; padding: 0 30px; }

/* ---- button base + styles ---- */
.ksn-stickycart__btn {
	flex: none;
	display: inline-flex; align-items: center; justify-content: center; gap: 8px;
	height: 48px; padding: 0 24px;
	font-family: var(--ksn-font); font-weight: 800; font-size: 0.95rem;
	color: #fff; border: none; border-radius: 14px; cursor: pointer;
	transition: transform .18s ease, box-shadow .18s ease, background .2s ease, background-position .45s ease, color .2s ease;
}
.ksn-stickycart__btn svg { width: 18px; height: 18px; }
.ksn-stickycart__btn:hover { transform: translateY(-2px); }
.ksn-stickycart--pill .ksn-stickycart__btn,
.ksn-stickycart--glass .ksn-stickycart__btn { border-radius: 999px; }

.ksn-stickycart--btn-gradient .ksn-stickycart__btn {
	background: linear-gradient(120deg, var(--ksn-primary), var(--ksn-accent)); background-size: 160% 160%;
	box-shadow: 0 14px 30px -14px rgba(var(--ksn-accent-rgb), .6);
}
.ksn-stickycart--btn-gradient .ksn-stickycart__btn:hover { background-position: 100% 0; }
.ksn-stickycart--btn-heat .ksn-stickycart__btn { background: var(--ksn-heat); color: #1a0c00; box-shadow: 0 14px 30px -14px rgba(var(--ksn-heat-rgb), .7); }
.ksn-stickycart--btn-primary .ksn-stickycart__btn { background: var(--ksn-primary); box-shadow: 0 14px 30px -14px rgba(var(--ksn-primary-rgb), .6); }
.ksn-stickycart--btn-glow .ksn-stickycart__btn { background: var(--ksn-accent); animation: ksn-sc-glow 2.4s ease-in-out infinite; }
@keyframes ksn-sc-glow {
	0%, 100% { box-shadow: 0 0 0 1px rgba(var(--ksn-accent-rgb), .5), 0 0 20px -4px rgba(var(--ksn-accent-rgb), .7); }
	50%      { box-shadow: 0 0 0 1px rgba(var(--ksn-accent-rgb), .8), 0 0 34px 0 rgba(var(--ksn-accent-rgb), .95); }
}
.ksn-stickycart--btn-outline .ksn-stickycart__btn { background: transparent; color: var(--ksn-primary); border: 2px solid var(--ksn-primary); }
.ksn-stickycart--btn-outline .ksn-stickycart__btn:hover { background: var(--ksn-primary); color: #fff; }
.ksn-dark .ksn-stickycart--btn-outline .ksn-stickycart__btn,
html.ksn-dark .ksn-stickycart--btn-outline .ksn-stickycart__btn { color: #eef3fb; border-color: rgba(255,255,255,.4); }
@media (prefers-reduced-motion: reduce) { .ksn-stickycart--btn-glow .ksn-stickycart__btn { animation: none; } }

/* dark */
.ksn-dark .ksn-stickycart,
html.ksn-dark .ksn-stickycart { background: var(--ksn-surface); border-color: rgba(255,255,255,.1); }
.ksn-dark .ksn-stickycart--glass,
html.ksn-dark .ksn-stickycart--glass { background: color-mix(in srgb, var(--ksn-primary-dark) 50%, transparent); border-color: rgba(255,255,255,.14); }

@media (min-width: 1025px) {
	.ksn-stickycart--mobile { display: none !important; }
}
@media (max-width: 480px) {
	.ksn-stickycart--floating, .ksn-stickycart--pill { width: calc(100% - 20px); border-radius: 16px; }
	.ksn-stickycart--pill { padding: 8px 8px 8px 14px; }
}

/* =========================================================================
   Product tabs — fully reworked nav styles (light + dark):
     stamp | underline | pills | segment | glass | neon | card | vertical
   ========================================================================= */
.ksn-tabs { width: 100%; }
.ksn-tabs__nav { display: flex; flex-wrap: wrap; gap: 8px; position: relative; }
.ksn-tabs__tab {
	display: inline-flex; align-items: center; gap: 9px; justify-content: center;
	font-family: var(--ksn-font); font-weight: 800; font-size: 0.95rem; line-height: 1.2;
	color: var(--ksn-muted); cursor: pointer; background: transparent; border: none;
	-webkit-tap-highlight-color: transparent;
	transition: color .2s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.ksn-tabs__tab:hover { color: var(--ksn-ink); }
.ksn-tabs__tab-ico { display: inline-flex; font-size: 1.05em; line-height: 1; opacity: .85; transition: transform .2s ease, color .2s ease; }
.ksn-tabs__tab:hover .ksn-tabs__tab-ico { transform: scale(1.12); }
.ksn-tabs__tab.is-active .ksn-tabs__tab-ico { opacity: 1; }
.ksn-tabs__panels {
	margin-top: 18px;
	background: var(--ksn-surface);
	border: 1px solid var(--ksn-line);
	border-radius: 20px;
	padding: 30px 32px;
}
@media (max-width: 600px) { .ksn-tabs__panels { padding: 20px; border-radius: 16px; } }
.ksn-tabs__panel { display: none; }
.ksn-tabs__panel.is-active { display: block; animation: ksn-tab-in .4s cubic-bezier(.16,1,.3,1); }
@keyframes ksn-tab-in { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }

/* align (horizontal styles) */
.ksn-tabs--align-center .ksn-tabs__nav { justify-content: center; }
.ksn-tabs--align-stretch .ksn-tabs__nav { display: flex; }
.ksn-tabs--align-stretch .ksn-tabs__tab { flex: 1 1 0; text-align: center; }

/* ---- 1) STAMP — industrial cut-corner block with induction-heat accent ---- */
.ksn-tabs--stamp .ksn-tabs__nav { gap: 6px; border-bottom: 2px solid var(--ksn-line); }
.ksn-tabs--stamp .ksn-tabs__tab {
	padding: 14px 26px; color: var(--ksn-muted); position: relative; isolation: isolate;
	background: transparent;
	clip-path: polygon(0 0, 100% 0, 100% 100%, 15px 100%, 0 calc(100% - 15px));
}
.ksn-tabs--stamp .ksn-tabs__tab:hover { color: var(--ksn-ink); background: var(--ksn-surface-2); }
.ksn-tabs--stamp .ksn-tabs__tab.is-active {
	color: #fff;
	background: linear-gradient(135deg, var(--ksn-primary), var(--ksn-accent));
	box-shadow: 0 14px 28px -16px rgba(var(--ksn-accent-rgb), .8);
}
.ksn-tabs--stamp .ksn-tabs__tab.is-active::before {
	content: ""; position: absolute; top: 0; inset-inline: 0; height: 3px; background: var(--ksn-heat);
}
.ksn-tabs--stamp .ksn-tabs__tab.is-active .ksn-tabs__tab-ico { color: #fff; }
.ksn-tabs--stamp .ksn-tabs__panels {
	background: var(--ksn-surface); padding: 30px 32px; margin-top: 14px;
	border: none; border-radius: 0;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 24px), calc(100% - 24px) 100%, 0 100%);
	box-shadow: inset 0 3px 0 var(--ksn-heat);
}

/* ---- 2) UNDERLINE — animated gradient bar that grows from center ---- */
.ksn-tabs--underline .ksn-tabs__nav { gap: 6px; border-bottom: 2px solid var(--ksn-line); }
.ksn-tabs--underline .ksn-tabs__tab { padding: 14px 20px; position: relative; margin-bottom: -2px; }
.ksn-tabs--underline .ksn-tabs__tab::after {
	content: ""; position: absolute; left: 50%; bottom: -2px; height: 3px; width: 0; border-radius: 3px;
	background: linear-gradient(90deg, var(--ksn-heat), var(--ksn-accent));
	transform: translateX(-50%); transition: width .3s cubic-bezier(.16,1,.3,1);
}
.ksn-tabs--underline .ksn-tabs__tab:hover::after { width: 38%; }
.ksn-tabs--underline .ksn-tabs__tab.is-active { color: var(--ksn-ink); }
.ksn-tabs--underline .ksn-tabs__tab.is-active::after { width: 100%; }
.ksn-tabs--underline .ksn-tabs__tab.is-active .ksn-tabs__tab-ico { color: var(--ksn-accent); }

/* ---- 3) PILLS — soft pill, gradient active, lift on hover ---- */
.ksn-tabs--pills .ksn-tabs__tab { padding: 11px 22px; border-radius: 999px; background: var(--ksn-surface-2); border: 1px solid var(--ksn-line); }
.ksn-tabs--pills .ksn-tabs__tab:hover { border-color: rgba(var(--ksn-accent-rgb), .5); transform: translateY(-2px); }
.ksn-tabs--pills .ksn-tabs__tab.is-active {
	color: #fff; border-color: transparent;
	background: linear-gradient(120deg, var(--ksn-primary), var(--ksn-accent));
	box-shadow: 0 14px 28px -12px rgba(var(--ksn-accent-rgb), .65);
}
.ksn-tabs--pills .ksn-tabs__tab.is-active .ksn-tabs__tab-ico { color: #fff; }

/* ---- 4) SEGMENT — iOS-style segmented control on a recessed track ---- */
.ksn-tabs--segment .ksn-tabs__nav {
	display: inline-flex; gap: 4px; padding: 6px; border-radius: 16px; max-width: 100%;
	background: var(--ksn-surface-2); border: 1px solid var(--ksn-line);
	box-shadow: inset 0 2px 6px -4px rgba(13,27,52,.3);
}
.ksn-tabs--segment .ksn-tabs__tab { padding: 11px 22px; border-radius: 11px; }
.ksn-tabs--segment .ksn-tabs__tab.is-active {
	background: var(--ksn-surface); color: var(--ksn-primary);
	box-shadow: 0 6px 16px -8px rgba(13,27,52,.45);
}
.ksn-tabs--segment .ksn-tabs__tab.is-active .ksn-tabs__tab-ico { color: var(--ksn-accent); }
@media (max-width: 600px) { .ksn-tabs--segment .ksn-tabs__nav { overflow-x: auto; } }

/* ---- 5) GLASS — frosted dark capsule (a self-contained dark island) ---- */
.ksn-tabs--glass .ksn-tabs__nav {
	gap: 2px; padding: 6px; border-radius: 16px;
	background: linear-gradient(180deg, rgba(12,18,30,.92), rgba(12,18,30,.72));
	border: 1px solid rgba(255,255,255,.08);
	backdrop-filter: blur(12px);
	box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 16px 34px -20px rgba(0,0,0,.55);
}
.ksn-tabs--glass .ksn-tabs__tab { padding: 13px 22px; border-radius: 11px; color: rgba(255,255,255,.55); position: relative; }
.ksn-tabs--glass .ksn-tabs__tab::after {
	content: ""; position: absolute; inset-inline: 16px; bottom: 4px; height: 2px; border-radius: 2px;
	background: var(--ksn-accent); transform: scaleX(0); transition: transform .24s ease;
}
.ksn-tabs--glass .ksn-tabs__tab:hover { color: rgba(255,255,255,.88); }
.ksn-tabs--glass .ksn-tabs__tab.is-active { color: #fff; background: rgba(255,255,255,.07); }
.ksn-tabs--glass .ksn-tabs__tab.is-active::after { transform: scaleX(1); }
.ksn-tabs--glass .ksn-tabs__tab.is-active .ksn-tabs__tab-ico { color: var(--ksn-accent); }
@media (max-width: 600px) { .ksn-tabs--glass .ksn-tabs__nav { overflow-x: auto; flex-wrap: nowrap; } }

/* ---- 6) NEON — dark glowing bar, accent halo on active ---- */
.ksn-tabs--neon .ksn-tabs__nav {
	gap: 6px; padding: 6px; border-radius: 14px;
	background: #0b1020; border: 1px solid rgba(var(--ksn-accent-rgb), .25);
}
.ksn-tabs--neon .ksn-tabs__tab { padding: 12px 22px; border-radius: 10px; color: rgba(255,255,255,.6); }
.ksn-tabs--neon .ksn-tabs__tab:hover { color: #fff; }
.ksn-tabs--neon .ksn-tabs__tab.is-active {
	color: #fff; background: rgba(var(--ksn-accent-rgb), .14);
	box-shadow: inset 0 0 0 1px rgba(var(--ksn-accent-rgb), .6), 0 0 20px -2px rgba(var(--ksn-accent-rgb), .5);
	text-shadow: 0 0 10px rgba(var(--ksn-accent-rgb), .7);
}
.ksn-tabs--neon .ksn-tabs__tab.is-active .ksn-tabs__tab-ico { color: var(--ksn-accent); }
@media (max-width: 600px) { .ksn-tabs--neon .ksn-tabs__nav { overflow-x: auto; flex-wrap: nowrap; } }

/* ---- 7) CARD — icon-on-top elevated cards ---- */
.ksn-tabs--card .ksn-tabs__nav { gap: 10px; }
.ksn-tabs--card .ksn-tabs__tab {
	flex-direction: column; gap: 8px; min-width: 100px;
	padding: 16px 14px; border-radius: 16px;
	background: var(--ksn-surface-2); border: 1px solid var(--ksn-line);
}
.ksn-tabs--card .ksn-tabs__tab-ico {
	width: 40px; height: 40px; display: grid; place-items: center; border-radius: 12px;
	background: rgba(var(--ksn-primary-rgb), .1); color: var(--ksn-primary); font-size: 1.15rem;
}
.ksn-tabs--card .ksn-tabs__tab:hover { border-color: rgba(var(--ksn-primary-rgb), .4); transform: translateY(-3px); box-shadow: 0 14px 28px -18px rgba(13,27,52,.4); }
.ksn-tabs--card .ksn-tabs__tab.is-active { background: var(--ksn-surface); border-color: var(--ksn-primary); box-shadow: var(--ksn-shadow); }
.ksn-tabs--card .ksn-tabs__tab.is-active .ksn-tabs__tab-ico { background: linear-gradient(135deg, var(--ksn-primary), var(--ksn-accent)); color: #fff; }
.ksn-tabs--card .ksn-tabs__tab-label { font-size: 0.85rem; }

/* ---- 8) VERTICAL — side rail with heat marker ---- */
.ksn-tabs--vertical { display: grid; grid-template-columns: 220px 1fr; gap: 26px; align-items: start; }
.ksn-tabs--vertical .ksn-tabs__nav { flex-direction: column; gap: 4px; }
.ksn-tabs--vertical .ksn-tabs__tab { text-align: start; justify-content: flex-start; padding: 14px 16px; border-radius: 12px; position: relative; }
.ksn-tabs--vertical .ksn-tabs__tab:hover { background: var(--ksn-surface-2); }
.ksn-tabs--vertical .ksn-tabs__tab.is-active { background: var(--ksn-surface-2); color: var(--ksn-ink); box-shadow: inset 3px 0 0 var(--ksn-heat); }
.ksn-tabs--vertical .ksn-tabs__tab.is-active .ksn-tabs__tab-ico { color: var(--ksn-accent); }
.ksn-tabs--vertical .ksn-tabs__panels { margin-top: 0; }
@media (max-width: 768px) { .ksn-tabs--vertical { grid-template-columns: 1fr; } .ksn-tabs--vertical .ksn-tabs__nav { flex-direction: row; flex-wrap: nowrap; overflow-x: auto; } }

/* ---- 9) CLASSIC — full-width rectangular tab strip + bold dark cut-corner active ---- */
.ksn-tabs--classic .ksn-tabs__nav { gap: 0; width: 100%; flex-wrap: nowrap; }
.ksn-tabs--classic .ksn-tabs__tab {
	flex: 1 1 0; min-width: 0; padding: 16px 18px; position: relative;
	background: var(--ksn-surface-2); color: var(--ksn-muted);
	border: 1px solid var(--ksn-line); margin-inline-start: -1px;
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ksn-tabs--classic .ksn-tabs__tab:hover { color: var(--ksn-ink); background: var(--ksn-surface); }
.ksn-tabs--classic .ksn-tabs__tab.is-active {
	z-index: 2; color: var(--ksn-surface);
	background: var(--ksn-ink); border-color: var(--ksn-ink);
}
.ksn-tabs--classic .ksn-tabs__tab.is-active .ksn-tabs__tab-ico { color: var(--ksn-surface); }

/* the content sits as a connected sheet under the tab strip; the cut corner
   lives at the bottom-right of the whole widget */
.ksn-tabs--classic .ksn-tabs__panels {
	margin-top: -1px; padding: 0; overflow: hidden;
	background: var(--ksn-surface); border: 1px solid var(--ksn-line); border-radius: 0 0 0 12px;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 28px), calc(100% - 28px) 100%, 0 100%);
}
.ksn-tabs--classic .ksn-tabs__rich,
.ksn-tabs--classic .ksn-tabs__reviews { padding: 26px 28px; }
.ksn-tabs--classic .ksn-tabs__videos { padding: 24px; }
.ksn-tabs--classic .ksn-tabs__specs { border: none; border-radius: 0; }
.ksn-tabs--classic .ksn-tabs__specs-head { display: none; }
@media (max-width: 600px) { .ksn-tabs--classic .ksn-tabs__nav { overflow-x: auto; } .ksn-tabs--classic .ksn-tabs__tab { flex: 1 0 auto; } }

/* legacy alias: old "boxed" selection now maps to the segment look */
.ksn-tabs--boxed .ksn-tabs__nav {
	display: inline-flex; gap: 4px; padding: 6px; border-radius: 16px; max-width: 100%;
	background: var(--ksn-surface-2); border: 1px solid var(--ksn-line);
}
.ksn-tabs--boxed .ksn-tabs__tab { padding: 11px 22px; border-radius: 11px; }
.ksn-tabs--boxed .ksn-tabs__tab.is-active { background: var(--ksn-surface); color: var(--ksn-primary); box-shadow: 0 6px 16px -8px rgba(13,27,52,.45); }

/* dark-mode polish for token-driven styles */
.ksn-dark .ksn-tabs--segment .ksn-tabs__nav { box-shadow: inset 0 2px 6px -4px rgba(0,0,0,.5); }
.ksn-dark .ksn-tabs--segment .ksn-tabs__tab.is-active,
.ksn-dark .ksn-tabs--card .ksn-tabs__tab.is-active { box-shadow: 0 10px 24px -14px rgba(0,0,0,.6); }

/* ---- content ---- */
/* section heading with accent bar */
.ksn-tabs__section-title {
	position: relative; margin: 0 0 18px; padding-inline-start: 15px;
	font-family: var(--ksn-font); font-weight: 900; font-size: 1.25rem; color: var(--ksn-ink);
}
.ksn-tabs__section-title::before {
	content: ""; position: absolute; inset-inline-start: 0; top: 3px; bottom: 3px; width: 4px; border-radius: 4px;
	background: linear-gradient(180deg, var(--ksn-heat), var(--ksn-accent));
}

/* rich description */
.ksn-tabs__rich { color: var(--ksn-muted); line-height: 2.15; font-size: 0.97rem; text-align: justify; }
.ksn-tabs__rich p { margin: 0 0 1.1em; }
.ksn-tabs__rich p:last-child { margin-bottom: 0; }
.ksn-tabs__rich h2, .ksn-tabs__rich h3, .ksn-tabs__rich h4 { color: var(--ksn-ink); margin: 1.3em 0 .5em; font-weight: 800; }
.ksn-tabs__rich a { color: var(--ksn-accent); font-weight: 700; }
.ksn-tabs__rich img { max-width: 100%; height: auto; border-radius: var(--ksn-radius); margin: 1em 0; }
.ksn-tabs__rich ul, .ksn-tabs__rich ol { padding-inline-start: 1.4em; margin: 0 0 1.1em; line-height: 2.1; }
.ksn-tabs__rich li { margin-bottom: .4em; }

/* specs table — our own clean markup: bold labels on the right, plain values on the left, zebra */
.ksn-tabs__specs {
	border: 1px solid var(--ksn-line); border-radius: 16px; overflow: hidden;
	background: var(--ksn-surface);
}
.ksn-tabs__specs-head {
	display: flex; align-items: center; gap: 10px;
	padding: 16px 22px; font-family: var(--ksn-font); font-weight: 900; font-size: 1.02rem; color: #fff;
	background: linear-gradient(120deg, var(--ksn-primary), var(--ksn-accent));
}
.ksn-tabs__specs-ico {
	width: 18px; height: 18px; flex: none; opacity: .95;
	background: currentColor;
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4 5h16v3H4zM4 10.5h16v3H4zM4 16h10v3H4z'/%3E%3C/svg%3E") center/contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4 5h16v3H4zM4 10.5h16v3H4zM4 16h10v3H4z'/%3E%3C/svg%3E") center/contain no-repeat;
}
.ksn-specs { width: 100%; border-collapse: collapse; font-family: var(--ksn-font); }
.ksn-specs th.ksn-spec__label,
.ksn-specs td.ksn-spec__value {
	padding: 15px 22px; border-bottom: 1px solid var(--ksn-line); font-size: 0.95rem; vertical-align: middle; line-height: 1.8;
}
/* labels stick to the right, bold dark — never colored */
.ksn-specs th.ksn-spec__label {
	width: 32%; text-align: start; font-weight: 800; color: var(--ksn-ink) !important;
	background: color-mix(in srgb, var(--ksn-surface-2) 100%, var(--ksn-ink) 3%);
}
/* values go to the left, clean muted text — strip any inherited theme color/link styling */
.ksn-specs td.ksn-spec__value {
	text-align: end; font-weight: 600; color: var(--ksn-muted) !important; background: transparent;
}
.ksn-specs td.ksn-spec__value a { color: inherit !important; text-decoration: none; }
.ksn-specs tr:nth-child(even) td.ksn-spec__value { background: color-mix(in srgb, var(--ksn-surface) 100%, var(--ksn-ink) 2%); }
.ksn-specs tr:last-child th.ksn-spec__label,
.ksn-specs tr:last-child td.ksn-spec__value { border-bottom: none; }
.ksn-specs tr:hover th.ksn-spec__label,
.ksn-specs tr:hover td.ksn-spec__value { background: rgba(var(--ksn-accent-rgb), .06); }

/* videos grid */
.ksn-tabs__videos { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 14px; }
.ksn-tabs__video {
	position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px;
	aspect-ratio: 16/10; padding: 16px; cursor: pointer; overflow: hidden;
	background: var(--ksn-surface-2); border: 1px solid var(--ksn-line);
	border-radius: 16px; color: var(--ksn-ink); font-family: var(--ksn-font); font-weight: 800; font-size: 0.92rem;
	transition: border-color .18s ease, transform .18s ease, box-shadow .18s ease;
}
.ksn-tabs__video:hover { border-color: var(--ksn-accent); transform: translateY(-3px); box-shadow: var(--ksn-shadow); }
.ksn-tabs__video-thumb {
	position: absolute; inset: 0; background-size: cover; background-position: center;
}
.ksn-tabs__video-thumb::after {
	content: ""; position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,.1), rgba(0,0,0,.55));
}
.ksn-tabs__video-play {
	position: relative; z-index: 1;
	width: 52px; height: 52px; border-radius: 50%;
	background: linear-gradient(120deg, var(--ksn-primary), var(--ksn-accent))
		url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M8 5v14l11-7z'/%3E%3C/svg%3E") center/20px no-repeat;
	box-shadow: 0 12px 26px -10px rgba(var(--ksn-accent-rgb), .6);
	transition: transform .2s ease;
}
.ksn-tabs__video:hover .ksn-tabs__video-play { transform: scale(1.08); }
.ksn-tabs__video-title { position: relative; z-index: 1; text-align: center; }
.ksn-tabs__video:has(.ksn-tabs__video-thumb) .ksn-tabs__video-title { color: #fff; text-shadow: 0 2px 8px rgba(0,0,0,.5); }

/* video modal */
.ksn-vmodal {
	position: fixed; inset: 0; z-index: 99999; display: grid; place-items: center;
	background: rgba(6,10,18,.88); opacity: 0; transition: opacity .25s ease; padding: 24px;
}
.ksn-vmodal.is-open { opacity: 1; }
.ksn-vmodal__frame {
	width: min(960px, 100%); aspect-ratio: 16/9; border-radius: 14px; overflow: hidden;
	background: #000; box-shadow: 0 30px 70px -20px rgba(0,0,0,.6);
	transform: scale(.92); transition: transform .25s ease;
}
.ksn-vmodal.is-open .ksn-vmodal__frame { transform: scale(1); }
.ksn-vmodal__frame iframe, .ksn-vmodal__frame video { width: 100%; height: 100%; border: none; display: block; }
.ksn-vmodal__close {
	position: absolute; top: 18px; inset-inline-end: 22px; width: 42px; height: 42px; border-radius: 50%;
	background: rgba(255,255,255,.1); color: #fff; border: none; font-size: 1.6rem; line-height: 1; cursor: pointer;
	transition: background .15s ease;
}
.ksn-vmodal__close:hover { background: rgba(255,255,255,.2); }

/* reviews — keep WooCommerce markup readable in both themes */
.ksn-tabs__reviews { color: var(--ksn-ink); }
.ksn-tabs__reviews .comment-text, .ksn-tabs__reviews p { color: var(--ksn-muted); line-height: 1.9; }
.ksn-tabs__reviews .comment-form input[type="text"],
.ksn-tabs__reviews .comment-form input[type="email"],
.ksn-tabs__reviews .comment-form textarea {
	width: 100%; padding: 10px 12px; border: 1px solid var(--ksn-line);
	border-radius: 10px; background: var(--ksn-surface-2); color: var(--ksn-ink); font-family: var(--ksn-font);
}
.ksn-tabs__reviews .submit, .ksn-tabs__reviews button {
	background: var(--ksn-primary) !important; color: #fff !important; border: none !important;
	padding: 10px 24px !important; border-radius: 12px !important; font-weight: 800 !important; cursor: pointer;
}
