/**
 * Front-end widget styles — South Delicious Catering Assistant.
 *
 * Aesthetic direction: refined luxury catering. A premium white surface, a deep
 * elegant green as the primary, and a gold accent used sparingly as hairlines
 * and highlights. Depth comes from soft, layered shadows and subtle gradients
 * rather than flat fills; motion is calm and orchestrated rather than busy.
 *
 * Engineering notes:
 *   • EVERYTHING is scoped under #sdca-widget so the widget cannot leak styles
 *     into — or inherit surprises from — the host theme. We also reset the few
 *     properties (box-sizing, font, line-height, etc.) that themes most often
 *     set globally, so the widget looks identical across sites.
 *   • Colours are driven by CSS custom properties that PHP injects inline on the
 *     root (--sdca-primary / --sdca-accent / --sdca-surface). The stylesheet
 *     itself is static and fully cacheable; re-theming never requires new CSS.
 *   • No external fonts are loaded. To honour the PRD's "fast loading / SEO
 *     safe" requirement and to avoid third-party privacy concerns on the host
 *     site, we pair an elegant available serif (for the brand) with a clean
 *     system sans (for body), achieving a refined look with zero network cost.
 *   • A prefers-reduced-motion block disables non-essential animation.
 */

/* ---------------------------------------------------------------------------
   Root + design tokens
   --------------------------------------------------------------------------- */
#sdca-widget {
	/* Fall back to the brand palette if the inline variables are ever absent. */
	--sdca-primary: #0f5132;
	--sdca-accent: #c9a227;
	--sdca-surface: #ffffff;

	/* Derived tokens. */
	--sdca-ink: #1f2a24;            /* primary text on light surfaces */
	--sdca-ink-soft: #5b6660;       /* secondary text */
	--sdca-line: rgba( 15, 81, 50, 0.12 );
	--sdca-user-bubble: var( --sdca-primary );
	--sdca-bot-bubble: #f3f1ea;     /* warm ivory for assistant bubbles */
	--sdca-shadow: 0 18px 50px -12px rgba( 17, 40, 28, 0.45 );
	--sdca-shadow-soft: 0 8px 24px -10px rgba( 17, 40, 28, 0.35 );
	--sdca-radius: 18px;

	--sdca-serif: "Hoefler Text", "Cormorant Garamond", "Apple Garamond", "Georgia", "Times New Roman", serif;
	--sdca-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", "Arial", "Noto Sans", sans-serif;

	/* Containing context for the fixed children. */
	position: fixed;
	right: 22px;
	bottom: 22px;
	z-index: 2147483000; /* above almost everything, below browser chrome */
	font-family: var( --sdca-sans );
	line-height: 1.5;
	color: var( --sdca-ink );
}

/* Scoped reset so host-theme globals cannot distort the widget. */
#sdca-widget *,
#sdca-widget *::before,
#sdca-widget *::after {
	box-sizing: border-box;
}
#sdca-widget button {
	font-family: inherit;
	cursor: pointer;
	border: 0;
	background: none;
}
#sdca-widget input {
	font-family: inherit;
	font-size: 15px;
}

/* A genuinely hidden helper for screen-reader-only text. */
#sdca-widget .screen-reader-text {
	position: absolute !important;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect( 0, 0, 0, 0 );
	white-space: nowrap;
	border: 0;
}

/* Honeypot: keep it in the DOM and focusable-order-neutral, but invisible and
   off-screen so humans never interact with it while bots happily fill it in. */
#sdca-widget .sdca-hp {
	position: absolute !important;
	left: -9999px !important;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* ---------------------------------------------------------------------------
   Floating launcher
   --------------------------------------------------------------------------- */
#sdca-widget .sdca-launcher {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 62px;
	height: 62px;
	margin-left: auto;
	border-radius: 50%;
	color: var( --sdca-surface );
	background:
		radial-gradient( 120% 120% at 30% 20%, rgba( 255, 255, 255, 0.18 ), transparent 55% ),
		linear-gradient( 155deg, var( --sdca-primary ) 0%, #0b3d26 100% );
	box-shadow:
		0 0 0 1px rgba( 201, 162, 39, 0.5 ),
		var( --sdca-shadow );
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
#sdca-widget .sdca-launcher:hover {
	transform: translateY( -2px ) scale( 1.03 );
	box-shadow:
		0 0 0 1px rgba( 201, 162, 39, 0.85 ),
		0 24px 60px -14px rgba( 17, 40, 28, 0.55 );
}
#sdca-widget .sdca-launcher:focus-visible {
	outline: 3px solid var( --sdca-accent );
	outline-offset: 3px;
}

