/* ColorSeason Analyzer — frontend styles */

/* Force the hidden attribute to actually hide — beats any cascade. */
.cs-analyzer [hidden] {
	display: none !important;
}

.cs-analyzer {
	max-width: 640px;
	margin: 2.5rem auto;
	padding: 2rem 1rem;
	text-align: center;
}

.cs-analyzer__stage {
	display: block;
}

.cs-analyzer__privacy {
	color: var(--muted, #2B2B2B);
	font-size: 0.9375rem;
	margin: 0 0 1.5rem;
}

/* Primary action button — used for both the file picker (label)
   and the reset button. Same look, different semantics. */
.cs-analyzer__btn {
	display: inline-block;
	padding: 0.875rem 2rem;
	background: var(--text, #0F0F0F);
	color: var(--on-dark, #F5F4F0);
	cursor: pointer;
	font: inherit;
	font-weight: 500;
	letter-spacing: 0.01em;
	border: 0;
	border-radius: 2px;
	text-decoration: none;
	transition: background 0.15s ease, color 0.15s ease;
}
.cs-analyzer__btn:hover,
.cs-analyzer__btn:focus-visible,
.cs-analyzer__btn:focus-within {
	background: var(--accent, #8B6F47);
	color: var(--on-dark, #F5F4F0);
	outline: none;
}

.cs-analyzer__btn--outline {
	background: transparent;
	color: var(--text, #0F0F0F);
	border: 1.5px solid var(--text, #0F0F0F);
}
.cs-analyzer__btn--outline:hover,
.cs-analyzer__btn--outline:focus-visible {
	background: var(--accent, #8B6F47);
	border-color: var(--accent, #8B6F47);
	color: var(--on-dark, #F5F4F0);
}

/* Two-button initial layout */
.cs-analyzer__stage[data-cs-stage="initial"] {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.75rem;
}

/* ------------------------------------------------------------------
   Camera / viewfinder
   ------------------------------------------------------------------ */

.cs-analyzer__viewfinder {
	position: relative;
	width: 100%;
	max-width: 480px;
	margin: 0 auto 1rem;
	border-radius: 4px;
	overflow: hidden;
	background: #000;
	aspect-ratio: 1 / 1;
}

.cs-analyzer__video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transform: scaleX(-1); /* mirror for selfie feel */
}

/* Face-positioning guide — oval silhouette overlay */
.cs-analyzer__face-guide {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	pointer-events: none;
}
.cs-analyzer__face-guide::before {
	content: '';
	display: block;
	width: 54%;
	height: 74%;
	border: 2px solid rgba(255, 255, 255, 0.55);
	border-radius: 50% 50% 44% 44% / 52% 52% 48% 48%;
	box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.28);
}

.cs-analyzer__camera-actions {
	display: flex;
	justify-content: center;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.cs-analyzer__btn input[type="file"] {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
}

/* Result canvas */
.cs-analyzer__canvas {
	max-width: 100%;
	max-height: 520px;
	width: auto;
	height: auto;
	margin: 0 auto 1.5rem;
	border-radius: 4px;
	display: block;
}

.cs-analyzer__note {
	color: var(--muted, #2B2B2B);
	font-size: 0.875rem;
	font-style: italic;
	margin: 1rem 0 1.25rem;
}

.cs-analyzer__error {
	color: #2A0A0A;
	background: rgba(255, 200, 200, 0.35);
	padding: 0.875rem 1rem;
	border-radius: 2px;
	margin: 0 0 1rem;
}

/* Progress indicator */
.cs-analyzer__progress {
	position: relative;
	width: 200px;
	height: 4px;
	margin: 0 auto 1.25rem;
	background: rgba(0, 0, 0, 0.18);
	border-radius: 2px;
	overflow: hidden;
}
.cs-analyzer__progress::before {
	content: '';
	position: absolute;
	top: 0;
	left: -40%;
	width: 40%;
	height: 100%;
	background: var(--text, #0F0F0F);
	border-radius: 2px;
	animation: cs-analyzer-slide 1.3s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}
@keyframes cs-analyzer-slide {
	0%   { left: -40%; }
	50%  { left: 40%; }
	100% { left: 100%; }
}

.cs-analyzer__status {
	font-size: 1rem;
	color: var(--text, #0F0F0F);
	margin: 0 0 0.5rem;
}

.cs-analyzer__subnote {
	font-size: 0.8125rem;
	color: var(--muted, #2B2B2B);
	margin: 0;
}

@media (prefers-reduced-motion: reduce) {
	.cs-analyzer__progress::before {
		animation: none;
		left: 0;
		width: 100%;
		opacity: 0.6;
	}
}

/* Mobile adjustments */
@media (max-width: 480px) {
	.cs-analyzer {
		padding: 1.25rem 0.75rem;
	}

	/* 2×2 grid on narrow screens so the labels don't get crushed */
	.cs-analyzer__summary {
		grid-template-columns: repeat(2, 1fr);
	}

	.cs-analyzer__season-name {
		font-size: 1.375rem;
	}

	.cs-analyzer__canvas {
		max-height: 380px;
	}
}

/* ------------------------------------------------------------------
   Features panel — swatches + summary text
   ------------------------------------------------------------------ */

.cs-analyzer__features {
	margin: 0 0 1.5rem;
}

.cs-analyzer__features-title {
	font-family: var(--font-display, "Cormorant Garamond", serif);
	font-size: 1.5rem;
	font-weight: 500;
	letter-spacing: -0.01em;
	margin: 0 0 1rem;
	color: var(--text, #0F0F0F);
}

.cs-analyzer__swatches {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
	margin: 0 0 1.5rem;
}

.cs-analyzer__swatch {
	display: flex;
	flex-direction: column;
	align-items: center;
	min-width: 80px;
}

.cs-analyzer__swatch-chip {
	display: block;
	width: 64px;
	height: 64px;
	border-radius: 6px;
	background: transparent;
	box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.18) inset;
	margin-bottom: 0.5rem;
}

/* Per-feature chip shapes */
/* Skin: face silhouette — wider at forehead, tapers to chin */
.cs-analyzer__swatch--skin  .cs-analyzer__swatch-chip {
	width: 46px;
	height: 66px;
	border-radius: 48% 48% 38% 38% / 52% 52% 46% 46%;
}
/* Eyes: circle */
.cs-analyzer__swatch--eyes  .cs-analyzer__swatch-chip { width: 58px; height: 58px; border-radius: 50%; }
/* Lips: horizontal oval */
.cs-analyzer__swatch--lips  .cs-analyzer__swatch-chip { width: 76px; height: 44px; border-radius: 50%; }
/* Hair: wide rounded rectangle, landscape */
.cs-analyzer__swatch--hair  .cs-analyzer__swatch-chip { width: 80px; height: 46px; border-radius: 8px; }

.cs-analyzer__swatch--empty .cs-analyzer__swatch-chip {
	background: repeating-linear-gradient(
		45deg,
		rgba(0,0,0,0.1),
		rgba(0,0,0,0.1) 4px,
		rgba(0,0,0,0.18) 4px,
		rgba(0,0,0,0.18) 8px
	);
}

.cs-analyzer__swatch-label {
	display: block;
	font-size: 0.8125rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--text, #0F0F0F);
}

.cs-analyzer__swatch-name {
	display: block;
	font-size: 0.75rem;
	color: var(--muted, #2B2B2B);
	margin-top: 0.125rem;
}

.cs-analyzer__card-note {
	font-size: 0.8125rem;
	color: #3a6a3a;
	margin: -0.25rem 0 1rem;
}

.cs-analyzer__summary {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0.5rem 0.5rem;
	margin: 0 0 1rem;
	padding: 1rem 0.75rem;
	background: rgba(0, 0, 0, 0.08);
	border-radius: 2px;
}

.cs-analyzer__summary-row {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.cs-analyzer__summary-row dt {
	font-size: 0.75rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--muted, #2B2B2B);
	margin: 0;
}

.cs-analyzer__summary-row dd {
	font-size: 1.0625rem;
	font-weight: 500;
	color: var(--text, #0F0F0F);
	margin: 0.125rem 0 0;
	text-transform: capitalize;
}

/* ------------------------------------------------------------------
   Season result
   ------------------------------------------------------------------ */

.cs-analyzer__season {
	border-left: 4px solid var(--season-color, #888);
	padding: 1rem 1rem 1rem 1.25rem;
	background: rgba(0, 0, 0, 0.05);
	border-radius: 0 4px 4px 0;
	margin: 0 0 1rem;
	text-align: left;
}

.cs-analyzer__season-header {
	display: flex;
	align-items: baseline;
	gap: 0.625rem;
	margin-bottom: 0.5rem;
	flex-wrap: wrap;
}

.cs-analyzer__season-family {
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--season-color, #888);
}

.cs-analyzer__season-name {
	font-family: var(--font-display, "Cormorant Garamond", serif);
	font-size: 1.625rem;
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--text, #0F0F0F);
	margin: 0;
	line-height: 1.2;
}

.cs-analyzer__season-confidence {
	margin-left: auto;
	font-size: 0.8125rem;
	color: var(--muted, #2B2B2B);
	white-space: nowrap;
}

.cs-analyzer__season-description {
	font-size: 0.9375rem;
	line-height: 1.6;
	color: var(--text, #0F0F0F);
	margin: 0;
}

.cs-analyzer__version {
	font-size: 0.6875rem;
	color: var(--muted, #2B2B2B);
	opacity: 0.4;
	margin: 1.25rem 0 0;
	text-align: center;
	letter-spacing: 0.03em;
}
