/* T'Loosa Date Night Planner v2 */
.tldnp,
.tldnp * {
	box-sizing: border-box;
}

.tldnp {
	--tldnp-bg: #160f14;
	--tldnp-panel: #21151d;
	--tldnp-panel-soft: #2b1b25;
	--tldnp-gold: #c9a227;
	--tldnp-gold-light: #ead98f;
	--tldnp-burgundy: #8a5a3c;
	--tldnp-text: #fffaf2;
	--tldnp-muted: #d8cbd2;
	--tldnp-border: rgba(201, 162, 39, 0.28);
	--tldnp-shadow: 0 24px 70px rgba(0, 0, 0, 0.32);
	width: 100%;
	margin: 24px auto;
	color: var(--tldnp-text);
	font-family: inherit;
}

.tldnp-card {
	max-width: 980px;
	margin: 0 auto;
	padding: clamp(22px, 4vw, 48px);
	border: 1px solid var(--tldnp-border);
	border-radius: 24px;
	background:
		radial-gradient(circle at top right, rgba(138, 90, 60, 0.22), transparent 34%),
		linear-gradient(145deg, var(--tldnp-bg), var(--tldnp-panel));
	box-shadow: var(--tldnp-shadow);
	overflow: hidden;
}

.tldnp-header {
	max-width: 760px;
	margin-bottom: 28px;
}

.tldnp-kicker {
	margin: 0 0 8px;
	color: var(--tldnp-gold-light);
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.13em;
	text-transform: uppercase;
}

.tldnp h2,
.tldnp h3,
.tldnp h4,
.tldnp p {
	color: inherit;
}

.tldnp h2 {
	margin: 0 0 12px;
	font-size: clamp(2rem, 5vw, 3.35rem);
	line-height: 1.05;
}

.tldnp-header > p:last-child {
	max-width: 720px;
	margin: 0;
	color: var(--tldnp-muted);
	font-size: 1.05rem;
	line-height: 1.65;
}

.tldnp-progress-wrap {
	margin: 0 0 34px;
}

.tldnp-progress-copy {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 9px;
	color: var(--tldnp-muted);
	font-size: 0.9rem;
	font-weight: 700;
}

.tldnp-progress {
	height: 10px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.1);
	overflow: hidden;
}

.tldnp-progress span {
	display: block;
	height: 100%;
	border-radius: inherit;
	background: linear-gradient(90deg, var(--tldnp-burgundy), var(--tldnp-gold));
	transition: width 220ms ease;
}

.tldnp-step {
	min-width: 0;
	margin: 0;
	padding: 0;
	border: 0;
}

.tldnp-step legend {
	width: 100%;
	margin: 0 0 20px;
	padding: 0;
	color: var(--tldnp-text);
	font-size: clamp(1.35rem, 3vw, 1.9rem);
	font-weight: 800;
	line-height: 1.25;
}

.tldnp-options {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 13px;
}

.tldnp-option {
	min-height: 58px;
	padding: 14px 16px;
	border: 1px solid rgba(255, 255, 255, 0.13);
	border-radius: 14px;
	background: rgba(255, 255, 255, 0.045);
	color: var(--tldnp-text);
	font: inherit;
	font-weight: 750;
	text-align: left;
	cursor: pointer;
	transition: transform 150ms ease, border-color 150ms ease, background 150ms ease;
}

.tldnp-option:hover,
.tldnp-option:focus-visible {
	transform: translateY(-1px);
	border-color: var(--tldnp-gold);
	outline: none;
}

.tldnp-option.is-selected {
	border-color: var(--tldnp-gold);
	background: rgba(201, 162, 39, 0.14);
	box-shadow: inset 0 0 0 1px rgba(201, 162, 39, 0.45);
}

.tldnp-nav,
.tldnp-cta-row {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 28px;
}

.tldnp-nav {
	justify-content: space-between;
}

