/* TempleSetu Spiritual Care – Public Styles */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;600;700&family=Nunito+Sans:wght@400;600;700&display=swap');

:root {
	--ts-saffron: #C26148;
	--ts-terracotta: #7B2D1E;
	--ts-gold: #D4A853;
	--ts-cream: #FDF6EC;
	--ts-border: #E8D9C8;
	--ts-text: #2d2018;
	--ts-muted: #7a6254;
	--ts-radius: 10px;
	--ts-shadow: 0 2px 16px rgba(194,97,72,.10);
}

.ts-public-wrap {
	font-family: 'Nunito Sans', sans-serif;
	color: var(--ts-text);
	max-width: 720px;
	margin: 0 auto;
	padding: 16px;
}

.ts-public-wrap * { box-sizing: border-box; }

/* Login notice */
.ts-login-notice {
	background: var(--ts-cream);
	border: 1px solid var(--ts-border);
	border-radius: var(--ts-radius);
	padding: 20px 24px;
	text-align: center;
}
.ts-login-notice a { color: var(--ts-saffron); font-weight: 600; }

/* Step wrapper */
.ts-step {
	background: #fff;
	border: 1px solid var(--ts-border);
	border-radius: var(--ts-radius);
	padding: 28px 32px;
	margin-bottom: 20px;
	box-shadow: var(--ts-shadow);
}

.ts-hidden { display: none !important; }

/* Step header */
.ts-step-header {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 24px;
}
.ts-step-number {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--ts-cream);
	border: 2px solid var(--ts-gold);
	color: var(--ts-terracotta);
	font-family: 'Cormorant Garamond', serif;
	font-size: 18px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.ts-step-number.active { background: var(--ts-saffron); border-color: var(--ts-terracotta); color: #fff; }
.ts-step-title {
	font-family: 'Cormorant Garamond', serif;
	font-size: 22px;
	font-weight: 700;
	color: var(--ts-terracotta);
	margin: 0;
}

/* Form grid */
.ts-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 20px; }
.ts-field { display: flex; flex-direction: column; gap: 5px; }
.ts-field.ts-full { grid-column: 1 / -1; }
.ts-field label { font-size: 13px; font-weight: 700; color: var(--ts-muted); text-transform: uppercase; letter-spacing: .04em; }
.ts-required { color: var(--ts-saffron); }

/* Inputs */
.ts-input {
	border: 1.5px solid var(--ts-border);
	border-radius: 6px;
	padding: 10px 12px;
	font-size: 15px;
	font-family: 'Nunito Sans', sans-serif;
	color: var(--ts-text);
	background: #fff;
	transition: border-color .2s, box-shadow .2s;
	width: 100%;
}
.ts-input:focus { border-color: var(--ts-saffron); outline: none; box-shadow: 0 0 0 3px rgba(194,97,72,.12); }
.ts-textarea { resize: vertical; min-height: 80px; }

.ts-select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M0 0l6 8 6-8z' fill='%237B2D1E'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 32px; }

