/*
 * Hafdz Du'a — wall + modal form. Mirrors the trust-first design tokens
 * used by [waqf_projects] so the two plugins read as one product.
 *
 * All tokens are scoped to the wall and dialog roots; the styles work in
 * isolation regardless of the surrounding theme.
 */

.hafdz-dua-wall,
.hafdz-dua-dialog {
	--hd-bg: #fafaf7;
	--hd-surface: #ffffff;
	--hd-surface-2: #f5f4ef;
	--hd-border: #e8e6df;
	--hd-border-strong: #d8d5cc;
	--hd-ink: #1a1a17;
	--hd-ink-2: #4a4a44;
	--hd-ink-3: #8a8880;
	--hd-ink-4: #b8b6ad;
	--hd-accent: #0d5c4a;
	--hd-accent-hover: #0a4a3b;
	--hd-accent-soft: #e6efec;
	--hd-accent-ink: #073128;
	--hd-warm-soft: #f6ecd9;
	--hd-warm-ink: #8a5a1f;
	--hd-success: #2e7d5b;
	--hd-danger: #b84a3a;

	--hd-radius-sm: 6px;
	--hd-radius-md: 10px;
	--hd-radius-lg: 14px;

	--hd-shadow-lg: 0 16px 48px -12px rgba(20, 20, 15, 0.18);

	--hd-font-sans: "Inter Tight", "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--hd-font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

	color: var(--hd-ink);
	font-family: var(--hd-font-sans);
	font-size: 14px;
	line-height: 1.45;
	-webkit-font-smoothing: antialiased;
}

.hafdz-dua-wall *,
.hafdz-dua-wall *::before,
.hafdz-dua-wall *::after,
.hafdz-dua-dialog *,
.hafdz-dua-dialog *::before,
.hafdz-dua-dialog *::after {
	box-sizing: border-box;
}

/* ===== Wall card ===== */
.hafdz-dua-wall__card {
	background: var(--hd-surface);
	border: 1px solid var(--hd-border);
	border-radius: var(--hd-radius-md);
	overflow: hidden;
}

.hafdz-dua-wall__header {
	display: flex;
	gap: 24px;
	align-items: end;
	justify-content: space-between;
	padding: 24px 24px 20px;
	border-bottom: 1px solid var(--hd-border);
	flex-wrap: wrap;
}
.hafdz-dua-wall__eyebrow {
	font-family: var(--hd-font-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--hd-ink-3);
	font-weight: 500;
	margin-bottom: 8px;
}
.hafdz-dua-wall__title {
	margin: 0;
	font-size: 22px;
	font-weight: 600;
	letter-spacing: -0.015em;
	line-height: 1.2;
	color: var(--hd-ink);
}
.hafdz-dua-wall__subtitle {
	margin: 4px 0 0;
	font-size: 13px;
	color: var(--hd-ink-3);
}

/* ===== Verse ===== */
.hafdz-dua-wall__verse {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	padding: 24px;
	text-align: center;
	background: var(--hd-surface-2);
	border-bottom: 1px solid var(--hd-border);
}
.hafdz-dua-wall__verse-arabic {
	margin: 0;
	max-width: 100%;
	font-family: "qpc-hafs", "Amiri", "Scheherazade New", "Noto Naskh Arabic", "Traditional Arabic", serif;
	font-size: 28px;
	line-height: 2.1;
	color: var(--hd-ink);
	letter-spacing: 0;
	text-align: center;
	font-weight: normal;
}
/* QPC HAFS tajweed markers from /surahs/{n}/ayahs/{a}. Soft-tints the
   highlighted letters; theme-friendly and falls back gracefully when the
   `<rule>` wrapper isn't present. */
