/* =========================================================================
   KeepSeal Neo — professional in-page search box
   ========================================================================= */
.ksn-searchbox-wrap {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 14px;
	width: 100%;
}

.ksn-searchbox {
	width: 100%;
	max-width: 620px;
	position: relative;
}

/* ---------- Live-search results dropdown ---------- */
.ksn-searchbox__results {
	position: absolute;
	top: calc(100% + 10px);
	inset-inline: 0;
	z-index: 60;
	background: var(--ksn-surface);
	border: 1px solid var(--ksn-line);
	border-radius: calc(var(--ksn-radius) + 4px);
	box-shadow: 0 30px 70px -28px rgba(13,27,52,.5), 0 6px 18px -10px rgba(13,27,52,.2);
	overflow: hidden;
	max-height: 60vh;
	overflow-y: auto;
	text-align: start;
}
.ksn-sresults__list { display: block; }
.ksn-sresult {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 14px;
	text-decoration: none;
	color: var(--ksn-ink);
	border-bottom: 1px solid var(--ksn-line);
	transition: background .15s ease;
}
.ksn-sresult:last-child { border-bottom: none; }
.ksn-sresult:hover,
.ksn-sresult.is-active { background: var(--ksn-surface-2); }
.ksn-sresult__img {
	flex: none;
	width: 48px; height: 48px;
	border-radius: 10px;
	overflow: hidden;
	background: var(--ksn-surface-2);
	display: grid; place-items: center;
}
.ksn-sresult__img img { width: 100%; height: 100%; object-fit: cover; }
.ksn-sresult__body { flex: 1; min-width: 0; }
.ksn-sresult__title {
	display: block;
	font-weight: 700;
	font-size: 0.94rem;
	color: var(--ksn-ink);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.ksn-sresult__price {
	display: block;
	margin-top: 3px;
	font-size: 0.85rem;
	font-weight: 800;
	color: var(--ksn-accent);
}
.ksn-sresult__price del { color: var(--ksn-muted); font-weight: 500; margin-inline-end: 6px; }
.ksn-sresult__price ins { text-decoration: none; }

.ksn-sresults__more {
	display: block;
	padding: 12px 14px;
	text-align: center;
	font-weight: 800;
	font-size: 0.88rem;
	color: var(--ksn-primary);
	background: var(--ksn-surface-2);
	text-decoration: none;
}
.ksn-sresults__more:hover { color: var(--ksn-accent); }
.ksn-sresults__status,
.ksn-sresults__empty {
	padding: 18px 14px;
	text-align: center;
	font-size: 0.9rem;
	color: var(--ksn-muted);
}

/* Base layout (chrome comes from the style modifier on .ksn-searchbox-wrap) */
.ksn-searchbox__form {
	display: flex;
	align-items: center;
	gap: 8px;
	position: relative;
	background: transparent;
	border: 0 solid transparent;
	border-radius: var(--ksn-radius);
	padding: 7px 8px 7px 7px;
	transition: box-shadow .25s ease, border-color .25s ease, transform .25s ease, background .25s ease;
}

/* ===== Style: solid (default) — clean filled, NO border ===== */
.ksn-searchbox--solid .ksn-searchbox__form {
	background: var(--ksn-surface);
	border-radius: 999px;
	box-shadow: 0 18px 50px -28px rgba(13,27,52,.55);
}
.ksn-searchbox--solid .ksn-searchbox__form:focus-within {
	box-shadow: 0 22px 60px -26px rgba(var(--ksn-primary-rgb), .55), 0 0 0 4px rgba(var(--ksn-primary-rgb), .12);
	transform: translateY(-2px);
}

/* ===== Style: pill — filled + subtle border ===== */
.ksn-searchbox--pill .ksn-searchbox__form {
	background: var(--ksn-surface);
	border: 1px solid var(--ksn-line);
	border-radius: 999px;
	box-shadow: 0 18px 50px -28px rgba(13,27,52,.55);
}
.ksn-searchbox--pill .ksn-searchbox__form:focus-within {
	border-color: rgba(var(--ksn-primary-rgb), .5);
	box-shadow: 0 22px 60px -26px rgba(var(--ksn-primary-rgb), .6), 0 0 0 4px rgba(var(--ksn-primary-rgb), .1);
	transform: translateY(-2px);
}

/* ===== Style: glass — frosted (great over dark hero) ===== */
.ksn-searchbox--glass .ksn-searchbox__form {
	background: color-mix(in srgb, var(--ksn-surface) 30%, transparent);
	border: 1px solid rgba(255,255,255,.22);
	border-radius: 999px;
	backdrop-filter: blur(16px) saturate(1.4);
	-webkit-backdrop-filter: blur(16px) saturate(1.4);
	box-shadow: 0 18px 50px -26px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.25);
}
.ksn-searchbox--glass .ksn-searchbox__form:focus-within {
	border-color: rgba(255,255,255,.4);
	transform: translateY(-2px);
}