/* A soft golden pulse ring to gently draw the eye, only while closed. */
#sdca-widget .sdca-launcher::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 50%;
	border: 2px solid var( --sdca-accent );
	opacity: 0;
	animation: sdca-pulse 2.8s ease-out infinite;
}
#sdca-widget[data-state="open"] .sdca-launcher::after {
	animation: none;
}

@keyframes sdca-pulse {
	0%   { transform: scale( 1 ); opacity: 0.55; }
	70%  { transform: scale( 1.5 ); opacity: 0; }
	100% { transform: scale( 1.5 ); opacity: 0; }
}

/* Icon crossfade between chat (closed) and close (open). */
#sdca-widget .sdca-launcher__icon {
	position: absolute;
	display: inline-flex;
	transition: opacity 0.2s ease, transform 0.3s ease;
}
#sdca-widget .sdca-launcher__icon--close {
	opacity: 0;
	transform: rotate( -90deg ) scale( 0.6 );
}
#sdca-widget[data-state="open"] .sdca-launcher__icon--chat {
	opacity: 0;
	transform: rotate( 90deg ) scale( 0.6 );
}
#sdca-widget[data-state="open"] .sdca-launcher__icon--close {
	opacity: 1;
	transform: rotate( 0 ) scale( 1 );
}

/* ---------------------------------------------------------------------------
   Panel
   --------------------------------------------------------------------------- */
#sdca-widget .sdca-panel {
	position: absolute;
	right: 0;
	bottom: 78px;
	width: 380px;
	max-width: calc( 100vw - 32px );
	height: 560px;
	max-height: calc( 100vh - 120px );
	display: flex;
	flex-direction: column;
	overflow: hidden;
	background: var( --sdca-surface );
	border-radius: var( --sdca-radius );
	box-shadow: var( --sdca-shadow );
	/* Hidden state: scaled down toward the launcher, faded out. */
	transform-origin: bottom right;
	transform: translateY( 12px ) scale( 0.96 );
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.22s ease, transform 0.26s cubic-bezier( 0.22, 1, 0.36, 1 );
}
#sdca-widget[data-state="open"] .sdca-panel {
	opacity: 1;
	transform: translateY( 0 ) scale( 1 );
	pointer-events: auto;
}

/* Header with a gold hairline under it for a refined finish. */
#sdca-widget .sdca-panel__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 16px 18px;
	color: var( --sdca-surface );
	background:
		radial-gradient( 130% 120% at 0% 0%, rgba( 255, 255, 255, 0.12 ), transparent 50% ),
		linear-gradient( 135deg, var( --sdca-primary ) 0%, #0b3d26 100% );
	border-bottom: 1px solid rgba( 201, 162, 39, 0.55 );
}
#sdca-widget .sdca-panel__brand {
	display: flex;
	align-items: center;
	gap: 12px;
	min-width: 0;
}
#sdca-widget .sdca-panel__avatar {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	color: var( --sdca-primary );
	background: linear-gradient( 160deg, #fdfbf3, #efe7cf );
	box-shadow: 0 0 0 1px rgba( 201, 162, 39, 0.65 );
	flex: 0 0 auto;
}
#sdca-widget .sdca-panel__titles {
	display: flex;
	flex-direction: column;
	min-width: 0;
}
#sdca-widget .sdca-panel__title {
	font-family: var( --sdca-serif );
	font-size: 17px;
	font-weight: 600;
	letter-spacing: 0.01em;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
#sdca-widget .sdca-panel__subtitle {
	font-size: 11.5px;
	opacity: 0.82;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
#sdca-widget .sdca-panel__subtitle::before {
	content: "";
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: #7CFFA0;
	box-shadow: 0 0 0 2px rgba( 124, 255, 160, 0.3 );
}
#sdca-widget .sdca-panel__close {
	color: rgba( 255, 255, 255, 0.85 );
	display: inline-flex;
	padding: 6px;
	border-radius: 8px;
	transition: background 0.2s ease, color 0.2s ease;
	flex: 0 0 auto;
}
#sdca-widget .sdca-panel__close:hover {
	background: rgba( 255, 255, 255, 0.14 );
	color: #fff;
}
#sdca-widget .sdca-panel__close:focus-visible {
	outline: 2px solid var( --sdca-accent );
	outline-offset: 2px;
}

/* ---------------------------------------------------------------------------
   Conversation log
   --------------------------------------------------------------------------- */