.hafdz-dua-wall__verse-arabic rule { color: inherit; }
.hafdz-dua-wall__verse-arabic rule.ham_wasl          { color: #9ca3af; }
.hafdz-dua-wall__verse-arabic rule.laam_shamsiyah    { color: #9ca3af; }
.hafdz-dua-wall__verse-arabic rule.madda_normal      { color: var(--hd-accent); }
.hafdz-dua-wall__verse-arabic rule.madda_permissible { color: var(--hd-accent); }
.hafdz-dua-wall__verse-arabic rule.ghunnah           { color: #b45309; }
.hafdz-dua-wall__verse-arabic rule.qalaqah           { color: #b45309; }
.hafdz-dua-wall__verse-arabic rule.ikhafa            { color: #7c3aed; }
.hafdz-dua-wall__verse-arabic rule.idgham_wo_ghunnah { color: #7c3aed; }
.hafdz-dua-wall__verse-translation {
	margin: 0 auto;
	max-width: 56ch;
	font-family: "Instrument Serif", "Cormorant Garamond", Georgia, serif;
	font-size: 17px;
	font-style: italic;
	line-height: 1.55;
	color: var(--hd-ink-2);
	letter-spacing: -0.005em;
	text-align: center;
}
.hafdz-dua-wall__verse-cite {
	display: inline-block;
	margin: 0;
	font-family: var(--hd-font-mono);
	font-size: 11px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--hd-ink-3);
	font-style: normal;
	text-align: center;
}

/* ===== Toolbar ===== */
.hafdz-dua-toolbar {
	display: flex;
	gap: 16px;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	padding: 14px 24px;
	border-bottom: 1px solid var(--hd-border);
}
.hafdz-dua-toolbar__chips {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}
.hafdz-dua-chip {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 12px;
	border-radius: 999px;
	border: 1px solid var(--hd-border);
	background: transparent;
	color: var(--hd-ink-2);
	font-family: inherit;
	font-size: 12px;
	font-weight: 500;
	cursor: pointer;
	white-space: nowrap;
	transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}
.hafdz-dua-chip:hover { background: var(--hd-surface-2); }
.hafdz-dua-chip.is-active {
	border-color: var(--hd-accent);
	background: var(--hd-accent-soft);
	color: var(--hd-accent-ink);
}

/* ===== Buttons ===== */
.hafdz-dua-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 16px;
	border-radius: var(--hd-radius-sm);
	border: 1px solid var(--hd-border-strong);
	background: var(--hd-surface);
	color: var(--hd-ink);
	font-family: inherit;
	font-size: 13px;
	font-weight: 500;
	cursor: pointer;
	text-decoration: none;
	transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}
.hafdz-dua-btn:hover { background: var(--hd-surface-2); }
/* Compound class for higher specificity — beats theme.json `elements.link`
   rules like `:root :where(a:where(:not(.wp-element-button))) { color: inherit; }`
   and stops the theme from re-coloring the label as a "visited" link. */
.hafdz-dua-btn.hafdz-dua-btn--primary,
.hafdz-dua-btn.hafdz-dua-btn--primary:link,
.hafdz-dua-btn.hafdz-dua-btn--primary:visited {
	background: var(--hd-accent);
	color: #fff;
	border-color: var(--hd-accent);
	text-decoration: none;
}
.hafdz-dua-btn.hafdz-dua-btn--primary:hover,
.hafdz-dua-btn.hafdz-dua-btn--primary:focus {
	background: var(--hd-accent-hover);
	border-color: var(--hd-accent-hover);
	color: #fff;
	text-decoration: none;
}
.hafdz-dua-btn[disabled] { opacity: 0.6; cursor: not-allowed; }

/* ===== List ===== */
.hafdz-dua-list {
	display: flex;
	flex-direction: column;
	padding: 0;
	margin: 0;
}
.hafdz-dua-card {
	padding: 20px 24px;
	border-top: 1px solid var(--hd-border);
	transition: background 120ms ease;
}
.hafdz-dua-card:first-child { border-top: 0; }
.hafdz-dua-card:hover { background: var(--hd-surface-2); }
.hafdz-dua-card__body {
	color: var(--hd-ink);
	font-size: 15px;
	line-height: 1.55;
	letter-spacing: -0.005em;
}
.hafdz-dua-card__body p { margin: 0 0 .5em; }
.hafdz-dua-card__body p:last-child { margin-bottom: 0; }
.hafdz-dua-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-top: 12px;
	flex-wrap: wrap;
}
.hafdz-dua-card__meta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	color: var(--hd-ink-3);
}
.hafdz-dua-card__author { font-weight: 500; color: var(--hd-ink-2); }
.hafdz-dua-card__sep { color: var(--hd-ink-4); }
.hafdz-dua-card__avatar {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: #fff;
	flex-shrink: 0;
	font-family: var(--hd-font-sans);
	line-height: 1;
	user-select: none;
}

/* ===== Aamiin button ===== */
.hafdz-dua-support-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 12px;
	border-radius: 999px;
	border: 1px solid var(--hd-border);
	background: var(--hd-surface);
	color: var(--hd-ink-2);
	font-family: inherit;
	font-size: 12px;
	font-weight: 500;
	cursor: pointer;
	transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}
.hafdz-dua-support-btn:hover {
	background: var(--hd-surface-2);
	color: var(--hd-ink);
}
.hafdz-dua-support-btn[aria-pressed="true"] {
	background: var(--hd-accent-soft);
	border-color: var(--hd-accent);
	color: var(--hd-accent-ink);
}
.hafdz-dua-support-btn[aria-pressed="true"] .hafdz-dua-support-btn__icon { color: var(--hd-accent); }
.hafdz-dua-support-btn[disabled] { opacity: 0.5; cursor: not-allowed; }
.hafdz-dua-support-btn__icon {
	display: inline-flex;
	align-items: center;
	color: var(--hd-ink-3);
	line-height: 0;
}
.hafdz-dua-support-btn__count {
	font-variant-numeric: tabular-nums;
	font-weight: 600;
}

/* ===== Pagination ===== */
.hafdz-dua-pagination {
	display: flex;
	gap: 8px;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	border-top: 1px solid var(--hd-border);
	background: var(--hd-surface-2);
}
.hafdz-dua-pagination:empty { display: none; }
.hafdz-dua-pagination__btn {
	padding: 6px 10px;
	border-radius: var(--hd-radius-sm);
	border: 1px solid var(--hd-border-strong);
	background: var(--hd-surface);
	color: var(--hd-ink-2);
	font: inherit;
	cursor: pointer;
}
.hafdz-dua-pagination__btn:hover:not([disabled]) { background: var(--hd-surface-2); }
.hafdz-dua-pagination__btn[disabled] { opacity: 0.4; cursor: not-allowed; }
.hafdz-dua-pagination__info {
	font-size: 12px;
	color: var(--hd-ink-3);
	font-variant-numeric: tabular-nums;
}

/* ===== Empty / loading ===== */
.hafdz-dua-empty {
	margin: 0;
	padding: 48px 24px;
	color: var(--hd-ink-3);
	font-size: 14px;
	text-align: center;
}

/* ===== Modal dialog ===== */
.hafdz-dua-dialog {
	width: min(560px, calc(100vw - 32px));
	max-width: none;
	padding: 0;
	border: 1px solid var(--hd-border);
	border-radius: var(--hd-radius-lg);
	background: var(--hd-surface);
	box-shadow: var(--hd-shadow-lg);
	color: var(--hd-ink);
}
.hafdz-dua-dialog::backdrop {
	background: rgba(20, 20, 15, 0.45);
	backdrop-filter: blur(2px);
}
.hafdz-dua-dialog__inner { padding: 0; }
.hafdz-dua-dialog__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 18px 24px;
	border-bottom: 1px solid var(--hd-border);
}
.hafdz-dua-dialog__title {
	margin: 0;
	font-size: 16px;
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--hd-ink);
}
.hafdz-dua-dialog__close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: var(--hd-radius-sm);
	border: 0;
	background: transparent;
	color: var(--hd-ink-3);
	cursor: pointer;
	line-height: 0;
}
.hafdz-dua-dialog__close:hover {
	background: var(--hd-surface-2);
	color: var(--hd-ink);
}

