/* Janaz Announcements - Front-end */

:root {
	--jann-green:    #1a5c3a;
	--jann-green-lt: #e8f4ec;
	--jann-gold:     #c8a45a;
	--jann-border:   #e0e0e0;
	--jann-muted:    #666;
	--jann-radius:   10px;
	--jann-shadow:   0 2px 16px rgba(0,0,0,.07);
}

/* -- Card list ------ */
.janaz-ann-list { display: flex; flex-direction: column; gap: 1.25rem; }
.janaz-layout-grid .janaz-ann-list,
.janaz-ann-list.janaz-layout-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.25rem; }

/* -- Card --- */
.janaz-ann-card {
	background: #fff;
	border: 1px solid var(--jann-border);
	border-radius: var(--jann-radius);
	box-shadow: var(--jann-shadow);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

/* Age-class tints */
.janaz-ann-card.jann-age-baby  { border-left: 4px solid #a8d5c2; }
.janaz-ann-card.jann-age-child { border-left: 4px solid #7db8a4; }
.janaz-ann-card.jann-age-elder { border-left: 4px solid var(--jann-gold); }

.janaz-ann-card-link { text-decoration: none; color: inherit; display: flex; gap: 0; }
.janaz-ann-card-link * { text-decoration: none; }
.janaz-ann-card-link:hover { text-decoration: none; }

/* Photo */
.janaz-ann-photo-wrap {
	width: 90px;
	min-width: 90px;
	background: var(--jann-green-lt);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}
.janaz-ann-photo-wrap img { width: 100%; height: 100%; object-fit: cover; }
/* .janaz-ann-no-photo removed - no placeholder shown when photo absent */

/* Card body */
.janaz-ann-card-body { padding: 1rem 1.25rem; flex: 1; text-decoration: none; }
.janaz-ann-name  { font-size: 1.1rem; font-weight: 700; margin: 0 0 .1rem; color: #1a1a1a; }
.janaz-ann-name-sec { font-size: .875rem; color: var(--jann-muted); margin: 0 0 .4rem; }
.janaz-ann-dop   { font-size: .8rem; color: var(--jann-muted); margin: 0 0 .5rem; }

/* Age badge */
.jann-age-badge {
	display: inline-block;
	font-size: .7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	padding: 2px 8px;
	border-radius: 999px;
	margin-bottom: .5rem;
}
.jann-age-badge-baby  { background: #d4f0e7; color: #1a5c3a; }
.jann-age-badge-child { background: #d4f0e7; color: #1a5c3a; }
.jann-age-badge-youth { background: #e8f4ec; color: #2d7a52; }
.jann-age-badge-elder { background: #fdf3e0; color: #7a5a1a; }

.janaz-ann-detail { margin-bottom: .5rem; font-size: .875rem; }
.janaz-ann-detail strong { display: block; font-size: .75rem; text-transform: uppercase; letter-spacing: .05em; color: var(--jann-green); margin-bottom: 1px; }
.janaz-ann-detail span { display: block; }
.janaz-ann-loc { color: var(--jann-muted); text-decoration: none; }

/* Card footer */
.janaz-ann-card-footer {
	padding: .75rem 1.25rem;
	border-top: 1px solid var(--jann-border);
	background: #fafafa;
}
.janaz-ann-rsvp { font-size: .8rem; color: var(--jann-muted); margin-bottom: .5rem; }
.janaz-att-stat strong,
.janaz-ann-rsvp strong,
.janaz-att-count { color: var(--jann-green); font-weight: 700; }

/* RSVP buttons - always stay on one row, shrink gracefully on mobile */
.janaz-rsvp-btns {
	display: flex;
	gap: .4rem;
	flex-wrap: nowrap;   /* keep on one row */
	margin-top: .4rem;
}
.janaz-rsvp-btn {
	border: 1.5px solid var(--jann-green);
	background: #fff;
	color: var(--jann-green);
	padding: .3rem .7rem;
	border-radius: 999px;
	font-size: .78rem;
	cursor: pointer;
	font-family: inherit;
	transition: background .15s, color .15s;
	white-space: nowrap;   /* prevent text wrapping inside button */
	line-height: 1.3;
}
.janaz-rsvp-btn:hover,
.janaz-rsvp-btn.active { background: var(--jann-green); color: #fff; }

/* Du'a emoji - use brown heart to represent brown skin tones consistently */
.jann-dua-icon {
	font-style: normal;
	/* 🤎 renders as brown heart universally; we position it as the du'a icon */
}

/* Fund button */
.jann-fund-btn {
	display: inline-block;
	margin-top: .5rem;
	padding: .4rem .9rem;
	border-radius: 999px;
	background: var(--jann-green-lt);
	color: var(--jann-green);
	font-size: .8rem;
	font-weight: 600;
	text-decoration: none;
	border: 1.5px solid var(--jann-green);
	transition: background .15s, color .15s;
	white-space: nowrap;
}
.jann-fund-btn:hover { background: var(--jann-green); color: #fff; }

/* -- Single page --- */
.jann-single { padding: 2rem 0; }


.jann-single-card {
	background: #fff;
	border: 1px solid var(--jann-border);
	border-radius: var(--jann-radius);
	box-shadow: var(--jann-shadow);
}

/* Photo strip */
.jann-photo-strip { display: flex; gap: 1px; background: #000; border-bottom: 1px solid var(--jann-border); }
.jann-photo-strip img { flex: 1; min-width: 0; aspect-ratio: 4/3; object-fit: cover; }

.jann-single-header { padding: 2rem 2rem 1.25rem; border-bottom: 1px solid var(--jann-border); }
.jann-single-name    { font-size: clamp(1.5rem, 4vw, 2.25rem); margin: 0 0 .35rem; }
.jann-single-name-sec { font-size: 1rem; color: var(--jann-muted); margin: 0 0 .75rem; }
.jann-single-meta { display: flex; gap: 1rem; flex-wrap: wrap; font-size: .875rem; color: var(--jann-muted); }
.jann-single-meta strong { color: #333; }

.jann-service-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.jann-service-block {
	padding: 1.5rem 2rem;
	border-right: 1px solid var(--jann-border);
	border-bottom: 1px solid var(--jann-border);
}
.jann-service-block:last-child { border-right: none; }
.jann-service-block h2 { font-size: .8rem; text-transform: uppercase; letter-spacing: .07em; color: var(--jann-green); margin: 0 0 .75rem; }
.jann-datetime { font-size: 1rem; font-weight: 600; margin: 0 0 .25rem; }
.jann-venue    { margin: 0 0 .25rem; font-size: .9rem; }
.jann-address  { font-style: normal; font-size: .85rem; color: var(--jann-muted); margin: .25rem 0; }
.jann-map-link { font-size: .85rem; color: var(--jann-green); }

.jann-family-notes {
	padding: 1.5rem 2rem;
	background: var(--jann-green-lt);
	border-bottom: 1px solid var(--jann-border);
}
.jann-family-notes h2 { font-size: .8rem; text-transform: uppercase; letter-spacing: .07em; color: var(--jann-green); margin: 0 0 .5rem; }
.jann-survived-by { padding: 1.25rem 2rem; border-bottom: 1px solid var(--jann-border); font-size: .95rem; }
.jann-survived-by strong { display: block; color: var(--jann-green); font-size: .8rem; text-transform: uppercase; letter-spacing: .05em; margin-bottom: .25rem; }

/* RSVP section - single page */
.jann-rsvp-section { padding: 2rem; }
.jann-rsvp-section h2 { font-size: 1.15rem; margin: 0 0 1rem; }
.jann-att-summary { display: flex; gap: 1.5rem; flex-wrap: wrap; font-size: .9rem; margin-bottom: 1.25rem; }
.jann-att-count { color: var(--jann-green); font-weight: 700; font-size: 1.2rem; display: block; }
.jann-att-label { display: block; font-size: .8rem; color: var(--jann-muted); }

/* Single-page RSVP buttons - also stay on one row */
.jann-single-rsvp .janaz-rsvp-btns {
	flex-wrap: nowrap;
	gap: .5rem;
}
.jann-single-rsvp .janaz-rsvp-btn {
	padding: .5rem 1.1rem;
	font-size: .9rem;
}

.jann-rsvp-fields { display: flex; gap: .5rem; flex-wrap: wrap; margin: .75rem 0; }
.jann-input {
	padding: .6rem .9rem;
	border: 1px solid var(--jann-border);
	border-radius: var(--jann-radius);
	font-size: .95rem;
	font-family: inherit;
	width: 100%;
	box-sizing: border-box;
}
.jann-input:focus { outline: none; border-color: var(--jann-green); box-shadow: 0 0 0 3px rgba(26,92,58,.1); }
.jann-rsvp-msg {
	margin-top: .75rem;
	padding: .75rem 1rem;
	border-radius: var(--jann-radius);
	background: var(--jann-green-lt);
	color: var(--jann-green);
	font-weight: 500;
}

/* Fund section */
.jann-fund-section { padding: 1.5rem 2rem; border-top: 1px solid var(--jann-border); }
.jann-fund-section h2 { font-size: 1.15rem; margin: 0 0 .75rem; }
.jann-fund-btn-lg {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .75rem 1.5rem;
	border-radius: var(--jann-radius);
	background: var(--jann-green);
	color: #fff;
	font-size: 1rem;
	font-weight: 600;
	text-decoration: none;
	transition: background .15s;
	white-space: nowrap;
}
.jann-fund-btn-lg:hover { background: #134a2d; }

/* -- Submission form --- */
.jann-form-wrap { max-width: 700px; margin: 0 auto; }
.jann-notice { background: var(--jann-green-lt); border-left: 4px solid var(--jann-green); padding: .75rem 1rem; border-radius: 0 var(--jann-radius) var(--jann-radius) 0; margin-bottom: 1.5rem; font-size: .9rem; }
.jann-fieldset { border: 1px solid var(--jann-border); border-radius: var(--jann-radius); padding: 1.5rem; margin-bottom: 1.5rem; }
.jann-fieldset legend { font-weight: 700; color: var(--jann-green); padding: 0 .5rem; font-size: .95rem; }
.jann-field { margin-bottom: 1rem; }
.jann-field:last-child { margin-bottom: 0; }
.jann-field > label { display: block; font-weight: 600; margin-bottom: .35rem; font-size: .9rem; }
.jann-req { color: #c00; }
.jann-row { display: flex; gap: .5rem; align-items: flex-start; }
.jann-row > * { flex: 1; }
.jann-submit-row { margin-top: .5rem; }
.jann-form-msg { margin-top: 1rem; padding: .75rem 1rem; border-radius: var(--jann-radius); font-size: .9rem; }
.jann-form-msg.success { background: var(--jann-green-lt); color: var(--jann-green); }
.jann-form-msg.error   { background: #fdf0f0; color: #c00; }

/* -- Archive --- */
.jann-archive-header { margin-bottom: 2rem; }
.janaz-no-results { color: var(--jann-muted); text-align: center; padding: 3rem 0; }

/* -- Responsive --- */
@media (max-width: 640px) {
	.jann-service-grid    { grid-template-columns: 1fr; }
	.jann-service-block   { border-right: none; }

	/* Card buttons: compact but still inline on mobile */
	.janaz-rsvp-btns      { gap: .3rem; }
	.janaz-rsvp-btn       { padding: .28rem .55rem; font-size: .72rem; }

	/* Single-page RSVP: scale down proportionally */
	.jann-single-rsvp .janaz-rsvp-btn { padding: .4rem .75rem; font-size: .82rem; }

	.jann-rsvp-fields     { flex-direction: column; }
	.jann-row             { flex-direction: column; }
	.janaz-ann-photo-wrap { width: 72px; min-width: 72px; }

	/* Donation button on mobile - slightly smaller */
	.jann-fund-btn-lg { padding: .6rem 1.1rem; font-size: .9rem; }
}
/* ═══════════════════════════════════════════════════════════════════
   RSVP FIELDS + ATTEND ACTIONS — high-specificity, cache-busted
   ═══════════════════════════════════════════════════════════════════ */

/* ── Separator between RSVP buttons and the action panel ─────────── */
.janaz-ann-rsvp .jann-attend-actions {
	display: flex !important;
	gap: .5rem !important;
	flex-wrap: wrap !important;
	align-items: center !important;
	margin-top: .9rem !important;
	padding: .7rem .85rem !important;
	background: #f0f7f3 !important;
	border: 1.5px solid #c2dac9 !important;
	border-radius: 14px !important;
	box-sizing: border-box !important;
}

/* ── Base pill — both buttons share this ─────────────────────────── */
.janaz-ann-rsvp .jann-attend-actions .jann-action-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: .35rem !important;
	font-family: inherit !important;
	font-size: .82rem !important;
	font-weight: 700 !important;
	line-height: 1 !important;
	letter-spacing: .01em !important;
	padding: .55rem 1.05rem !important;
	border-radius: 50px !important;
	cursor: pointer !important;
	text-decoration: none !important;
	white-space: nowrap !important;
	transition: background .15s ease, box-shadow .15s ease, transform .1s ease !important;
	-webkit-tap-highlight-color: transparent !important;
	box-sizing: border-box !important;
}
.janaz-ann-rsvp .jann-attend-actions .jann-action-btn:active {
	transform: scale(.96) !important;
}
.janaz-ann-rsvp .jann-attend-actions .jann-action-btn svg {
	display: block !important;
	flex-shrink: 0 !important;
	width: 14px !important;
	height: 14px !important;
}

/* ── Get Directions — solid green pill ───────────────────────────── */
.janaz-ann-rsvp .jann-attend-actions .jann-action-directions {
	background: #1a5c3a !important;
	color: #ffffff !important;
	border: none !important;
	box-shadow: 0 2px 6px rgba(26,92,58,.28) !important;
}
.janaz-ann-rsvp .jann-attend-actions .jann-action-directions:hover {
	background: #14472c !important;
	box-shadow: 0 3px 10px rgba(26,92,58,.38) !important;
	color: #ffffff !important;
}

/* ── Share — outlined pill ───────────────────────────────────────── */
.janaz-ann-rsvp .jann-attend-actions .jann-action-share {
	background: #ffffff !important;
	color: #1a5c3a !important;
	border: 1.5px solid #1a5c3a !important;
	box-shadow: none !important;
}
.janaz-ann-rsvp .jann-attend-actions .jann-action-share:hover {
	background: rgba(26,92,58,.06) !important;
}
.janaz-ann-rsvp .jann-attend-actions .jann-action-share.jann-share-copied {
	background: #b8902a !important;
	border-color: #b8902a !important;
	color: #ffffff !important;
}

/* ── Name/email fields inside card ───────────────────────────────── */
.janaz-ann-card-footer .jann-rsvp-fields {
	display: flex !important;
	flex-direction: column !important;
	gap: .45rem !important;
	margin-top: .7rem !important;
}
.janaz-ann-card-footer .jann-rsvp-fields input.jann-input {
	display: block !important;
	width: 100% !important;
	box-sizing: border-box !important;
	padding: .55rem .8rem !important;
	font-size: .83rem !important;
	font-family: inherit !important;
	color: #222 !important;
	background: #fff !important;
	border: 1.5px solid #d4d4d4 !important;
	border-radius: 10px !important;
	outline: none !important;
	transition: border-color .15s, box-shadow .15s !important;
	-webkit-appearance: none !important;
}
.janaz-ann-card-footer .jann-rsvp-fields input.jann-input:focus {
	border-color: #1a5c3a !important;
	box-shadow: 0 0 0 3px rgba(26,92,58,.12) !important;
}
.janaz-ann-card-footer .jann-rsvp-fields input.jann-input::placeholder {
	color: #aaa !important;
}

/* ── Confirm button ──────────────────────────────────────────────── */
.janaz-ann-rsvp .jann-rsvp-confirm {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 100% !important;
	padding: .6rem 1rem !important;
	margin-top: .2rem !important;
	font-family: inherit !important;
	font-size: .84rem !important;
	font-weight: 700 !important;
	letter-spacing: .02em !important;
	line-height: 1 !important;
	background: #1a5c3a !important;
	color: #ffffff !important;
	border: none !important;
	border-radius: 50px !important;
	cursor: pointer !important;
	box-shadow: 0 2px 6px rgba(26,92,58,.25) !important;
	transition: background .15s, box-shadow .15s, transform .1s !important;
	-webkit-appearance: none !important;
	box-sizing: border-box !important;
}
.janaz-ann-rsvp .jnn-rsvp-confirm:hover,
.janaz-ann-rsvp .jann-rsvp-confirm:hover { background: #14472c !important; }
.janaz-ann-rsvp .jann-rsvp-confirm:active { transform: scale(.97) !important; }

/* ── Success message ─────────────────────────────────────────────── */
.janaz-ann-rsvp .jann-rsvp-msg {
	font-size: .82rem !important;
	font-weight: 600 !important;
	color: #1a5c3a !important;
	margin-top: .5rem !important;
	padding: 0 !important;
	background: none !important;
	border: none !important;
}

/* ── Single page: larger buttons ────────────────────────────────── */
.jann-single-rsvp .jann-attend-actions {
	margin-top: 1.1rem !important;
	padding: .85rem 1.1rem !important;
}
.jann-single-rsvp .jann-attend-actions .jann-action-btn {
	font-size: .9rem !important;
	padding: .65rem 1.25rem !important;
}
.jann-single-rsvp .jann-attend-actions .jann-action-btn svg {
	width: 15px !important;
	height: 15px !important;
}

/* ═══════════════════════════════════════════════════════════════════
   ANNOUNCING MASJID BOX
   ═══════════════════════════════════════════════════════════════════ */

.jann-masjid-box {
	margin: 0;
	padding: 1.5rem 2rem;
	border-top: 1px solid var(--jann-border);
	background: #fafaf8;
}

.jann-masjid-eyebrow {
	font-size: .72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: var(--jann-green);
	margin: 0 0 .75rem;
}

.jann-masjid-inner {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.jann-masjid-avatar {
	width: 52px;
	height: 52px;
	border-radius: 12px;
	background: var(--jann-green-lt);
	border: 1.5px solid #c6ddc9;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	flex-shrink: 0;
	font-size: 1.5rem;
}
.jann-masjid-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.jann-masjid-content {
	flex: 1;
	min-width: 0;
}

.jann-masjid-name {
	display: block;
	font-size: 1rem;
	font-weight: 700;
	color: #1a1a1a;
	margin-bottom: .25rem;
}

.jann-masjid-meta {
	display: flex;
	gap: .75rem;
	flex-wrap: wrap;
	font-size: .82rem;
	color: var(--jann-muted);
	margin-bottom: .6rem;
}

.jann-masjid-links {
	display: flex;
	gap: .5rem;
	flex-wrap: wrap;
}

.jann-masjid-link {
	display: inline-block;
	font-size: .78rem;
	font-weight: 600;
	padding: .3rem .85rem;
	border-radius: 999px;
	text-decoration: none;
	transition: background .15s, color .15s;
}

.jann-masjid-link--solid {
	background: var(--jann-green);
	color: #fff;
	border: 1.5px solid var(--jann-green);
}
.jann-masjid-link--solid:hover {
	background: #134a2d;
	border-color: #134a2d;
	color: #fff;
}

.jann-masjid-link--outline {
	background: #fff;
	color: var(--jann-green);
	border: 1.5px solid var(--jann-green);
}
.jann-masjid-link--outline:hover {
	background: var(--jann-green-lt);
}

/* ═══════════════════════════════════════════════════════════════════
   SHARE ROW
   ═══════════════════════════════════════════════════════════════════ */

.jann-share-row {
	padding: 1.25rem 2rem;
	border-top: 1px solid var(--jann-border);
	display: flex;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
}

.jann-share-eyebrow {
	font-size: .72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: var(--jann-muted);
	white-space: nowrap;
}

.jann-share-btns {
	display: flex;
	gap: .45rem;
	flex-wrap: wrap;
	align-items: center;
}

/* Base share pill */
.jann-share-btn {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	padding: .42rem .9rem;
	border-radius: 999px;
	font-size: .78rem;
	font-weight: 600;
	font-family: inherit;
	text-decoration: none;
	cursor: pointer;
	border: 1.5px solid transparent;
	transition: opacity .15s, transform .1s;
	line-height: 1;
	white-space: nowrap;
}
.jann-share-btn:hover  { opacity: .85; text-decoration: none; }
.jann-share-btn:active { transform: scale(.95); }

/* Brand colours */
.jann-share-wa   { background: #25D366; color: #fff; }
.jann-share-fb   { background: #1877F2; color: #fff; }
.jann-share-x    { background: #000;    color: #fff; }
.jann-share-sms  { background: #34b7f1; color: #fff; }
.jann-share-copy {
	background: #fff;
	color: var(--jann-green);
	border-color: var(--jann-green);
}
.jann-share-copy:hover { background: var(--jann-green-lt); }

/* Hide labels on very small screens, keep icons */
@media (max-width: 480px) {
	.jann-share-label { display: none; }
	.jann-share-btn   { padding: .42rem .6rem; }
}

/* ═══════════════════════════════════════════════════════════════════
   INNA LILLAHI REMINDER BLOCK
   ═══════════════════════════════════════════════════════════════════ */

.jann-inna-reminder {
	padding: 2rem 2rem 1.75rem;
	border-top: 1px solid var(--jann-border);
	text-align: center;
	background: #f9f8f5;
}

.jann-inna-arabic {
	font-family: 'Scheherazade New', 'Amiri', Georgia, serif;
	font-size: clamp(1.25rem, 3vw, 1.7rem);
	color: var(--jann-green);
	direction: rtl;
	line-height: 1.8;
	margin: 0 0 .4rem;
}

.jann-inna-roman {
	font-size: .95rem;
	font-style: italic;
	color: #444;
	margin: 0 0 .3rem;
}

.jann-inna-translation {
	font-size: .88rem;
	color: var(--jann-muted);
	margin: 0 0 .6rem;
}

.jann-inna-note {
	font-size: .78rem;
	color: #aaa;
	margin: 0;
	font-style: italic;
}

/* ═══════════════════════════════════════════════════════════════════
   CONDOLENCES CALLOUT  (bridges to janaz-comments section below)
   ═══════════════════════════════════════════════════════════════════ */

.jann-condolences-callout {
	padding: 1.75rem 2rem;
	border-top: 1px solid var(--jann-border);
	background: #fff;
	display: flex;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
}

.jann-condolences-callout-icon {
	font-size: 2rem;
	line-height: 1;
	flex-shrink: 0;
}

.jann-condolences-callout-text {
	flex: 1;
	min-width: 200px;
}

.jann-condolences-callout-text h3 {
	font-size: 1rem;
	font-weight: 700;
	color: #1a1a1a;
	margin: 0 0 .2rem;
}

.jann-condolences-callout-text p {
	font-size: .85rem;
	color: var(--jann-muted);
	margin: 0;
}

.jann-condolences-callout-arrow {
	font-size: .85rem;
	color: var(--jann-green);
	font-weight: 600;
	white-space: nowrap;
	text-decoration: none;
}
.jann-condolences-callout-arrow:hover {
	text-decoration: underline;
}

/* ═══════════════════════════════════════════════════════════════════
   RESPONSIVE ADDITIONS
   ═══════════════════════════════════════════════════════════════════ */

@media (max-width: 640px) {
	.jann-masjid-box,
	.jann-share-row,
	.jann-inna-reminder,
	.jann-condolences-callout { padding-left: 1.25rem; padding-right: 1.25rem; }

	.jann-masjid-inner { gap: .75rem; }
	.jann-masjid-avatar { width: 44px; height: 44px; }

	.jann-share-row { gap: .6rem; }
}