#sdca-widget .sdca-panel__log {
	flex: 1 1 auto;
	overflow-y: auto;
	padding: 18px 16px 8px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	/* A whisper-soft ivory wash gives the surface warmth without distraction. */
	background:
		radial-gradient( 120% 60% at 100% 0%, rgba( 201, 162, 39, 0.05 ), transparent 60% ),
		var( --sdca-surface );
	scrollbar-width: thin;
	scrollbar-color: rgba( 15, 81, 50, 0.25 ) transparent;
}
#sdca-widget .sdca-panel__log::-webkit-scrollbar {
	width: 8px;
}
#sdca-widget .sdca-panel__log::-webkit-scrollbar-thumb {
	background: rgba( 15, 81, 50, 0.22 );
	border-radius: 8px;
}

/* Message bubbles. */
#sdca-widget .sdca-msg {
	max-width: 84%;
	padding: 10px 13px;
	border-radius: 14px;
	font-size: 14.5px;
	white-space: pre-wrap;       /* preserve newlines from replies */
	word-wrap: break-word;
	overflow-wrap: anywhere;
	animation: sdca-rise 0.32s cubic-bezier( 0.22, 1, 0.36, 1 ) both;
}
#sdca-widget .sdca-msg--bot {
	align-self: flex-start;
	background: var( --sdca-bot-bubble );
	color: var( --sdca-ink );
	border-bottom-left-radius: 5px;
}
#sdca-widget .sdca-msg--user {
	align-self: flex-end;
	background: var( --sdca-user-bubble );
	color: #fff;
	border-bottom-right-radius: 5px;
}

@keyframes sdca-rise {
	from { opacity: 0; transform: translateY( 8px ); }
	to   { opacity: 1; transform: translateY( 0 ); }
}

/* Typing indicator: three gold dots gently pulsing in sequence. */
#sdca-widget .sdca-typing {
	align-self: flex-start;
	display: inline-flex;
	gap: 5px;
	padding: 12px 14px;
	background: var( --sdca-bot-bubble );
	border-radius: 14px;
	border-bottom-left-radius: 5px;
}
#sdca-widget .sdca-typing span {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var( --sdca-accent );
	opacity: 0.5;
	animation: sdca-blink 1.2s infinite ease-in-out;
}
#sdca-widget .sdca-typing span:nth-child( 2 ) { animation-delay: 0.18s; }
#sdca-widget .sdca-typing span:nth-child( 3 ) { animation-delay: 0.36s; }

@keyframes sdca-blink {
	0%, 80%, 100% { opacity: 0.35; transform: translateY( 0 ); }
	40%           { opacity: 1; transform: translateY( -3px ); }
}

/* ---------------------------------------------------------------------------
   Recommendation card (rendered after a completed enquiry)
   --------------------------------------------------------------------------- */
#sdca-widget .sdca-reco {
	align-self: stretch;
	max-width: 100%;
	background: linear-gradient( 180deg, #fffdf6 0%, #ffffff 100% );
	border: 1px solid var( --sdca-line );
	border-radius: 14px;
	padding: 14px 15px;
	box-shadow: var( --sdca-shadow-soft );
	animation: sdca-rise 0.32s cubic-bezier( 0.22, 1, 0.36, 1 ) both;
}
#sdca-widget .sdca-reco__title {
	font-family: var( --sdca-serif );
	font-size: 15.5px;
	font-weight: 600;
	color: var( --sdca-primary );
	margin: 0 0 8px;
	display: flex;
	align-items: center;
	gap: 8px;
}
#sdca-widget .sdca-reco__title::before {
	content: "";
	width: 22px;
	height: 2px;
	background: var( --sdca-accent );
	border-radius: 2px;
}
#sdca-widget .sdca-reco__row {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	padding: 4px 0;
	font-size: 13.5px;
	border-bottom: 1px dashed var( --sdca-line );
}
#sdca-widget .sdca-reco__row:last-of-type {
	border-bottom: 0;
}
#sdca-widget .sdca-reco__key {
	color: var( --sdca-ink-soft );
}
#sdca-widget .sdca-reco__val {
	font-weight: 600;
	text-align: right;
	font-variant-numeric: tabular-nums;
}
#sdca-widget .sdca-reco__addons {
	margin: 8px 0 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
#sdca-widget .sdca-reco__addons li {
	font-size: 12px;
	padding: 3px 9px;
	border-radius: 999px;
	background: rgba( 201, 162, 39, 0.14 );
	color: #7a5c00;
	border: 1px solid rgba( 201, 162, 39, 0.4 );
}

/* WhatsApp call-to-action button. */
#sdca-widget .sdca-wa {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	margin-top: 12px;
	padding: 11px 14px;
	border-radius: 12px;
	font-size: 14px;
	font-weight: 600;
	color: #fff;
	text-decoration: none;
	background: linear-gradient( 135deg, #1faf54 0%, #128c41 100% );
	box-shadow: 0 8px 20px -8px rgba( 18, 140, 65, 0.7 );
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
#sdca-widget .sdca-wa:hover {
	transform: translateY( -1px );
	box-shadow: 0 12px 26px -8px rgba( 18, 140, 65, 0.8 );
}