/* Buttons */
.ts-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 11px 22px;
	border-radius: 6px;
	font-family: 'Nunito Sans', sans-serif;
	font-size: 15px;
	font-weight: 700;
	cursor: pointer;
	border: 2px solid transparent;
	transition: all .2s;
	text-decoration: none;
}
.ts-btn-primary { background: var(--ts-saffron); color: #fff; border-color: var(--ts-terracotta); }
.ts-btn-primary:hover { background: var(--ts-terracotta); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(123,45,30,.25); }
.ts-btn-secondary { background: var(--ts-cream); color: var(--ts-terracotta); border-color: var(--ts-gold); }
.ts-btn-secondary:hover { background: #f3e6d4; }

/* Label */
.ts-label { font-weight: 600; color: var(--ts-muted); margin-bottom: 10px; }
.ts-subheading { font-family: 'Cormorant Garamond', serif; color: var(--ts-terracotta); font-size: 18px; margin: 16px 0 14px; border-bottom: 1px solid var(--ts-border); padding-bottom: 8px; }

/* Existing beneficiaries */
.ts-existing-bens { margin-bottom: 20px; }
.ts-existing-bens .ts-select { margin-bottom: 14px; }
.ts-divider-text { text-align: center; color: var(--ts-muted); font-size: 13px; margin: 12px 0; position: relative; }
.ts-divider-text::before, .ts-divider-text::after { content: ''; position: absolute; top: 50%; width: 40%; height: 1px; background: var(--ts-border); }
.ts-divider-text::before { left: 0; }
.ts-divider-text::after { right: 0; }

.ts-back-link { margin-bottom: 12px; }
.ts-back-link a { color: var(--ts-saffron); font-size: 13px; text-decoration: none; }
.ts-back-link a:hover { text-decoration: underline; }

/* Puja type cards */
.ts-puja-cards { display: flex; flex-direction: column; gap: 10px; }
.ts-puja-card { cursor: pointer; }
.ts-puja-radio { position: absolute; opacity: 0; width: 0; height: 0; }
.ts-puja-card-inner {
	display: flex;
	flex-direction: column;
	gap: 3px;
	border: 2px solid var(--ts-border);
	border-radius: 8px;
	padding: 12px 16px;
	transition: border-color .2s, background .2s;
	background: #fff;
}
.ts-puja-card-inner strong { color: var(--ts-terracotta); font-size: 15px; }
.ts-puja-card-inner span { color: var(--ts-muted); font-size: 13px; }
.ts-puja-radio:checked + .ts-puja-card-inner {
	border-color: var(--ts-saffron);
	background: var(--ts-cream);
}
.ts-puja-card:hover .ts-puja-card-inner { border-color: var(--ts-gold); background: var(--ts-cream); }

/* Char count */
.ts-char-count { font-size: 11px; color: var(--ts-muted); font-weight: 400; margin-left: 6px; }

/* Selected ben notice */
.ts-selected-ben-notice {
	background: var(--ts-cream);
	border: 1px solid var(--ts-gold);
	border-radius: 6px;
	padding: 10px 16px;
	font-size: 14px;
	color: var(--ts-terracotta);
	margin-bottom: 20px;
}

/* Error */
.ts-error-message {
	background: #fff5f5;
	border: 1px solid #f5c6c6;
	border-radius: 6px;
	padding: 10px 14px;
	color: #c00;
	font-size: 14px;
	margin: 12px 0;
}

/* Actions */
.ts-step-actions { display: flex; gap: 12px; align-items: center; margin-top: 20px; flex-wrap: wrap; }

/* Confirmation */
.ts-confirmation {
	text-align: center;
	padding: 20px 0;
}
.ts-confirm-icon { font-size: 52px; margin-bottom: 12px; animation: ts-glow 2s infinite alternate; }
@keyframes ts-glow {
	from { text-shadow: 0 0 8px rgba(212,168,83,.4); }
	to   { text-shadow: 0 0 24px rgba(212,168,83,.9); }
}
.ts-confirm-title {
	font-family: 'Cormorant Garamond', serif;
	font-size: 28px;
	color: var(--ts-terracotta);
	margin: 0 0 12px;
}
.ts-confirm-message {
	font-size: 16px;
	color: var(--ts-text);
	margin-bottom: 8px;
	font-weight: 600;
}
.ts-confirm-sub { color: var(--ts-muted); font-size: 14px; }

/* Spinner */
.ts-btn.ts-loading { opacity: .7; cursor: not-allowed; }
.ts-btn.ts-loading::after { content: ' ⏳'; }

@media (max-width: 560px) {
	.ts-step { padding: 20px 16px; }
	.ts-form-grid { grid-template-columns: 1fr; }
	.ts-field.ts-full { grid-column: auto; }
}

/* ==========================================================================
   CHANGE: Temple Selection Step Styles
   New styles for the ts-step-temple step introduced in v1.1.0.
   ========================================================================== */

/* Grid of temple cards */
.ts-temple-cards {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 16px;
	margin: 16px 0 24px;
}

/* Individual temple card (label wraps radio + content) */
.ts-temple-card {
	display: flex;
	cursor: pointer;
}

.ts-temple-card input[type="radio"] {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.ts-temple-card-inner {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 6px;
	padding: 18px 20px;
	border: 2px solid #e2d9d0;
	border-radius: 10px;
	background: #fffaf6;
	width: 100%;
	transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}

/* Hover state */
.ts-temple-card:hover .ts-temple-card-inner {
	border-color: #C26148;
	background: #fff4ee;
}

/* Selected state – applied via JS when radio is checked */
.ts-temple-card--selected .ts-temple-card-inner,
.ts-temple-card input[type="radio"]:checked + .ts-temple-card-inner {
	border-color: #C26148;
	background: #fff4ee;
	box-shadow: 0 0 0 3px rgba(194, 97, 72, 0.18);
}

.ts-temple-icon {
	font-size: 1.8rem;
	line-height: 1;
}

.ts-temple-name {
	font-size: 1rem;
	font-weight: 700;
	color: #3b2212;
	line-height: 1.3;
}

.ts-temple-deity {
	font-size: 0.88rem;
	color: #7B2D1E;
	font-style: italic;
}

.ts-temple-place {
	font-size: 0.82rem;
	color: #7a6250;
	margin-top: 2px;
}

/* Info notice when no temples available */
.ts-notice-info {
	background: #fff8f0;
	border-left: 4px solid #D4A853;
	padding: 14px 18px;
	border-radius: 6px;
	color: #5a4a38;
	margin: 16px 0;
}

/* ==========================================================================
   CHANGE: Puja Price Badge – v1.2.0
   Displays the admin-configured price on each puja selection card.
   Price shows "Free" when 0, or "₹X.XX" for paid sevas.
   ========================================================================== */

.ts-puja-price {
	display: inline-block;
	margin-top: 8px;
	padding: 4px 12px;
	border-radius: 20px;
	font-size: 0.88rem;
	font-weight: 700;
	background: #fff3e8;
	color: #7B2D1E;
	border: 1px solid #e8c9a8;
	letter-spacing: 0.02em;
	align-self: flex-start;
}

/* Highlight price badge when the card is selected */
.ts-puja-card input[type="radio"]:checked ~ .ts-puja-card-inner .ts-puja-price,
.ts-puja-card--selected .ts-puja-price {
	background: #7B2D1E;
	color: #fff;
	border-color: #7B2D1E;
}

/* ==========================================================================
   CHANGE v1.3.0: Notification Step Styles
   ========================================================================== */

.ts-notify-question { margin-bottom: 24px; }

.ts-notify-prompt {
	font-size: 16px;
	font-weight: 600;
	color: var(--ts-terracotta);
	margin-bottom: 18px;
	line-height: 1.5;
}

.ts-notify-options {
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
	margin-bottom: 8px;
}

.ts-notify-option-label { cursor: pointer; }

.ts-notify-option-label input[type="radio"] {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.ts-notify-option-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 12px 24px;
	border: 2px solid var(--ts-border);
	border-radius: 8px;
	font-size: 15px;
	font-weight: 600;
	background: #fff;
	color: var(--ts-text);
	transition: all .2s;
	cursor: pointer;
}

.ts-notify-option-label input[type="radio"]:checked + .ts-notify-option-btn,
.ts-notify-option--active {
	border-color: var(--ts-saffron);
	background: var(--ts-cream);
	color: var(--ts-terracotta);
	box-shadow: 0 0 0 3px rgba(194,97,72,.15);
}

.ts-notify-option-btn:hover {
	border-color: var(--ts-gold);
	background: var(--ts-cream);
}

/* Notification details sub-form */
.ts-notify-details {
	border-top: 1px solid var(--ts-border);
	padding-top: 20px;
	margin-top: 16px;
}

/* Channel toggle (WhatsApp / Email) */
.ts-channel-toggle {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.ts-channel-option { cursor: pointer; }

.ts-channel-option input[type="radio"] {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.ts-channel-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 9px 18px;
	border: 1.5px solid var(--ts-border);
	border-radius: 6px;
	font-size: 14px;
	font-weight: 600;
	background: #fff;
	color: var(--ts-muted);
	transition: all .2s;
	cursor: pointer;
}

.ts-channel-option input[type="radio"]:checked + .ts-channel-btn,
.ts-channel-btn--active {
	border-color: var(--ts-saffron);
	background: var(--ts-cream);
	color: var(--ts-terracotta);
}

.ts-field-hint {
	font-size: 12px;
	color: var(--ts-muted);
	margin-top: 2px;
}

/* ==========================================================================
   CHANGE v1.3.0: Payment Step Styles
   ========================================================================== */

/* Seva summary box */
.ts-payment-summary {
	background: var(--ts-cream);
	border: 1px solid var(--ts-border);
	border-radius: var(--ts-radius);
	padding: 20px 24px;
	margin-bottom: 28px;
}

.ts-payment-summary-title {
	font-family: 'Cormorant Garamond', serif;
	font-size: 18px;
	color: var(--ts-terracotta);
	margin: 0 0 16px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--ts-border);
}

.ts-summary-row {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: 7px 0;
	border-bottom: 1px dashed var(--ts-border);
	font-size: 14px;
}

.ts-summary-row:last-child { border-bottom: none; }

.ts-summary-label {
	color: var(--ts-muted);
	font-weight: 600;
	text-transform: uppercase;
	font-size: 12px;
	letter-spacing: .04em;
}

.ts-summary-value {
	color: var(--ts-text);
	font-weight: 600;
	text-align: right;
	flex: 1;
	margin-left: 16px;
}

.ts-summary-total {
	margin-top: 8px;
	padding-top: 12px;
	border-top: 2px solid var(--ts-gold);
	border-bottom: none;
}

.ts-total-amount {
	font-size: 20px;
	color: var(--ts-terracotta);
	font-family: 'Cormorant Garamond', serif;
}

/* Devotional content */
.ts-devotional-content {
	background: linear-gradient(135deg, #fffdf7 0%, #fff5e8 100%);
	border: 1px solid var(--ts-gold);
	border-radius: var(--ts-radius);
	padding: 28px 32px;
	text-align: center;
	margin-bottom: 28px;
}

.ts-devotional-icon {
	font-size: 40px;
	margin-bottom: 12px;
	animation: ts-glow 2s infinite alternate;
}

.ts-devotional-title {
	font-family: 'Cormorant Garamond', serif;
	font-size: 22px;
	color: var(--ts-terracotta);
	margin: 0 0 16px;
}

.ts-devotional-text {
	font-size: 14px;
	color: var(--ts-text);
	line-height: 1.75;
	margin-bottom: 14px;
	text-align: left;
}

.ts-devotional-quote {
	font-family: 'Cormorant Garamond', serif;
	font-size: 16px;
	color: var(--ts-terracotta);
	font-style: italic;
	border-left: 4px solid var(--ts-gold);
	padding: 10px 18px;
	margin: 18px 0;
	background: rgba(212,168,83,.08);
	border-radius: 0 6px 6px 0;
	text-align: left;
}

.ts-devotional-note {
	color: var(--ts-muted);
	font-size: 13px;
	font-style: italic;
	text-align: center;
}

/* Submit button — slightly larger on payment page */
.ts-btn-submit {
	padding: 14px 28px;
	font-size: 16px;
}

@media (max-width: 560px) {
	.ts-notify-options { flex-direction: column; }
	.ts-channel-toggle { flex-direction: column; }
	.ts-devotional-content { padding: 20px 16px; }
	.ts-payment-summary { padding: 16px; }
}

/* ==========================================================================
   CHANGE v1.9.1: Removed the Onboarding / Authentication Screen and Guest
   Access Form CSS blocks that used to follow here. The Spiritual Care
   feature has no login/signup/guest gate any more, so those styles
   (.ts-onboarding-*, .ts-ob-btn, .ts-guest-*) are no longer needed.
   ========================================================================== */

