/* ===================================================================
   TempleSetu Spiritual Guide — Spiritual Action (Recommended Seva) v1.0
   Extends the existing saffron / cream design system:
     Primary gradient : #E76F1E → #F4A261 (marigold/saffron)
     Background       : #FFF8EF (warm cream)
     Card surface      : #FFFFFF
     Text             : #2D2A4A (indigo-dark)
     Accent / gold    : #C9A227
     Card radius      : 20px
=================================================================== */

/* ------------------------------------------------------------------ */
/*  Spiritual Action card                                               */
/* ------------------------------------------------------------------ */
.tssg-card-spiritual-action {
	border-left: 4px solid #C9A227;
	background: linear-gradient( 145deg, #FFFFFF, #FFF8EF );
}

.tssg-card-spiritual-action .tssg-pill {
	background: #FBEFD2;
	color: #9C7A12;
}

.tssg-card-spiritual-action .tssg-body-text {
	margin-bottom: 14px;
}

/* "View Recommended Seva" button */
.tssg-seva-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	min-height: 48px;
	padding: 12px 20px;
	border: none;
	border-radius: 50px;
	background: linear-gradient( 135deg, #E76F1E, #F4A261 );
	color: #FFFFFF;
	font-size: 0.97rem;
	font-weight: 700;
	letter-spacing: 0.2px;
	cursor: pointer;
	box-shadow: 0 6px 16px rgba(231, 111, 30, 0.28);
	transition: transform 0.15s ease, box-shadow 0.2s ease, filter 0.2s ease;
	-webkit-tap-highlight-color: transparent;
}

.tssg-seva-btn-icon {
	font-size: 1.05rem;
	line-height: 1;
}

.tssg-seva-btn:hover {
	filter: brightness(1.05);
	box-shadow: 0 10px 22px rgba(231, 111, 30, 0.34);
	transform: translateY(-1px);
}

.tssg-seva-btn:focus-visible {
	outline: 3px solid rgba(201, 162, 39, 0.55);
	outline-offset: 2px;
}

.tssg-seva-btn:active {
	transform: translateY(0) scale(0.98);
	box-shadow: 0 4px 12px rgba(231, 111, 30, 0.28);
}

/* ------------------------------------------------------------------ */
/*  Modal overlay                                                       */
/* ------------------------------------------------------------------ */
.tssg-seva-modal-overlay {
	position: fixed;
	inset: 0;
	z-index: 100000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
	background: rgba(45, 42, 74, 0.45);
	backdrop-filter: blur(3px);
	-webkit-backdrop-filter: blur(3px);
	opacity: 0;
	transition: opacity 0.25s ease;
	box-sizing: border-box;
}

.tssg-seva-modal-overlay[hidden] {
	display: none;
}

.tssg-seva-modal-overlay.tssg-seva-modal-visible {
	opacity: 1;
}

body.tssg-seva-modal-open {
	overflow: hidden;
}

/* ------------------------------------------------------------------ */
/*  Modal panel                                                          */
/* ------------------------------------------------------------------ */
.tssg-seva-modal {
	position: relative;
	width: 100%;
	max-width: 600px;
	max-height: 85vh;
	overflow-y: auto;
	background: #FFFFFF;
	border-radius: 24px;
	padding: 28px 24px 20px;
	box-shadow: 0 20px 60px rgba(45, 42, 74, 0.25);
	border: 1px solid rgba(245, 208, 170, 0.5);
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	transform: translateY(16px) scale(0.98);
	transition: transform 0.25s ease;
	box-sizing: border-box;
}

.tssg-seva-modal-overlay.tssg-seva-modal-visible .tssg-seva-modal {
	transform: translateY(0) scale(1);
}

.tssg-seva-modal-title {
	margin: 0 0 16px;
	padding-right: 32px;
	font-size: 1.3rem;
	font-weight: 700;
	letter-spacing: -0.2px;
	background: linear-gradient( 135deg, #E76F1E, #F4A261 );
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

/* Close (X) button */
.tssg-seva-modal-close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 36px;
	height: 36px;
	min-width: 36px;
	min-height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: none;
	border-radius: 50%;
	background: #FEF3E9;
	color: #C3632F;
	font-size: 1.4rem;
	line-height: 1;
	cursor: pointer;
	transition: background 0.2s ease, transform 0.15s ease;
}

.tssg-seva-modal-close:hover {
	background: #FFE3CE;
}

.tssg-seva-modal-close:focus-visible {
	outline: 3px solid rgba(201, 162, 39, 0.55);
	outline-offset: 2px;
}

.tssg-seva-modal-close:active {
	transform: scale(0.92);
}

/* ------------------------------------------------------------------ */
/*  Modal body                                                          */
/* ------------------------------------------------------------------ */
.tssg-seva-modal-body {
	min-height: 80px;
}

/* Loading state */
.tssg-seva-modal-loading {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	padding: 24px 8px;
	text-align: center;
	color: #B46A37;
}

.tssg-seva-spinner {
	font-size: 2rem;
	display: inline-block;
	animation: tssg-seva-spin 1.6s ease-in-out infinite;
}

@keyframes tssg-seva-spin {
	0%, 100% { transform: scale(1) rotate(0deg); }
	50%       { transform: scale(1.12) rotate(8deg); }
}

/* Empty / error message state */
.tssg-seva-modal-message {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	padding: 24px 8px;
	text-align: center;
	color: #6b5b40;
}

.tssg-seva-message-icon {
	font-size: 1.8rem;
}

/* ------------------------------------------------------------------ */
/*  Seva detail rows                                                    */
/* ------------------------------------------------------------------ */
.tssg-seva-details {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.tssg-seva-row {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 12px;
	padding: 10px 14px;
	border-radius: 14px;
	background: #FFF8EF;
	border: 1px solid rgba(245, 208, 170, 0.5);
}

.tssg-seva-row-block {
	flex-direction: column;
	align-items: flex-start;
}

.tssg-seva-row-temple {
	background: #FEF3E9;
	border-color: rgba(231, 111, 30, 0.25);
}

.tssg-seva-row-donation .tssg-seva-value {
	font-weight: 700;
	color: #5B9279;
}

.tssg-seva-label {
	flex-shrink: 0;
	font-size: 0.82rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.4px;
	color: #C3632F;
}

.tssg-seva-value {
	font-size: 0.97rem;
	font-weight: 600;
	color: #2D2A4A;
	text-align: right;
}

.tssg-seva-value-block {
	margin: 6px 0 0;
	text-align: left;
	font-weight: 500;
	line-height: 1.6;
	color: #3E3C4A;
}

/* ------------------------------------------------------------------ */
/*  Modal footer                                                        */
/* ------------------------------------------------------------------ */
.tssg-seva-modal-footer {
	margin-top: 20px;
	display: flex;
	justify-content: flex-end;
}

.tssg-seva-modal-close-btn {
	min-height: 44px;
	padding: 10px 24px;
	border: 1.5px solid #F0BC8C;
	border-radius: 50px;
	background: #FFFFFF;
	color: #DE6C31;
	font-weight: 700;
	font-size: 0.95rem;
	cursor: pointer;
	transition: background 0.2s ease, transform 0.15s ease;
}

.tssg-seva-modal-close-btn:hover {
	background: #FFEFE3;
}

.tssg-seva-modal-close-btn:focus-visible {
	outline: 3px solid rgba(201, 162, 39, 0.55);
	outline-offset: 2px;
}

.tssg-seva-modal-close-btn:active {
	transform: scale(0.97);
}

/* ------------------------------------------------------------------ */
/*  Mobile responsive                                                    */
/* ------------------------------------------------------------------ */
@media ( max-width: 480px ) {
	.tssg-seva-modal-overlay {
		padding: 0;
		align-items: flex-end;
	}

	.tssg-seva-modal {
		width: 95%;
		max-width: none;
		max-height: 88vh;
		margin: 0 auto 12px;
		border-radius: 22px;
	}

	.tssg-seva-modal-title {
		font-size: 1.15rem;
	}

	.tssg-seva-row {
		flex-direction: column;
		align-items: flex-start;
		gap: 4px;
	}

	.tssg-seva-value {
		text-align: left;
	}
}

/* ------------------------------------------------------------------ */
/*  Confirmation section                                                */
/* ------------------------------------------------------------------ */
.tssg-seva-confirm-section {
	margin-top: 20px;
	padding: 18px 16px;
	border-radius: 16px;
	background: linear-gradient(135deg, #FFF8EF, #FEF3E9);
	border: 1.5px solid rgba(231, 111, 30, 0.2);
	text-align: center;
}

.tssg-seva-confirm-header {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	margin-bottom: 14px;
}

.tssg-seva-confirm-icon {
	font-size: 1.6rem;
}

.tssg-seva-confirm-prompt {
	margin: 0;
	font-size: 0.95rem;
	font-weight: 600;
	color: #2D2A4A;
	line-height: 1.5;
}

.tssg-seva-confirm-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	min-height: 48px;
	padding: 12px 24px;
	border: none;
	border-radius: 50px;
	background: linear-gradient(135deg, #E76F1E, #F4A261);
	color: #FFFFFF;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.2px;
	cursor: pointer;
	box-shadow: 0 6px 16px rgba(231, 111, 30, 0.28);
	transition: transform 0.15s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.tssg-seva-confirm-btn:hover {
	filter: brightness(1.05);
	box-shadow: 0 10px 22px rgba(231, 111, 30, 0.34);
	transform: translateY(-1px);
}

.tssg-seva-confirm-btn:active {
	transform: translateY(0) scale(0.98);
}

/* ------------------------------------------------------------------ */
/*  Contact form                                                        */
/* ------------------------------------------------------------------ */
.tssg-seva-contact-form {
	margin-top: 20px;
	padding: 20px 16px;
	border-radius: 16px;
	background: #FAFAFA;
	border: 1.5px solid rgba(200, 200, 200, 0.4);
}

.tssg-seva-form-title {
	margin: 0 0 6px;
	font-size: 1.05rem;
	font-weight: 700;
	color: #2D2A4A;
}

.tssg-seva-form-subtitle {
	margin: 0 0 18px;
	font-size: 0.85rem;
	color: #6B6880;
	line-height: 1.5;
}

.tssg-seva-field-group {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin-bottom: 14px;
}

.tssg-seva-field-label {
	font-size: 0.85rem;
	font-weight: 700;
	color: #C3632F;
	text-transform: uppercase;
	letter-spacing: 0.4px;
}

.tssg-seva-required {
	color: #D63031;
	margin-left: 3px;
}

.tssg-seva-optional {
	color: #999;
	font-weight: 500;
	text-transform: none;
	letter-spacing: 0;
	font-size: 0.82rem;
}

.tssg-seva-input {
	width: 100%;
	min-height: 44px;
	padding: 10px 14px;
	border: 1.5px solid #E0D5C8;
	border-radius: 12px;
	background: #FFFFFF;
	font-size: 0.95rem;
	color: #2D2A4A;
	box-sizing: border-box;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	outline: none;
}

.tssg-seva-input:focus {
	border-color: #E76F1E;
	box-shadow: 0 0 0 3px rgba(231, 111, 30, 0.12);
}

.tssg-seva-input::placeholder {
	color: #C2BAAF;
}

.tssg-seva-field-error {
	font-size: 0.82rem;
	color: #D63031;
	font-weight: 600;
}

.tssg-seva-form-actions {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-top: 18px;
}

.tssg-seva-submit-btn {
	width: 100%;
	min-height: 48px;
	padding: 12px 24px;
	border: none;
	border-radius: 50px;
	background: linear-gradient(135deg, #E76F1E, #F4A261);
	color: #FFFFFF;
	font-size: 1rem;
	font-weight: 700;
	cursor: pointer;
	box-shadow: 0 6px 16px rgba(231, 111, 30, 0.28);
	transition: transform 0.15s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.tssg-seva-submit-btn:hover:not(:disabled) {
	filter: brightness(1.05);
	transform: translateY(-1px);
}

.tssg-seva-submit-btn:disabled {
	opacity: 0.65;
	cursor: not-allowed;
}

.tssg-seva-back-btn {
	width: 100%;
	min-height: 42px;
	padding: 10px 24px;
	border: 1.5px solid #E0D5C8;
	border-radius: 50px;
	background: #FFFFFF;
	color: #6B6880;
	font-size: 0.9rem;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s ease;
}

.tssg-seva-back-btn:hover {
	background: #F5F0EB;
}

/* ------------------------------------------------------------------ */
/*  Form feedback (error / success inline)                              */
/* ------------------------------------------------------------------ */
.tssg-seva-form-feedback {
	margin-top: 12px;
	padding: 10px 14px;
	border-radius: 10px;
	font-size: 0.88rem;
	font-weight: 600;
	line-height: 1.5;
}

.tssg-seva-feedback-success {
	background: #EDFAF1;
	color: #27AE60;
	border: 1px solid rgba(39, 174, 96, 0.25);
}

.tssg-seva-feedback-error {
	background: #FFF0F0;
	color: #D63031;
	border: 1px solid rgba(214, 48, 49, 0.25);
}

/* ------------------------------------------------------------------ */
/*  Success state                                                        */
/* ------------------------------------------------------------------ */
.tssg-seva-success {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	padding: 28px 12px;
	text-align: center;
}

.tssg-seva-success-icon {
	font-size: 3rem;
	animation: tssg-pulse 1.2s ease-in-out 1;
}

@keyframes tssg-pulse {
	0%   { transform: scale(0.7); opacity: 0; }
	60%  { transform: scale(1.1); }
	100% { transform: scale(1);   opacity: 1; }
}

.tssg-seva-success-title {
	margin: 0;
	font-size: 1.2rem;
	font-weight: 700;
	color: #27AE60;
}

.tssg-seva-success-msg {
	margin: 0;
	font-size: 0.92rem;
	color: #3E3C4A;
	line-height: 1.6;
	max-width: 380px;
}