/* ===== Style: outline — modern thin outline, no shadow ===== */
.ksn-searchbox--outline .ksn-searchbox__form {
	background: transparent;
	border: 2px solid var(--ksn-line);
	border-radius: var(--ksn-radius);
}
.ksn-searchbox--outline .ksn-searchbox__form:focus-within {
	border-color: var(--ksn-primary);
	box-shadow: 0 0 0 4px rgba(var(--ksn-primary-rgb), .1);
}

/* ===== Style: minimal — borderless, animated underline ===== */
.ksn-searchbox--minimal .ksn-searchbox__form {
	background: transparent;
	border-radius: 0;
	border-bottom: 2px solid var(--ksn-line);
	padding: 4px 6px;
}
.ksn-searchbox--minimal .ksn-searchbox__form::after {
	content: "";
	position: absolute;
	bottom: -2px; inset-inline-start: 0;
	height: 2px; width: 0;
	background: var(--ksn-primary);
	transition: width .35s cubic-bezier(.16,1,.3,1);
}
.ksn-searchbox--minimal .ksn-searchbox__form:focus-within::after { width: 100%; }
.ksn-searchbox--minimal .ksn-searchbox__btn { border-radius: var(--ksn-radius); }

/* ===== Style: split — input and button separated ===== */
.ksn-searchbox--split .ksn-searchbox__form {
	background: transparent;
	gap: 12px;
	padding: 0;
}
.ksn-searchbox--split .ksn-searchbox__input {
	background: var(--ksn-surface);
	border-radius: 999px;
	box-shadow: 0 14px 40px -26px rgba(13,27,52,.55);
	padding-inline: 52px 18px;
}
.ksn-searchbox--split .ksn-searchbox__icon { inset-inline-start: 22px; }
.ksn-searchbox--split .ksn-searchbox__btn { box-shadow: 0 14px 30px -14px rgba(var(--ksn-primary-rgb), .6); }

/* magnifier sits at the start (right in RTL) of the input area */
.ksn-searchbox__icon {
	position: absolute;
	inset-inline-start: 20px;
	color: var(--ksn-muted);
	pointer-events: none;
	display: flex;
	transition: color .2s ease;
}
.ksn-searchbox__form:focus-within .ksn-searchbox__icon { color: var(--ksn-primary); }

.ksn-searchbox__input {
	flex: 1;
	min-width: 0;
	height: 50px;
	border: none;
	outline: none;
	box-shadow: none;
	-webkit-appearance: none;
	appearance: none;
	background: transparent;
	padding: 0 52px 0 8px;
	font-family: var(--ksn-font);
	font-size: 1.05rem;
	color: var(--ksn-ink);
}
.ksn-searchbox__input::placeholder { color: var(--ksn-muted); }
.ksn-searchbox__input:focus,
.ksn-searchbox__input:focus-visible { outline: none; box-shadow: none; border: none; }
/* kill the native search-field chrome (inner border / clear button) */
.ksn-searchbox__input::-webkit-search-decoration,
.ksn-searchbox__input::-webkit-search-cancel-button,
.ksn-searchbox__input::-webkit-search-results-button,
.ksn-searchbox__input::-webkit-search-results-decoration { -webkit-appearance: none; display: none; }

.ksn-searchbox__btn {
	flex: none;
	height: 50px;
	padding: 0 30px;
	border: none;
	border-radius: 999px;
	background: var(--ksn-primary);
	color: #fff;
	font-family: var(--ksn-font);
	font-weight: 800;
	font-size: 1rem;
	cursor: pointer;
	transition: background .2s ease, transform .2s ease, box-shadow .2s ease;
}
.ksn-searchbox__btn:hover {
	background: var(--ksn-accent);
	transform: translateY(-1px);
	box-shadow: 0 12px 26px -12px rgba(var(--ksn-accent-rgb), .7);
}
.ksn-searchbox__btn:active { transform: translateY(0); }

/* ---------- Popular chips ---------- */
.ksn-searchbox__popular {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
}
.ksn-searchbox__poplabel {
	font-size: 0.88rem;
	font-weight: 700;
	color: var(--ksn-muted);
}
.ksn-searchbox__chips { display: inline-flex; flex-wrap: wrap; gap: 8px; }
.ksn-searchbox__chip {
	display: inline-flex;
	align-items: center;
	padding: 8px 16px;
	border-radius: 999px;
	background: var(--ksn-surface);
	border: 1px solid var(--ksn-line);
	color: var(--ksn-ink);
	font-size: 0.86rem;
	font-weight: 600;
	text-decoration: none;
	transition: transform .18s ease, border-color .18s ease, color .18s ease, background .18s ease, box-shadow .18s ease;
}
.ksn-searchbox__chip:hover {
	transform: translateY(-2px);
	border-color: transparent;
	color: #fff;
	background: var(--ksn-primary);
	box-shadow: 0 10px 22px -12px rgba(var(--ksn-primary-rgb), .7);
}

/* On dark surfaces (e.g. inside a dark hero) lift the contrast. */
.ksn-dark .ksn-searchbox__poplabel { color: #a9bcdc; }

@media (max-width: 520px) {
	.ksn-searchbox__btn { padding: 0 18px; }
	.ksn-searchbox__input { font-size: 0.98rem; }
}
