/* === Email Health Chk Dashboard Widget — Light brand =================
 *
 * Matches the visual language of Breach Chk / EML Analyzer / Toolkit Chk.
 *
 * Architecture:
 *   - Light theme: white surface, dark ink, cyan accent.
 *   - BEM-style class names under .email-health-chk__*.
 *   - Heavy `!important` to defeat Elementor's .elementor-kit-N globals
 *     (button gradients, input border-radius, h2/h3 typography).
 *   - CSS custom properties prefixed --ehc-* so the Customize Widget admin
 *     page (Phase 7.2) can still inject colour overrides via inline <style>.
 *
 * Breakpoint: 820px collapses the 5-card grid to a single column.
 */

/* Fix: HTML [hidden] attribute must beat our display: flex / grid rules. */
.email-health-chk [hidden],
.email-health-chk[hidden] { display: none !important; }

.email-health-chk {
	--ehc-primary:        #126E00;
	--ehc-primary-hover:  #0a5a00;
	--ehc-bg:             #ffffff;
	--ehc-surface:        #ffffff;
	--ehc-card:           #ffffff;
	--ehc-text:           #1a1a2e;
	--ehc-muted:          #5a6478;
	--ehc-line:           rgba(0, 0, 0, 0.08);
	--ehc-line-strong:    #d0d5dd;
	--ehc-btn-text:       #ffffff;
	--ehc-sev-critical:   #dc2626;
	--ehc-sev-high:       #ef4444;
	--ehc-sev-medium:     #f59e0b;
	--ehc-sev-low:        #3b82f6;
	--ehc-sev-pass:       #4AAE34;
	--ehc-radius:         12px;
	--ehc-radius-sm:      6px;
	--ehc-pad:            24px;
	--ehc-gap:            16px;

	max-width: 980px;
	margin: 0 auto;
	padding: 28px 24px;
	border-radius: var(--ehc-radius) !important;
	background: var(--ehc-bg) !important;
	color: var(--ehc-text) !important;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
	font-size: 15px;
	line-height: 1.5;
	box-sizing: border-box;
}

.email-health-chk *,
.email-health-chk *::before,
.email-health-chk *::after {
	box-sizing: border-box;
}

.email-health-chk__visually-hidden {
	position: absolute !important;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* ----------------------------------------------------------------------
 * Brand header (optional Customize Widget HTML)
 * -------------------------------------------------------------------- */

.email-health-chk__brand-header {
	margin: 0 0 var(--ehc-gap);
	padding: 0 0 var(--ehc-gap);
	border-bottom: 1px solid var(--ehc-line);
	text-align: center;
}

.email-health-chk__brand-header img {
	max-height: 48px;
	width: auto;
}

/* ----------------------------------------------------------------------
 * Form (input + button + turnstile)
 * -------------------------------------------------------------------- */

.email-health-chk__title {
	margin: 0 0 6px !important;
	font-size: 1.25rem !important;
	font-weight: 700 !important;
	color: var(--ehc-text) !important;
	text-align: center;
	line-height: normal !important;
	letter-spacing: normal !important;
	text-transform: none !important;
	word-spacing: normal !important;
}

.email-health-chk__subtitle {
	margin: 0 0 18px !important;
	text-align: center;
	font-size: 0.92rem !important;
	color: var(--ehc-muted) !important;
	line-height: 1.45 !important;
}

.email-health-chk__form {
	display: flex;
	gap: 10px;
	margin-bottom: 4px;
	flex-wrap: wrap;
}

.email-health-chk__input {
	flex: 1;
	min-width: 0;
	padding: 12px 14px !important;
	font-size: 0.95rem !important;
	border: 1.5px solid var(--ehc-line-strong) !important;
	border-radius: 6px !important;
	outline: none;
	transition: border-color 0.2s;
	background: rgba(0, 0, 0, 0.03) !important;
	color: var(--ehc-text) !important;
	font-family: inherit !important;
	letter-spacing: normal !important;
	text-transform: none !important;
	line-height: normal !important;
}

.email-health-chk__input:focus {
	border-color: var(--ehc-primary) !important;
	background: var(--ehc-bg) !important;
}

.email-health-chk__input::placeholder {
	color: #999;
}

.email-health-chk__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px 22px !important;
	font-size: 0.95rem !important;
	font-weight: 600 !important;
	color: var(--ehc-btn-text) !important;
	background: var(--ehc-primary) !important;
	background-image: none !important;
	border: none !important;
	border-radius: 6px !important;
	cursor: pointer;
	transition: opacity 0.2s, transform 0.1s;
	white-space: nowrap;
	font-family: inherit !important;
	letter-spacing: normal !important;
	text-transform: none !important;
	text-decoration: none !important;
	font-style: normal !important;
}

