.nb-katina-widget {
	--nb-katina-bg: #1a1635;
	--nb-katina-panel: #251d46;
	--nb-katina-bordo: #7b1f3a;
	--nb-katina-rose: #e9a3b2;
	--nb-katina-gold: #d9bd75;
	--nb-katina-text: #fff7fb;
	--nb-katina-muted: #dacfe7;
	--nb-katina-border: rgba(217, 189, 117, 0.35);
	max-width: 960px;
	margin: 0 auto;
	color: var(--nb-katina-text);
}

.nb-katina-widget * {
	box-sizing: border-box;
}

.nb-katina-shell {
	overflow: hidden;
	border: 1px solid var(--nb-katina-border);
	border-radius: 18px;
	background:
		radial-gradient(circle at top left, rgba(233, 163, 178, 0.16), transparent 34%),
		linear-gradient(135deg, var(--nb-katina-bg), #101a36 62%, #2a1330);
	box-shadow: 0 18px 48px rgba(15, 11, 35, 0.22);
	padding: 22px;
}

.nb-katina-header {
	text-align: center;
	margin-bottom: 18px;
}

.nb-katina-title {
	margin: 0 0 8px;
	color: var(--nb-katina-text);
	font-size: clamp(24px, 4vw, 34px);
	line-height: 1.15;
	letter-spacing: 0;
}

.nb-katina-subtitle,
.nb-katina-intro p,
.nb-katina-disclaimer,
.nb-katina-cta,
.nb-katina-share-note,
.nb-katina-rating-note {
	color: var(--nb-katina-muted);
	font-size: 15px;
	line-height: 1.55;
}

.nb-katina-intro {
	display: grid;
	gap: 8px;
	margin-bottom: 18px;
	padding: 14px;
	border: 1px solid rgba(233, 163, 178, 0.22);
	border-radius: 14px;
	background: rgba(255, 255, 255, 0.06);
}

.nb-katina-intro p {
	margin: 0;
}

.nb-katina-intro strong {
	color: #fff;
	font-size: 15px;
}

.nb-katina-card-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	justify-items: center;
	min-height: 660px;
}

.nb-katina-card {
	width: min(100%, 174px);
	aspect-ratio: 5 / 7;
	min-height: 244px;
	padding: 0;
	border: 0;
	border-radius: 18px;
	background: transparent;
	color: inherit;
	cursor: pointer;
	perspective: 900px;
	transition: transform 0.22s ease, filter 0.22s ease;
}

.nb-katina-card:hover:not(:disabled) {
	filter: drop-shadow(0 18px 26px rgba(217, 189, 117, 0.2));
	transform: translateY(-5px) rotate(-1deg);
}

.nb-katina-card:focus-visible {
	outline: 3px solid var(--nb-katina-gold);
	outline-offset: 3px;
}

.nb-katina-card:disabled {
	cursor: default;
}

.nb-katina-card.is-dimmed {
	opacity: 0.5;
}

