/* =========================================================================
 * SpareTimeCustoms — consent-banner.css
 * Warm paper/ink palette consistent with storefront. The banner pins
 * bottom-left on desktop and stretches full-width on mobile.
 * ========================================================================= */

:root {
	--stc-consent-bg: #F3EDE0;
	--stc-consent-ink: #1A1612;
	--stc-consent-ink-soft: #4A3F35;
	--stc-consent-accent: #8A6A2E;
	--stc-consent-accent-ink: #FFFFFF;
	--stc-consent-border: rgba( 26, 22, 18, 0.12 );
	--stc-consent-shadow: 0 24px 48px -16px rgba( 26, 22, 18, 0.28 );
}

.stc-consent-banner {
	position: fixed;
	left: 1.25rem;
	bottom: 1.25rem;
	right: 1.25rem;
	max-width: 28rem;
	z-index: 2147483000;
	background: var( --stc-consent-bg );
	color: var( --stc-consent-ink );
	border: 1px solid var( --stc-consent-border );
	border-radius: 12px;
	box-shadow: var( --stc-consent-shadow );
	font: 15px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	opacity: 0;
	transform: translateY( 16px );
	transition: opacity 220ms ease-out, transform 220ms ease-out;
	pointer-events: none;
}

.stc-consent-banner.is-visible {
	opacity: 1;
	transform: translateY( 0 );
	pointer-events: auto;
}

.stc-consent-banner[hidden] {
	display: none !important;
}

.stc-consent-inner {
	padding: 1.1rem 1.25rem 1.25rem;
}

.stc-consent-title {
	font-size: 1.05rem;
	font-weight: 600;
	margin: 0 0 0.35rem;
	color: var( --stc-consent-ink );
}

.stc-consent-body {
	margin: 0 0 0.85rem;
	font-size: 0.925rem;
	color: var( --stc-consent-ink-soft );
}

.stc-consent-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	align-items: center;
}

.stc-consent-btn {
	appearance: none;
	border: 1px solid var( --stc-consent-border );
	background: transparent;
	color: var( --stc-consent-ink );
	font: inherit;
	font-weight: 500;
	padding: 0.5rem 0.9rem;
	border-radius: 8px;
	cursor: pointer;
	transition: background-color 140ms ease, border-color 140ms ease, color 140ms ease;
}

.stc-consent-btn:hover,
.stc-consent-btn:focus-visible {
	background-color: rgba( 138, 106, 46, 0.08 );
	border-color: var( --stc-consent-accent );
	outline: none;
}

.stc-consent-btn--primary {
	background-color: var( --stc-consent-accent );
	color: var( --stc-consent-accent-ink );
	border-color: var( --stc-consent-accent );
}

.stc-consent-btn--primary:hover,
.stc-consent-btn--primary:focus-visible {
	background-color: #735619;
	color: var( --stc-consent-accent-ink );
}

.stc-consent-btn--ghost {
	background: transparent;
}

.stc-consent-btn--link {
	border-color: transparent;
	padding-left: 0.25rem;
	padding-right: 0.25rem;
	color: var( --stc-consent-accent );
	text-decoration: underline;
}

.stc-consent-details {
	margin-top: 0.9rem;
	padding-top: 0.9rem;
	border-top: 1px solid var( --stc-consent-border );
}

.stc-consent-cats {
	list-style: none;
	padding: 0;
	margin: 0 0 0.75rem;
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.stc-consent-cat label {
	display: flex;
	align-items: flex-start;
	gap: 0.55rem;
	cursor: pointer;
}

.stc-consent-cat input[type="checkbox"] {
	margin-top: 0.18rem;
	accent-color: var( --stc-consent-accent );
}

.stc-consent-cat-label {
	font-weight: 500;
}

.stc-consent-cat-hint {
	display: block;
	color: var( --stc-consent-ink-soft );
	font-size: 0.825rem;
	margin-left: 0.15rem;
}

/* --- Preference Center --------------------------------------------------- */

.stc-prefs {
	max-width: 42rem;
	margin: 1.5rem auto;
	color: var( --stc-consent-ink );
	font: 15px/1.55 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.stc-prefs-flash {
	background-color: rgba( 138, 106, 46, 0.12 );
	border: 1px solid var( --stc-consent-accent );
	color: var( --stc-consent-ink );
	padding: 0.65rem 0.85rem;
	border-radius: 8px;
	margin-bottom: 1rem;
}

.stc-prefs-group {
	border: 1px solid var( --stc-consent-border );
	border-radius: 10px;
	padding: 0.9rem 1rem;
	margin: 0 0 1rem;
}

.stc-prefs-group legend {
	padding: 0 0.35rem;
	font-weight: 600;
	color: var( --stc-consent-ink );
}

.stc-prefs-row {
	display: flex;
	align-items: center;
	gap: 0.55rem;
	padding: 0.25rem 0;
}

.stc-prefs-pause-row {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 0.5rem;
}

.stc-prefs-btn {
	appearance: none;
	border: 1px solid var( --stc-consent-border );
	background: transparent;
	color: var( --stc-consent-ink );
	font: inherit;
	font-weight: 500;
	padding: 0.5rem 0.9rem;
	border-radius: 8px;
	cursor: pointer;
}

.stc-prefs-btn:hover,
.stc-prefs-btn:focus-visible {
	background-color: rgba( 138, 106, 46, 0.08 );
	border-color: var( --stc-consent-accent );
	outline: none;
}

.stc-prefs-btn--primary {
	background-color: var( --stc-consent-accent );
	color: var( --stc-consent-accent-ink );
	border-color: var( --stc-consent-accent );
}

.stc-prefs-btn--primary:hover {
	background-color: #735619;
}

.stc-prefs-btn--ghost {
	background: transparent;
}

.stc-prefs-actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: 1rem;
}

.stc-prefs-unsub {
	color: var( --stc-consent-ink-soft );
	font-size: 0.9rem;
	text-decoration: underline;
}

@media ( max-width: 480px ) {
	.stc-consent-banner {
		left: 0.75rem;
		right: 0.75rem;
		bottom: 0.75rem;
		max-width: none;
	}
}