.email-health-chk__btn:hover,
.email-health-chk__btn:focus {
	opacity: 0.88;
	background: var(--ehc-primary) !important;
	background-image: none !important;
	color: var(--ehc-btn-text) !important;
}

.email-health-chk__btn:active {
	transform: scale(0.97);
}

.email-health-chk__btn[disabled],
.email-health-chk__btn:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

.email-health-chk__btn-spinner {
	width: 14px;
	height: 14px;
	border: 2px solid rgba(255, 255, 255, 0.35);
	border-top-color: #fff;
	border-radius: 50%;
	animation: ehc-spin 0.8s linear infinite;
	display: none;
}

.email-health-chk__btn.is-loading .email-health-chk__btn-spinner {
	display: inline-block;
}

@keyframes ehc-spin {
	to { transform: rotate(360deg); }
}

/* Turnstile widget — collapses when invisible, expands when CF needs interaction */
.email-health-chk__turnstile {
	flex-basis: 100%;
	display: flex;
	justify-content: center;
	margin-top: 0;
	transition: margin-top 0.2s;
}

.email-health-chk__turnstile:has(iframe) {
	margin-top: 8px;
}

.email-health-chk__turnstile .cf-turnstile { max-width: 100%; }
.email-health-chk__turnstile .cf-turnstile iframe { max-width: 100% !important; }

/* === Terms & Conditions — iOS-style toggle + collapsible body ============
 * Mirrors the .breach-checker__terms-* pattern from Breach Chk v2.4.0.
 * Class names use __terms-* (NOT __tc-*) to avoid colliding with anything
 * upstream that grepped for `tc-`.
 * ======================================================================== */