.tldnp-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 12px 21px;
	border: 1px solid transparent;
	border-radius: 999px;
	font: inherit;
	font-weight: 850;
	line-height: 1.1;
	text-decoration: none !important;
	cursor: pointer;
	transition: transform 150ms ease, filter 150ms ease, opacity 150ms ease;
}

.tldnp-button:hover,
.tldnp-button:focus-visible {
	transform: translateY(-1px);
	filter: brightness(1.08);
	outline: 2px solid var(--tldnp-gold-light);
	outline-offset: 3px;
}

.tldnp-button:disabled {
	opacity: 0.42;
	cursor: not-allowed;
	transform: none;
}

.tldnp-button-primary {
	background: var(--tldnp-burgundy);
	color: #ffffff !important;
}

.tldnp-button-secondary {
	border-color: rgba(255, 255, 255, 0.23);
	background: transparent;
	color: var(--tldnp-text);
}

.tldnp-button-gold {
	background: var(--tldnp-gold);
	color: #17100f !important;
}

.tldnp-result {
	animation: tldnpFadeIn 240ms ease;
}

.tldnp-result h3 {
	margin: 0 0 22px;
	font-size: clamp(1.8rem, 4vw, 2.7rem);
	line-height: 1.12;
}

.tldnp-result-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.55fr) minmax(260px, 0.85fr);
	gap: 18px;
}

.tldnp-result-main,
.tldnp-result-facts {
	border: 1px solid var(--tldnp-border);
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.045);
}

.tldnp-result-main {
	padding: 24px;
}

.tldnp-result-main h4 {
	margin: 0 0 10px;
	font-size: 1.05rem;
}

.tldnp-route {
	margin: 0;
	font-size: 1.12rem;
	font-weight: 700;
	line-height: 1.65;
}

.tldnp-tip {
	margin: 15px 0 0;
	color: var(--tldnp-muted);
	line-height: 1.55;
}

.tldnp-result-facts {
	display: grid;
	overflow: hidden;
}

.tldnp-result-facts > div {
	padding: 17px 20px;
	border-bottom: 1px solid var(--tldnp-border);
}

.tldnp-result-facts > div:last-child {
	border-bottom: 0;
}

.tldnp-result-facts span,
.tldnp-result-facts strong {
	display: block;
}

.tldnp-result-facts span {
	margin-bottom: 4px;
	color: var(--tldnp-muted);
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.tldnp-result-facts strong {
	color: var(--tldnp-text);
	font-size: 1rem;
}

.tldnp-tools {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 18px;
	margin-top: 22px;
}

.tldnp-text-button {
	padding: 0;
	border: 0;
	border-bottom: 1px solid currentColor;
	background: transparent;
	color: var(--tldnp-gold-light);
	font: inherit;
	font-size: 0.92rem;
	font-weight: 800;
	cursor: pointer;
}

.tldnp-status {
	min-height: 1.4em;
	margin: 12px 0 0;
	color: var(--tldnp-gold-light);
	font-size: 0.9rem;
}

.tldnp-disclaimer {
	margin: 16px 0 0;
	color: var(--tldnp-muted);
	font-size: 0.82rem;
	line-height: 1.5;
}

@keyframes tldnpFadeIn {
	from { opacity: 0; transform: translateY(6px); }
	to { opacity: 1; transform: translateY(0); }
}

@media (max-width: 720px) {
	.tldnp-card {
		padding: 22px 17px;
		border-radius: 18px;
	}

	.tldnp-options,
	.tldnp-result-grid {
		grid-template-columns: 1fr;
	}

	.tldnp-option {
		min-height: 54px;
	}

	.tldnp-nav .tldnp-button,
	.tldnp-cta-row .tldnp-button {
		flex: 1 1 100%;
	}

	.tldnp-nav {
		flex-direction: column-reverse;
	}
}

@media (prefers-reduced-motion: reduce) {
	.tldnp *,
	.tldnp *::before,
	.tldnp *::after {
		scroll-behavior: auto !important;
		transition: none !important;
		animation: none !important;
	}
}