/* ---------------------------------------------------------------------------
   Quick-reply chips
   --------------------------------------------------------------------------- */
#sdca-widget .sdca-panel__quick {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	padding: 4px 16px 12px;
	background: var( --sdca-surface );
}
#sdca-widget .sdca-chip {
	font-size: 13px;
	padding: 8px 14px;
	border-radius: 999px;
	color: var( --sdca-primary );
	background: #fff;
	border: 1px solid var( --sdca-line );
	box-shadow: 0 1px 2px rgba( 17, 40, 28, 0.06 );
	transition: background 0.18s ease, border-color 0.18s ease, transform 0.12s ease;
}
#sdca-widget .sdca-chip:hover {
	background: rgba( 15, 81, 50, 0.06 );
	border-color: rgba( 15, 81, 50, 0.3 );
}
#sdca-widget .sdca-chip:active {
	transform: scale( 0.97 );
}
#sdca-widget .sdca-chip:focus-visible {
	outline: 2px solid var( --sdca-accent );
	outline-offset: 2px;
}

/* A date input presented inline as a chip-styled control. */
#sdca-widget .sdca-dateline {
	display: flex;
	gap: 8px;
	align-items: center;
	width: 100%;
}
#sdca-widget .sdca-dateline input[type="date"] {
	flex: 1 1 auto;
	padding: 9px 12px;
	border-radius: 10px;
	border: 1px solid var( --sdca-line );
	color: var( --sdca-ink );
	background: #fff;
}

/* ---------------------------------------------------------------------------
   Composer
   --------------------------------------------------------------------------- */
#sdca-widget .sdca-panel__composer {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 12px 14px;
	border-top: 1px solid var( --sdca-line );
	background: var( --sdca-surface );
}
#sdca-widget .sdca-panel__input {
	flex: 1 1 auto;
	min-width: 0;
	padding: 11px 14px;
	border-radius: 12px;
	border: 1px solid var( --sdca-line );
	color: var( --sdca-ink );
	background: #fbfbf9;
	transition: border-color 0.18s ease, box-shadow 0.18s ease;
}
#sdca-widget .sdca-panel__input:focus {
	outline: none;
	border-color: rgba( 15, 81, 50, 0.5 );
	box-shadow: 0 0 0 3px rgba( 15, 81, 50, 0.1 );
}
#sdca-widget .sdca-panel__send {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	flex: 0 0 auto;
	border-radius: 12px;
	color: #fff;
	background: linear-gradient( 155deg, var( --sdca-primary ) 0%, #0b3d26 100% );
	box-shadow: var( --sdca-shadow-soft );
	transition: transform 0.18s ease, opacity 0.18s ease;
}
#sdca-widget .sdca-panel__send:hover {
	transform: translateY( -1px );
}
#sdca-widget .sdca-panel__send:disabled {
	opacity: 0.5;
	cursor: default;
	transform: none;
}
#sdca-widget .sdca-panel__send:focus-visible {
	outline: 2px solid var( --sdca-accent );
	outline-offset: 2px;
}

/* Footer with a small, tasteful brand line. */
#sdca-widget .sdca-panel__footer {
	padding: 8px 14px 12px;
	text-align: center;
	background: var( --sdca-surface );
}
#sdca-widget .sdca-panel__footnote {
	font-size: 11px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var( --sdca-ink-soft );
}

/* ---------------------------------------------------------------------------
   Mobile: present the panel as a near-full-screen sheet
   --------------------------------------------------------------------------- */
@media screen and ( max-width: 480px ) {
	#sdca-widget {
		right: 16px;
		bottom: 16px;
	}
	#sdca-widget .sdca-panel {
		width: calc( 100vw - 24px );
		height: calc( 100vh - 96px );
		max-height: calc( 100vh - 96px );
		bottom: 76px;
	}
}

/* ---------------------------------------------------------------------------
   Respect users who prefer reduced motion
   --------------------------------------------------------------------------- */
@media ( prefers-reduced-motion: reduce ) {
	#sdca-widget .sdca-launcher,
	#sdca-widget .sdca-launcher__icon,
	#sdca-widget .sdca-panel,
	#sdca-widget .sdca-msg,
	#sdca-widget .sdca-reco,
	#sdca-widget .sdca-panel__send,
	#sdca-widget .sdca-wa {
		transition: none !important;
		animation: none !important;
	}
	#sdca-widget .sdca-launcher::after {
		animation: none !important;
		opacity: 0;
	}
	#sdca-widget .sdca-typing span {
		animation: none !important;
		opacity: 0.6;
	}
}