.email-health-chk__terms {
	flex-basis: 100%;
	background: color-mix(in srgb, var(--ehc-primary, #126E00) 5%, #fff) !important;
	border: 1px solid color-mix(in srgb, var(--ehc-primary, #126E00) 20%, #e2e8f0) !important;
	border-radius: var(--ehc-radius-sm, 8px) !important;
	padding: 14px 16px !important;
	margin-top: 12px !important;
}

.email-health-chk__terms-switch {
	display: flex !important;
	align-items: center !important;
	gap: 10px !important;
	cursor: pointer !important;
	user-select: none !important;
	margin: 0 !important;
}

.email-health-chk__terms-check {
	opacity: 0 !important;
	width: 0 !important;
	height: 0 !important;
	position: absolute !important;
}

.email-health-chk__terms-slider {
	position: relative !important;
	width: 44px !important;
	height: 24px !important;
	background: #cbd5e1 !important;
	border-radius: 12px !important;
	transition: background 0.2s !important;
	flex-shrink: 0 !important;
}

.email-health-chk__terms-slider::after {
	content: '' !important;
	position: absolute !important;
	top: 3px !important;
	left: 3px !important;
	width: 18px !important;
	height: 18px !important;
	background: #fff !important;
	border-radius: 50% !important;
	transition: transform 0.2s !important;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15) !important;
}

.email-health-chk__terms-check:checked + .email-health-chk__terms-slider {
	background: var(--ehc-primary, #126E00) !important;
}

.email-health-chk__terms-check:checked + .email-health-chk__terms-slider::after {
	transform: translateX(20px) !important;
}

.email-health-chk__terms-check:focus-visible + .email-health-chk__terms-slider {
	outline: 2px solid var(--ehc-primary, #126E00) !important;
	outline-offset: 2px !important;
}

.email-health-chk__terms-label {
	font-size: 0.9rem !important;
	font-weight: 600 !important;
	color: var(--ehc-text, #1a1a2e) !important;
}

.email-health-chk__terms-required {
	color: var(--ehc-primary, #126E00) !important;
	font-weight: 700 !important;
	margin-left: 2px !important;
}

.email-health-chk__terms-toggle {
	all: unset !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 6px !important;
	margin-top: 8px !important;
	background: none !important;
	border: none !important;
	color: var(--ehc-primary, #126E00) !important;
	font-size: 0.85rem !important;
	cursor: pointer !important;
	text-decoration: underline !important;
	padding: 0 !important;
	font-family: inherit !important;
}

.email-health-chk__terms-toggle:hover {
	opacity: 0.85 !important;
}

.email-health-chk__terms-text {
	background: #fff !important;
	border: 1px solid #e2e8f0 !important;
	border-radius: 8px !important;
	padding: 14px 16px !important;
	margin-top: 10px !important;
	font-size: 0.82rem !important;
	line-height: 1.6 !important;
	color: #475569 !important;
	max-height: 280px !important;
	overflow-y: auto !important;
	white-space: pre-wrap !important;
}

.email-health-chk__terms-text a {
	color: var(--ehc-primary, #126E00) !important;
}

/* Error message */
.email-health-chk__form-error {
	flex-basis: 100%;
	margin-top: 12px;
	padding: 12px 14px;
	background: #fff0f0;
	color: #c0392b;
	border: 1px solid #f5c6cb;
	border-radius: 6px;
	font-size: 0.9rem;
	text-align: center;
}

/* ----------------------------------------------------------------------
 * Loading
 * -------------------------------------------------------------------- */

.email-health-chk__loading {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	padding: 32px var(--ehc-pad);
	color: var(--ehc-muted);
}

.email-health-chk__loading-spinner {
	width: 32px;
	height: 32px;
	border: 3px solid #e0e0e0;
	border-top-color: var(--ehc-primary);
	border-radius: 50%;
	animation: ehc-spin 0.8s linear infinite;
}

.email-health-chk__loading-text {
	margin: 0;
	font-size: 0.9rem;
	color: var(--ehc-muted);
}

/* ----------------------------------------------------------------------
 * Results panel
 * -------------------------------------------------------------------- */

.email-health-chk__results {
	margin-top: 24px;
}

.email-health-chk__results-header {
	margin: 0 0 var(--ehc-gap);
	text-align: center;
}

.email-health-chk__results-title {
	margin: 0 !important;
	font-size: 1.1rem !important;
	font-weight: 700 !important;
	color: var(--ehc-text) !important;
	line-height: normal !important;
}

.email-health-chk__results-domain {
	color: var(--ehc-primary);
	font-family: ui-monospace, Menlo, Consolas, monospace;
}

.email-health-chk__results-meta {
	margin: 4px 0 0;
	font-size: 12px;
	color: var(--ehc-muted);
}

/* ----------------------------------------------------------------------
 * 5-card category grid (light cards with cyan top-edge accent)
 * -------------------------------------------------------------------- */

.email-health-chk__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: var(--ehc-gap);
}

/* Customize Widget — Category Layout = "list". One stacked column with the
   title + counts arranged horizontally on each row. */
.email-health-chk[data-category-layout="list"] .email-health-chk__grid {
	grid-template-columns: 1fr;
}
.email-health-chk[data-category-layout="list"] .email-health-chk__card {
	flex-direction: row;
	align-items: center;
	gap: 16px;
	padding: 14px 18px;
}
.email-health-chk[data-category-layout="list"] .email-health-chk__card-title {
	flex: 0 0 180px;
}
.email-health-chk[data-category-layout="list"] .email-health-chk__card-counts {
	flex: 0 0 auto;
}
.email-health-chk[data-category-layout="list"] .email-health-chk__card-summary {
	flex: 1;
	margin-left: auto;
	text-align: right;
}

.email-health-chk__card {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 16px;
	background: var(--ehc-card) !important;
	background-image: none !important;
	border: 1px solid var(--ehc-line) !important;
	border-radius: var(--ehc-radius) !important;
	cursor: pointer;
	transition: box-shadow 0.2s, transform 0.1s, border-color 0.15s;
	color: var(--ehc-text) !important;
	text-align: left;
	font: inherit;
	font-family: inherit !important;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

/* cyan top-edge accent — drawn with ::before so it doesn't fight the
   button's existing border-radius or Elementor overrides */
.email-health-chk__card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: var(--ehc-primary);
	border-top-left-radius: var(--ehc-radius);
	border-top-right-radius: var(--ehc-radius);
	opacity: 0.85;
}

.email-health-chk__card:hover,
.email-health-chk__card:focus-visible {
	border-color: var(--ehc-primary) !important;
	box-shadow: 0 4px 12px rgba(18, 110, 0, 0.12);
	outline: none;
	transform: translateY(-1px);
}

.email-health-chk__card.is-active {
	border-color: var(--ehc-primary) !important;
	box-shadow: 0 0 0 2px var(--ehc-primary) inset, 0 4px 12px rgba(18, 110, 0, 0.18);
}

.email-health-chk__card-title {
	margin: 0 !important;
	font-size: 0.78rem !important;
	font-weight: 700 !important;
	color: var(--ehc-muted) !important;
	text-transform: uppercase !important;
	letter-spacing: 0.06em !important;
	line-height: normal !important;
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.email-health-chk__card-icon-wrap {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	color: var(--ehc-primary);
	flex-shrink: 0;
}

.email-health-chk__card-icon {
	width: 100%;
	height: 100%;
	fill: currentColor;
	display: block;
}

/* Toggle: hide category icons when the admin disables them. */
.email-health-chk[data-category-icons="0"] .email-health-chk__card-icon-wrap {
	display: none !important;
}

.email-health-chk__card-counts {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: baseline;
}

.email-health-chk__count {
	display: inline-flex;
	align-items: baseline;
	gap: 4px;
	font-size: 14px;
	font-weight: 500;
}

.email-health-chk__count--bad  { color: var(--ehc-sev-critical); }
.email-health-chk__count--warn { color: var(--ehc-sev-medium); }
.email-health-chk__count--ok   { color: var(--ehc-sev-pass); }

.email-health-chk__count-num {
	font-size: 20px;
	font-weight: 700;
}

.email-health-chk__card-summary {
	margin: 0;
	font-size: 12px;
	color: var(--ehc-muted);
	line-height: 1.4;
}

/* ----------------------------------------------------------------------
 * Detail panel (inline under the active card)
 * -------------------------------------------------------------------- */

.email-health-chk__detail {
	margin-top: var(--ehc-gap);
	padding: var(--ehc-pad);
	background: rgba(18, 110, 0, 0.03);
	border: 1px solid var(--ehc-line);
	border-left: 3px solid var(--ehc-primary);
	border-radius: var(--ehc-radius-sm);
}

.email-health-chk__detail-title {
	margin: 0 0 12px !important;
	font-size: 1rem !important;
	font-weight: 700 !important;
	color: var(--ehc-text) !important;
	line-height: normal !important;
}

.email-health-chk__detail-empty {
	margin: 0;
	color: var(--ehc-muted);
	font-size: 0.9rem;
}

.email-health-chk__findings {
	margin: 0;
	padding: 0;
	list-style: none;
}

.email-health-chk__finding {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 10px 14px;
	padding: 12px 0;
	border-top: 1px solid var(--ehc-line);
}

.email-health-chk__finding:first-child {
	border-top: 0;
	padding-top: 0;
}

.email-health-chk__finding-sev {
	font-size: 18px;
	line-height: 1.2;
}

.email-health-chk__finding-body { min-width: 0; }

.email-health-chk__finding-label {
	margin: 0;
	font-weight: 600;
	color: var(--ehc-text);
	font-size: 0.95rem;
}

.email-health-chk__finding-evidence {
	margin: 4px 0 0;
	font-size: 0.82rem;
	color: var(--ehc-muted);
	word-break: break-word;
	line-height: 1.5;
}

.email-health-chk__sev--critical { color: var(--ehc-sev-critical); }
.email-health-chk__sev--high     { color: var(--ehc-sev-high); }
.email-health-chk__sev--medium   { color: var(--ehc-sev-medium); }
.email-health-chk__sev--low      { color: var(--ehc-sev-low); }
.email-health-chk__sev--ok       { color: var(--ehc-sev-pass); }
.email-health-chk__sev--pass     { color: var(--ehc-sev-pass); }

/* Detail panel subheads — "Issues to address" / "Checks passed" */
.email-health-chk__detail-subhead {
	margin: 16px 0 8px;
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.6px;
	color: var(--ehc-muted);
}

.email-health-chk__detail-subhead--bad {
	color: var(--ehc-sev-critical);
}

.email-health-chk__detail-subhead--ok {
	color: var(--ehc-sev-pass);
}

.email-health-chk__detail-subhead:first-of-type {
	margin-top: 0;
}

/* Pass list — slightly muted vs findings to keep the visual hierarchy:
   problems shout, passes whisper. */
.email-health-chk__findings--ok .email-health-chk__finding {
	border-top-color: rgba(16, 185, 129, 0.15);
}

.email-health-chk__finding--pass .email-health-chk__finding-label {
	color: var(--ehc-text);
	font-weight: 500;
}

.email-health-chk__finding--pass .email-health-chk__finding-evidence {
	color: var(--ehc-muted);
}

/* ----------------------------------------------------------------------
 * Usage wall (Phase 8.4) — email capture after daily quota hit
 * -------------------------------------------------------------------- */

.email-health-chk__wall {
	padding: 20px;
	background: #fffaf2;
	border: 1px solid #ffd8a8;
	border-radius: var(--ehc-radius);
}

.email-health-chk__wall-heading {
	margin: 0 0 8px !important;
	font-size: 1.1rem !important;
	font-weight: 700 !important;
	color: var(--ehc-text) !important;
}

.email-health-chk__wall-text {
	margin: 0 0 16px;
	color: var(--ehc-muted);
	font-size: 0.9rem;
}

.email-health-chk__wall-form {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
}

.email-health-chk__wall-email,
.email-health-chk__wall-code {
	flex: 1 1 240px;
	min-width: 0;
	padding: 12px 14px !important;
	border-radius: 6px !important;
	border: 1.5px solid var(--ehc-line-strong) !important;
	background: rgba(0, 0, 0, 0.03) !important;
	color: var(--ehc-text) !important;
	font-size: 0.95rem !important;
	font-family: inherit !important;
}

.email-health-chk__wall-msg {
	width: 100%;
	font-size: 0.82rem;
	min-height: 18px;
}

.email-health-chk__wall-otp-row {
	display: flex;
	gap: 10px;
	width: 100%;
	margin-top: 8px;
	flex-wrap: wrap;
}

/* ----------------------------------------------------------------------
 * Placeholder
 * -------------------------------------------------------------------- */

.email-health-chk__placeholder {
	padding: var(--ehc-pad);
	background: rgba(0, 0, 0, 0.02);
	border: 1px dashed var(--ehc-line-strong);
	border-radius: var(--ehc-radius-sm);
	color: var(--ehc-muted);
	text-align: center;
}

/* ----------------------------------------------------------------------
 * Responsive
 * -------------------------------------------------------------------- */

@media (max-width: 820px) {
	.email-health-chk {
		padding: 20px 16px;
	}
	.email-health-chk__grid {
		grid-template-columns: 1fr;
	}
	.email-health-chk__form {
		flex-direction: column;
	}
	.email-health-chk__btn {
		width: 100%;
	}
}

/* =========================================================================
   INLINE AI BRIEFING SECTION (Phase 9 — EML Analyzer-style)
   Lives below the results grid + detail panel. Light-theme card containing
   the email gate → OTP → inline dark briefing render.
   ========================================================================= */

.email-health-chk__post-results {
	margin-top: 24px;
}

.email-health-chk__ai-section {
	background: linear-gradient(135deg, #f0fdf4 0%, #ffffff 60%) !important;
	border: 1px solid var(--ehc-primary, #126E00) !important;
	border-radius: var(--ehc-radius) !important;
	padding: 28px 26px !important;
	box-shadow: 0 4px 16px rgba(18, 110, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.04) !important;
	position: relative;
}

/* Eyebrow tag at top of the gate — "Free personalized fix plan". */
.email-health-chk__ai-eyebrow {
	display: inline-block;
	margin: 0 0 12px;
	padding: 4px 12px;
	background: var(--ehc-primary, #126E00);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	border-radius: 20px;
}

.email-health-chk__ai-heading {
	margin: 0 0 10px !important;
	font-size: 22px !important;
	font-weight: 800 !important;
	color: var(--ehc-text) !important;
	line-height: 1.25 !important;
	letter-spacing: -0.01em !important;
}

.email-health-chk__ai-desc {
	margin: 0 0 16px !important;
	color: var(--ehc-muted) !important;
	font-size: 14.5px !important;
	line-height: 1.55 !important;
}

/* Benefit bullets — concrete deliverables. */
.email-health-chk__ai-bullets {
	margin: 0 0 22px !important;
	padding: 0 !important;
	list-style: none !important;
	display: grid;
	grid-template-columns: 1fr;
	gap: 6px;
}
@media (min-width: 560px) {
	.email-health-chk__ai-bullets {
		grid-template-columns: 1fr 1fr;
		gap: 6px 18px;
	}
}
.email-health-chk__ai-bullets li {
	position: relative;
	padding-left: 24px !important;
	font-size: 13.5px !important;
	color: var(--ehc-text) !important;
	line-height: 1.45 !important;
	list-style: none !important;
}
.email-health-chk__ai-bullets li::before {
	content: "✓";
	position: absolute;
	left: 2px;
	top: 0;
	color: var(--ehc-primary, #126E00);
	font-weight: 800;
	font-size: 14px;
}

/* Trust microcopy under the CTA button. */
.email-health-chk__ai-trust {
	margin-top: 12px;
	font-size: 12.5px;
	color: var(--ehc-muted);
	line-height: 1.55;
}

.email-health-chk__ai-form {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.email-health-chk__ai-email,
.email-health-chk__ai-code {
	width: 100% !important;
	padding: 12px 14px !important;
	border: 1px solid var(--ehc-line-strong) !important;
	border-radius: var(--ehc-radius-sm) !important;
	font-size: 15px !important;
	font-family: inherit !important;
	color: var(--ehc-text) !important;
	background: #ffffff !important;
	box-sizing: border-box !important;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.email-health-chk__ai-email:focus,
.email-health-chk__ai-code:focus {
	outline: none !important;
	border-color: var(--ehc-primary) !important;
	box-shadow: 0 0 0 3px rgba(18, 110, 0, 0.18) !important;
}

.email-health-chk__ai-code {
	letter-spacing: 0.25em;
	font-variant-numeric: tabular-nums;
	text-align: center;
}

.email-health-chk__ai-turnstile {
	display: flex;
	justify-content: center;
	min-height: 0;
}
.email-health-chk__ai-turnstile:empty { display: none; }

.email-health-chk__ai-btn {
	align-self: stretch;
	padding: 14px 28px !important;
	font-size: 16px !important;
	font-weight: 700 !important;
	letter-spacing: 0.01em !important;
	box-shadow: 0 4px 12px rgba(18, 110, 0, 0.25) !important;
	transition: transform 0.12s ease, box-shadow 0.12s ease, background 0.12s ease !important;
}
.email-health-chk__ai-btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 6px 16px rgba(18, 110, 0, 0.35) !important;
}
@media (min-width: 560px) {
	.email-health-chk__ai-btn {
		align-self: flex-start;
		min-width: 220px;
	}
}

.email-health-chk__ai-btnrow {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px 18px;
}

.email-health-chk__ai-link {
	background: transparent !important;
	border: 0 !important;
	padding: 6px 4px !important;
	color: var(--ehc-primary) !important;
	font-size: 14px !important;
	font-weight: 500 !important;
	cursor: pointer;
	text-decoration: none;
}
.email-health-chk__ai-link:hover {
	color: var(--ehc-primary-hover) !important;
	text-decoration: underline;
}
.email-health-chk__ai-link[disabled] {
	opacity: 0.6;
	cursor: not-allowed;
}

.email-health-chk__ai-msg {
	margin: 4px 0 0 !important;
	padding: 10px 12px !important;
	border-radius: var(--ehc-radius-sm) !important;
	font-size: 14px !important;
	background: rgba(220, 38, 38, 0.08) !important;
	color: #b91c1c !important;
	border: 1px solid rgba(220, 38, 38, 0.20) !important;
}
.email-health-chk__ai-msg[data-kind="ok"] {
	background: rgba(16, 185, 129, 0.10) !important;
	color: #047857 !important;
	border-color: rgba(16, 185, 129, 0.25) !important;
}
.email-health-chk__ai-msg[data-kind="info"] {
	background: rgba(59, 130, 246, 0.08) !important;
	color: #1e40af !important;
	border-color: rgba(59, 130, 246, 0.22) !important;
}

/* Spinner inline en botones AI — sale a la izquierda del label. */
.email-health-chk__ai-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 10px !important;
}
.email-health-chk__btn-spinner {
	width: 14px;
	height: 14px;
	border: 2px solid rgba(255, 255, 255, 0.35);
	border-top-color: #fff;
	border-radius: 50%;
	animation: ehc-spin 0.8s linear infinite;
	display: none;
}
.email-health-chk__ai-btn.is-loading .email-health-chk__btn-spinner {
	display: inline-block;
}

/* Inline dark report — drop the light card chrome so the dark briefing
   doesn't sit awkwardly inside the light AI-section card. */
.email-health-chk__ai-section:has(.email-health-chk__ai-report) {
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
	padding: 0 !important;
}

.email-health-chk__ai-report {
	margin: 8px 0 0;
	border-radius: var(--ehc-radius);
	overflow: hidden;
}

.email-health-chk__ai-footer {
	margin-top: 16px;
	padding: 14px 16px;
	background: #f8fafc;
	border: 1px solid var(--ehc-line);
	border-radius: var(--ehc-radius-sm);
}
.email-health-chk__ai-pdf-status {
	margin: 0 !important;
	color: var(--ehc-muted) !important;
	font-size: 13.5px !important;
	line-height: 1.55 !important;
}

/* Success banner — prominent, brand-green, shown at top of the AI section
   after a successful /briefing/verify. Communicates "we did it, check your
   inbox" in one glance. */
.email-health-chk__ai-success-banner {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	padding: 18px 20px;
	margin: 0 0 22px;
	background: linear-gradient(135deg, #ecfdf5 0%, #f0fdf4 100%);
	border: 1px solid var(--ehc-primary, #126E00);
	border-left-width: 4px;
	border-radius: var(--ehc-radius);
	box-shadow: 0 2px 8px rgba(18, 110, 0, 0.10);
}
.email-health-chk__ai-success-icon {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	background: var(--ehc-primary, #126E00);
	color: #fff;
	border-radius: 50%;
	font-size: 18px;
	font-weight: 800;
	line-height: 1;
}
.email-health-chk__ai-success-body {
	flex: 1;
	min-width: 0;
}
.email-health-chk__ai-success-title {
	font-size: 16px;
	font-weight: 700;
	color: #064e3b;
	margin: 0 0 4px;
	line-height: 1.3;
}
.email-health-chk__ai-success-text {
	font-size: 13.5px;
	line-height: 1.55;
	color: #065f46;
}
.email-health-chk__ai-success-text strong {
	color: var(--ehc-text);
	font-weight: 600;
}

/* Section label between success banner and briefing iframe. */
.email-health-chk__ai-section-label {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--ehc-muted);
	margin: 0 0 10px;
	padding-top: 4px;
}

/* =========================================================================
   Threat score strip + EML-Analyzer-style sectioned layout (replaces the
   old 5-card-with-click-to-expand grid). One section card per check group.
   ========================================================================= */

.email-health-chk__score {
	margin: 0 0 var(--ehc-gap);
}

.ehc-score {
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 18px 20px;
	background: #ffffff;
	border: 1px solid var(--ehc-line);
	border-left: 4px solid var(--ehc-primary);
	border-radius: var(--ehc-radius);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.ehc-score__num {
	font-size: 44px;
	font-weight: 800;
	line-height: 1;
	min-width: 70px;
	text-align: center;
	font-variant-numeric: tabular-nums;
}

.ehc-score__right { flex: 1; min-width: 0; }

.ehc-score__track {
	height: 12px;
	background: #f1f5f9;
	border-radius: 6px;
	overflow: hidden;
}

.ehc-score__fill {
	height: 100%;
	border-radius: 6px;
	transition: width 0.5s ease-out;
}

.ehc-score__label {
	margin-top: 6px;
	font-size: 13px;
	font-weight: 600;
}

.email-health-chk__sections {
	display: flex;
	flex-direction: column;
	gap: var(--ehc-gap);
}

.ehc-section {
	background: #ffffff;
	border: 1px solid var(--ehc-line);
	border-radius: var(--ehc-radius);
	padding: 18px 20px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.ehc-section__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin: 0 0 4px;
	padding: 0 0 10px;
	border-bottom: 2px solid var(--ehc-primary);
}

.ehc-section__title {
	margin: 0 !important;
	font-size: 14px !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.06em !important;
	color: var(--ehc-text) !important;
	line-height: 1.3 !important;
}

.ehc-status-badge {
	display: inline-block;
	padding: 4px 12px;
	border-radius: 20px;
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.06em;
}

.ehc-status-badge--pass {
	background: #dcfce7;
	color: #166534;
	border: 1px solid #86efac;
}
.ehc-status-badge--warn {
	background: #fef3c7;
	color: #92400e;
	border: 1px solid #fde68a;
}
.ehc-status-badge--fail {
	background: #fee2e2;
	color: #991b1b;
	border: 1px solid #fca5a5;
}
.ehc-status-badge--info {
	background: #dbeafe;
	color: #1e40af;
	border: 1px solid #93c5fd;
}

/* "Advanced" pill rendered next to a low-severity finding label. */
.ehc-find__advanced {
	display: inline-block;
	margin-left: 8px;
	padding: 1px 8px;
	border-radius: 10px;
	background: #dbeafe;
	color: #1e40af;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	vertical-align: middle;
}

.ehc-section__summary {
	margin: 10px 0 0;
	font-size: 12.5px;
	color: var(--ehc-muted);
}

.ehc-section__subhead {
	margin: 14px 0 8px;
	font-size: 11.5px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--ehc-muted);
}

.ehc-section__subhead--bad { color: var(--ehc-sev-critical); }
.ehc-section__subhead--ok  { color: var(--ehc-sev-pass); }

.ehc-find-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.ehc-find {
	display: grid;
	grid-template-columns: 22px 1fr;
	gap: 10px;
	padding: 10px 12px;
	background: #f8fafc;
	border: 1px solid var(--ehc-line);
	border-radius: var(--ehc-radius-sm);
}

.ehc-find--critical,
.ehc-find--high {
	border-left: 3px solid var(--ehc-sev-critical);
}
.ehc-find--medium {
	border-left: 3px solid var(--ehc-sev-medium);
}
.ehc-find--low {
	border-left: 3px solid var(--ehc-sev-low);
}
.ehc-find--pass {
	border-left: 3px solid var(--ehc-sev-pass);
	background: #f0fdf4;
}

.ehc-find__sev {
	width: 22px;
	height: 22px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	font-size: 12px;
	font-weight: 800;
	color: #ffffff;
	line-height: 1;
}

.ehc-find--critical .ehc-find__sev,
.ehc-find--high .ehc-find__sev { background: var(--ehc-sev-critical); }
.ehc-find--medium .ehc-find__sev { background: var(--ehc-sev-medium); }
.ehc-find--low .ehc-find__sev { background: var(--ehc-sev-low); }
.ehc-find--pass .ehc-find__sev { background: var(--ehc-sev-pass); }

.ehc-find__body { min-width: 0; }

.ehc-find__label {
	margin: 0;
	font-size: 13.5px;
	font-weight: 600;
	color: var(--ehc-text);
	line-height: 1.45;
}

.ehc-find--pass .ehc-find__label {
	font-weight: 500;
}

.ehc-find__evidence {
	margin: 6px 0 0;
	padding: 8px 10px;
	background: #ffffff;
	border: 1px solid var(--ehc-line);
	border-radius: 4px;
	font-family: ui-monospace, Menlo, Consolas, monospace;
	font-size: 11.5px;
	color: #334155;
	white-space: pre-wrap;
	word-break: break-word;
	line-height: 1.55;
	max-height: 240px;
	overflow: auto;
}

.ehc-find-list--ok .ehc-find__evidence {
	color: #475569;
}

@media (max-width: 820px) {
	.ehc-score { flex-direction: column; align-items: stretch; gap: 12px; padding: 14px 16px; }
	.ehc-section { padding: 14px 16px; }
	.ehc-section__head { flex-direction: column; align-items: flex-start; gap: 8px; }
}
