/* ==========================================================================
   Wellness Guide — Component Styles
   ========================================================================== */

/* Custom properties scoped to the component */
.wellness-guide {
	--wg-font:       inherit;
	--wg-clr-bg:     #faf9f7;
	--wg-clr-card:   #ffffff;
	--wg-clr-border: #e8e4df;
	--wg-clr-text:   #2d2926;
	--wg-clr-muted:  #7a7068;
	--wg-clr-accent: #5c7a6e;       /* muted sage — grounded, natural */
	--wg-clr-accent-light: #eaf2ee;
	--wg-clr-accent-dark:  #3d5c52;
	--wg-clr-selected-bg:  #eaf2ee;
	--wg-clr-selected-border: #5c7a6e;
	--wg-radius:     12px;
	--wg-radius-sm:  8px;
	--wg-shadow:     0 2px 16px rgba(0, 0, 0, 0.07);
	--wg-transition: 0.28s ease;
	--wg-max-width:  640px;
}

/* Base container */
.wellness-guide {
	font-family: var( --wg-font );
	color: var( --wg-clr-text );
	max-width: var( --wg-max-width );
	margin: 0 auto;
	padding: 16px;
	box-sizing: border-box;
}

*, *::before, *::after {
	box-sizing: inherit;
}

/* ==========================================================================
   Screens (intro / questions / result)
   ========================================================================== */

.wg-screen {
	opacity: 0;
	transform: translateY( 8px );
	transition: opacity var( --wg-transition ), transform var( --wg-transition );
	background: var( --wg-clr-card );
	border-radius: var( --wg-radius );
	box-shadow: var( --wg-shadow );
	padding: 40px 36px;
}

.wg-screen[hidden] {
	display: none;
}

.wg-screen.is-visible {
	opacity: 1;
	transform: translateY( 0 );
}

/* ==========================================================================
   Intro screen
   ========================================================================== */

.wg-intro {
	text-align: center;
}

.wg-intro-icon {
	display: block;
	margin: 0 auto 22px;
	color: var( --wg-clr-accent );
	opacity: 0.75;
}

.wg-title {
	font-size: 1.6rem;
	font-weight: 600;
	margin: 0 0 12px;
	color: var( --wg-clr-text );
	letter-spacing: -0.01em;
}

.wg-subtitle {
	font-size: 0.975rem;
	color: var( --wg-clr-muted );
	line-height: 1.7;
	margin: 0 0 32px;
	max-width: 460px;
	margin-left: auto;
	margin-right: auto;
}

/* ==========================================================================
   Progress bar
   ========================================================================== */

.wg-progress {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 28px;
}

.wg-progress-track {
	flex: 1;
	height: 4px;
	background: var( --wg-clr-border );
	border-radius: 99px;
	overflow: hidden;
}

.wg-progress-fill {
	height: 100%;
	background: var( --wg-clr-accent );
	border-radius: 99px;
	transition: width 0.4s ease;
}

.wg-progress-label {
	font-size: 0.75rem;
	color: var( --wg-clr-muted );
	white-space: nowrap;
	letter-spacing: 0.04em;
	font-variant-numeric: tabular-nums;
}

/* ==========================================================================
   Question
   ========================================================================== */

.wg-question-inner {
	opacity: 1;
	transform: translateX( 0 );
	transition: opacity 0.22s ease, transform 0.22s ease;
}

.wg-question-inner.wg-exit {
	opacity: 0;
	transform: translateX( -12px );
}

.wg-question-text {
	font-size: 1.15rem;
	font-weight: 600;
	color: var( --wg-clr-text );
	margin: 0 0 6px;
	line-height: 1.45;
}

.wg-question-note {
	font-size: 0.85rem;
	color: var( --wg-clr-muted );
	font-style: italic;
	margin: 0 0 20px;
}

/* ==========================================================================
   Options
   ========================================================================== */