.nb-katina-card-inner {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
	min-height: 244px;
	transform-style: preserve-3d;
	transition: transform 0.55s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.nb-katina-card.is-open .nb-katina-card-inner {
	transform: rotateY(180deg);
}

.nb-katina-card-back,
.nb-katina-card-front {
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	min-height: 244px;
	padding: 14px;
	border: 1px solid var(--nb-katina-border);
	border-radius: 18px;
	backface-visibility: hidden;
	box-shadow:
		0 16px 26px rgba(6, 9, 28, 0.26),
		inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.nb-katina-card-back {
	background:
		radial-gradient(circle at 50% 44%, rgba(217, 189, 117, 0.22) 0 2px, transparent 3px 100%),
		linear-gradient(45deg, rgba(255, 255, 255, 0.05) 25%, transparent 25% 50%, rgba(255, 255, 255, 0.05) 50% 75%, transparent 75%),
		linear-gradient(145deg, #201440, #711f3b 58%, #101a36);
	background-size: auto, 18px 18px, auto;
}

.nb-katina-card-back::before {
	content: "";
	position: absolute;
	inset: 12px;
	border: 2px solid rgba(217, 189, 117, 0.55);
	border-radius: 14px;
}

.nb-katina-card-back::after {
	content: "♥";
	position: absolute;
	color: rgba(217, 189, 117, 0.42);
	font-family: Georgia, serif;
	font-size: 52px;
}

.nb-katina-card-back span {
	display: grid;
	place-items: center;
	position: relative;
	z-index: 1;
	width: 68%;
	min-height: 110px;
	border: 1px solid rgba(217, 189, 117, 0.5);
	border-radius: 12px;
	color: var(--nb-katina-gold);
	font-weight: 800;
	background: rgba(16, 26, 54, 0.36);
	text-transform: uppercase;
}

.nb-katina-card-front {
	transform: rotateY(180deg);
	background:
		radial-gradient(circle at center, rgba(217, 189, 117, 0.18), transparent 36%),
		linear-gradient(145deg, #fff7fb, #f4e3e9);
	color: #32142f;
	text-align: center;
}

.nb-katina-card-front::before {
	content: "♥";
	position: absolute;
	top: 18px;
	left: 18px;
	color: #7b1f3a;
	font-family: Georgia, serif;
	font-size: 22px;
}

.nb-katina-card-front::after {
	content: "♥";
	position: absolute;
	right: 18px;
	bottom: 18px;
	color: #7b1f3a;
	font-family: Georgia, serif;
	font-size: 22px;
	transform: rotate(180deg);
}

.nb-katina-card-front strong {
	display: block;
	max-width: 116px;
	font-size: 21px;
	line-height: 1.2;
}

.nb-katina-card-front small {
	display: block;
	margin-top: 6px;
	color: #7b1f3a;
	font-weight: 700;
}

.nb-katina-result {
	margin-top: 18px;
	padding: 18px;
	border: 1px solid var(--nb-katina-border);
	border-radius: 16px;
	background: rgba(255, 255, 255, 0.08);
}

.nb-katina-result[hidden] {
	display: none;
}

.nb-katina-result-kicker {
	margin: 0 0 6px;
	color: var(--nb-katina-gold);
	font-size: 13px;
	font-weight: 800;
	text-transform: uppercase;
}

.nb-katina-card-name {
	margin: 0 0 10px;
	color: #fff;
	font-size: 24px;
	line-height: 1.2;
}

.nb-katina-comment {
	margin: 0 0 16px;
	color: var(--nb-katina-text);
	font-size: 16px;
	line-height: 1.65;
}

.nb-katina-rating {
	margin: 16px 0;
}

.nb-katina-rating p {
	margin: 0 0 8px;
	color: #fff;
	font-weight: 700;
}

.nb-katina-stars {
	display: flex;
	gap: 6px;
}

.nb-katina-star {
	width: 42px;
	height: 42px;
	border: 1px solid rgba(217, 189, 117, 0.4);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.08);
	color: rgba(255, 255, 255, 0.52);
	font-size: 22px;
	cursor: pointer;
}

.nb-katina-star.is-active {
	background: rgba(217, 189, 117, 0.18);
	color: var(--nb-katina-gold);
}

.nb-katina-actions {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 14px;
}

.nb-katina-share-panel {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	width: 100%;
	margin-top: 4px;
}

.nb-katina-share-panel[hidden] {
	display: none;
}

.nb-katina-share-option {
	min-height: 40px;
	padding: 9px 14px;
	border: 1px solid rgba(217, 189, 117, 0.46);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.1);
	color: #fff;
	font-weight: 800;
	cursor: pointer;
}

.nb-katina-share-option:hover,
.nb-katina-share-option:focus-visible {
	background: rgba(217, 189, 117, 0.22);
}

.nb-katina-action-btn {
	min-height: 44px;
	padding: 11px 16px;
	border: 1px solid rgba(217, 189, 117, 0.5);
	border-radius: 999px;
	background: var(--nb-katina-bordo);
	color: #fff;
	font-weight: 800;
	cursor: pointer;
}

.nb-katina-action-btn:hover,
.nb-katina-action-btn:focus-visible {
	background: #8f2947;
	color: #fff;
}

.nb-katina-share-note,
.nb-katina-rating-note,
.nb-katina-cta {
	margin: 10px 0 0;
}

.nb-katina-disclaimer {
	margin: 18px 0 0;
	padding-top: 14px;
	border-top: 1px solid rgba(217, 189, 117, 0.25);
	font-size: 13px;
}

@media (max-width: 768px) {
	.nb-katina-shell {
		padding: 16px;
		border-radius: 14px;
	}

	.nb-katina-card-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 12px;
		min-height: 780px;
	}

	.nb-katina-card,
	.nb-katina-card-inner,
	.nb-katina-card-back,
	.nb-katina-card-front {
		min-height: 244px;
	}

	.nb-katina-actions {
		flex-direction: column;
	}

	.nb-katina-action-btn {
		width: 100%;
	}
}