/* ===== Submit success state ===== */
.hafdz-dua-success {
	padding: 22px 24px 18px;
}
.hafdz-dua-success__message {
	margin: 0 0 18px;
	padding: 12px 14px;
	background: var(--hd-accent-soft);
	border: 1px solid var(--hd-accent);
	border-radius: var(--hd-radius-sm);
	color: var(--hd-accent-ink);
	font-size: 13px;
	line-height: 1.5;
}
.hafdz-dua-success__feed {
	margin-bottom: 16px;
}
.hafdz-dua-success__cta-label {
	margin: 0 0 10px;
	font-family: var(--hd-font-mono);
	font-size: 11px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--hd-ink-3);
}
.hafdz-dua-success__items {
	display: flex;
	flex-direction: column;
	gap: 0;
	border: 1px solid var(--hd-border);
	border-radius: var(--hd-radius-md);
	background: var(--hd-surface);
	overflow: hidden;
}
.hafdz-dua-success__items .hafdz-dua-card { padding: 14px 16px; }
.hafdz-dua-success__items .hafdz-dua-card__body { font-size: 14px; line-height: 1.5; }
.hafdz-dua-success__items .hafdz-dua-empty { padding: 28px 16px; }
.hafdz-dua-success__actions {
	display: flex;
	justify-content: flex-end;
}