.wg-options {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.wg-option {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	padding: 16px 18px;
	background: var( --wg-clr-bg );
	border: 1.5px solid var( --wg-clr-border );
	border-radius: var( --wg-radius-sm );
	cursor: pointer;
	text-align: left;
	font-size: 0.9rem;
	line-height: 1.55;
	color: var( --wg-clr-text );
	transition:
		border-color var( --wg-transition ),
		background var( --wg-transition ),
		box-shadow var( --wg-transition );
	width: 100%;
	font-family: inherit;
}

.wg-option:hover,
.wg-option:focus-visible {
	border-color: var( --wg-clr-accent );
	background: var( --wg-clr-accent-light );
	outline: none;
	box-shadow: 0 0 0 3px rgba( 92, 122, 110, 0.15 );
}

.wg-option.is-selected {
	border-color: var( --wg-clr-selected-border );
	background: var( --wg-clr-selected-bg );
}

.wg-option-marker {
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	border: 2px solid var( --wg-clr-border );
	margin-top: 2px;
	transition: border-color var( --wg-transition ), background var( --wg-transition );
	position: relative;
}

.wg-option-marker::after {
	content: '';
	position: absolute;
	inset: 3px;
	border-radius: 50%;
	background: var( --wg-clr-accent );
	opacity: 0;
	transition: opacity 0.2s ease;
}

.wg-option.is-selected .wg-option-marker {
	border-color: var( --wg-clr-accent );
}

.wg-option.is-selected .wg-option-marker::after {
	opacity: 1;
}

/* ==========================================================================
   Result card
   ========================================================================== */

.wg-result-card {
	text-align: center;
}

.wg-result-icon {
	width: 56px;
	height: 56px;
	margin: 0 auto 20px;
	color: var( --wg-clr-accent );
}

.wg-result-icon svg {
	width: 100%;
	height: 100%;
}

.wg-validation {
	font-size: 1rem;
	color: var( --wg-clr-text );
	line-height: 1.65;
	margin: 0 0 28px;
}

.wg-validation strong {
	color: var( --wg-clr-accent-dark );
	font-weight: 600;
}

/* Recommendation block */
.wg-recommendation {
	background: var( --wg-clr-bg );
	border: 1.5px solid var( --wg-clr-border );
	border-radius: var( --wg-radius );
	padding: 24px 24px 20px;
	text-align: left;
	margin-bottom: 28px;
}

.wg-rec-eyebrow {
	display: block;
	font-size: 0.7rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var( --wg-clr-muted );
	margin-bottom: 6px;
}

.wg-rec-name {
	font-size: 1.3rem;
	font-weight: 700;
	color: var( --wg-clr-accent-dark );
	margin: 0 0 12px;
	letter-spacing: -0.01em;
}

.wg-rec-description {
	font-size: 0.9rem;
	color: var( --wg-clr-text );
	line-height: 1.75;
	margin: 0 0 16px;
}

.wg-rec-benefit {
	border-top: 1px solid var( --wg-clr-border );
	padding-top: 14px;
}

.wg-benefit-label {
	display: block;
	font-size: 0.72rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var( --wg-clr-accent );
	margin-bottom: 4px;
	font-weight: 600;
}

.wg-rec-benefit p {
	font-size: 0.875rem;
	color: var( --wg-clr-muted );
	margin: 0;
	line-height: 1.6;
}

/* ==========================================================================
   Buttons
   ========================================================================== */

.wg-btn {
	display: inline-block;
	padding: 14px 28px;
	border-radius: var( --wg-radius-sm );
	font-size: 0.9rem;
	font-weight: 600;
	cursor: pointer;
	border: none;
	text-decoration: none;
	transition:
		background var( --wg-transition ),
		transform var( --wg-transition ),
		box-shadow var( --wg-transition );
	font-family: inherit;
	letter-spacing: 0.01em;
}

.wg-btn-primary {
	background: var( --wg-clr-accent );
	color: #ffffff;
}

.wg-btn-primary:hover,
.wg-btn-primary:focus-visible {
	background: var( --wg-clr-accent-dark );
	transform: translateY( -1px );
	box-shadow: 0 4px 14px rgba( 61, 92, 82, 0.28 );
	outline: none;
	color: #ffffff;
	text-decoration: none;
}

.wg-btn-cta {
	display: block;
	width: 100%;
	text-align: center;
	margin-bottom: 20px;
}

.wg-btn-link {
	background: none;
	border: none;
	padding: 0;
	cursor: pointer;
	font-family: inherit;
	font-size: 0.82rem;
	color: var( --wg-clr-muted );
	text-decoration: underline;
	text-underline-offset: 3px;
	margin-top: 4px;
}

.wg-btn-link:hover {
	color: var( --wg-clr-text );
}

/* ==========================================================================
   Disclaimer
   ========================================================================== */

.wg-disclaimer {
	font-size: 0.75rem;
	color: var( --wg-clr-muted );
	line-height: 1.6;
	margin: 0 0 12px;
	font-style: italic;
}

/* ==========================================================================
   Responsive
   ========================================================================== */

@media ( max-width: 480px ) {
	.wg-screen {
		padding: 28px 20px;
	}

	.wg-title {
		font-size: 1.35rem;
	}

	.wg-question-text {
		font-size: 1.05rem;
	}

	.wg-option {
		padding: 14px 14px;
	}
}