/* ===== Alert variant ===== */
.hafdz-dua-dialog--alert {
	width: min(420px, calc(100vw - 32px));
}
.hafdz-dua-dialog--alert .hafdz-dua-dialog__title { color: var(--hd-danger); }
.hafdz-dua-alert__body {
	padding: 18px 24px 6px;
	color: var(--hd-ink-2);
	font-size: 14px;
	line-height: 1.5;
}
.hafdz-dua-alert__actions {
	display: flex;
	justify-content: flex-end;
	gap: 8px;
	padding: 14px 24px 18px;
}

/* ===== Form ===== */
.hafdz-dua-form {
	padding: 20px 24px 22px;
	font-family: var(--hd-font-sans);
	color: var(--hd-ink);
}
.hafdz-dua-dialog .hafdz-dua-form { /* tighter padding inside the dialog */
	padding: 20px 24px 22px;
}
.hafdz-dua-form.hafdz-dua-empty {
	border: 1px solid var(--hd-border);
	border-radius: var(--hd-radius-md);
	background: var(--hd-surface);
}
.hafdz-dua-form__field {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin-bottom: 14px;
}
.hafdz-dua-form__field label {
	font-size: 12px;
	font-weight: 500;
	color: var(--hd-ink-2);
	letter-spacing: 0.01em;
}
.hafdz-dua-form__field textarea {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid var(--hd-border-strong);
	border-radius: var(--hd-radius-sm);
	background: var(--hd-surface);
	font-family: inherit;
	font-size: 14px;
	color: var(--hd-ink);
	resize: vertical;
	min-height: 110px;
	transition: border-color 120ms ease, box-shadow 120ms ease;
}
.hafdz-dua-form__field textarea:focus {
	outline: none;
	border-color: var(--hd-accent);
	box-shadow: 0 0 0 3px var(--hd-accent-soft);
}
.hafdz-dua-form__field textarea::placeholder { color: var(--hd-ink-4); }
.hafdz-dua-form__hint {
	margin: 0;
	font-size: 11px;
	color: var(--hd-ink-3);
}
.hafdz-dua-form__actions {
	display: flex;
	gap: 8px;
	align-items: center;
	justify-content: flex-end;
	margin-top: 8px;
}
.hafdz-dua-form__error {
	margin: 8px 0 0;
	min-height: 1.2em;
	font-size: 12px;
	color: var(--hd-danger);
}
.hafdz-dua-form__notice {
	margin: 4px 0 0;
	min-height: 1.2em;
	font-size: 12px;
	color: var(--hd-success);
}
.hafdz-dua-form__submit[disabled] { opacity: 0.6; cursor: not-allowed; }

/* ===== Responsive ===== */
@media (max-width: 540px) {
	.hafdz-dua-wall__header {
		flex-direction: column;
		align-items: flex-start;
		gap: 16px;
	}
	.hafdz-dua-wall__cta { width: 100%; }
	.hafdz-dua-wall__cta .hafdz-dua-btn { width: 100%; }
	.hafdz-dua-card { padding: 16px; }
	.hafdz-dua-toolbar { padding: 12px 16px; }
	.hafdz-dua-form__actions { flex-direction: column-reverse; align-items: stretch; }
	.hafdz-dua-form__actions .hafdz-dua-btn { width: 100%; }
}
