/* Alert 360 — Customer Experience page styles
 * Loaded only on the /customer-experience/ page. Inherits site-wide typography
 * from the active theme; this file just lays out the page-specific blocks.
 */

.a360-cx-wrap {
	max-width: 920px;
	margin: 0 auto;
	padding: 56px 24px;
	font-family: inherit;
	line-height: 1.55;
	color: #1B1B1B;
}

.a360-cx-wrap h1,
.a360-cx-wrap h2 {
	color: #1B1B1B;
	letter-spacing: -0.02em;
}

.a360-cx-wrap h1 {
	font-size: clamp(28px, 4vw, 44px);
	font-weight: 600;
	line-height: 1.2;
	margin: 0 0 16px;
}

.a360-cx-wrap h2 {
	font-size: clamp(22px, 3vw, 30px);
	font-weight: 600;
	margin: 0 0 16px;
}

.a360-cx-wrap p,
.a360-cx-wrap li {
	font-size: 17px;
	line-height: 1.65;
	margin: 0 0 14px;
}

.a360-cx-wrap a {
	color: #00964B;
	text-decoration: underline;
	text-underline-offset: 3px;
}
.a360-cx-wrap a:hover { color: #007a3d; }

/* Hero elements carry .a360-cx-wrap in the selector so they outrank the
 * generic `.a360-cx-wrap p` sizing above — without it, the kicker and lede
 * inherit the 17px body sizing and drift from the sitewide hero pattern
 * shared with /newsroom/ and /testimonial-release/.
 */
.a360-cx-wrap .a360-cx-kicker {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	line-height: 1.55;
	color: #00964B;
	margin: 0 0 12px;
}

.a360-cx-hero {
	padding-bottom: 28px;
	border-bottom: 1px solid #ECECEC;
	margin-bottom: 36px;
}

.a360-cx-wrap .a360-cx-subhead {
	font-size: 18px;
	font-weight: 500;
	color: #00964B;
	margin: 0 0 18px;
}

.a360-cx-wrap .a360-cx-lede {
	font-size: 19px;
	line-height: 1.6;
	color: #3a3a3a;
	margin: 0 0 18px;
}

.a360-cx-section {
	margin: 0 -24px 24px;
	padding: 32px 24px;
	border-radius: 20px;
}

.a360-cx-section--alt {
	background: #F5F5F5;
}

.a360-cx-section ul {
	padding-left: 1.2em;
	margin: 0 0 14px;
}
.a360-cx-section li { margin-bottom: 8px; }

.a360-cx-stats {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px;
	margin: 20px 0 8px;
}

.a360-cx-stat {
	background: #fff;
	border: 1px solid #ECECEC;
	border-radius: 16px;
	padding: 20px;
}

.a360-cx-stat-value {
	font-size: 28px;
	font-weight: 600;
	color: #00964B;
	letter-spacing: -0.01em;
	margin: 0 0 6px;
}

.a360-cx-stat-label {
	font-size: 13px;
	font-weight: 600;
	color: #1B1B1B;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin: 0 0 8px;
}

.a360-cx-stat-detail {
	font-size: 14px;
	color: #555;
	margin: 0;
	line-height: 1.5;
}

.a360-cx-faq h2 { margin-bottom: 20px; }

.a360-cx-faq-item {
	background: #fff;
	border: 1px solid #ECECEC;
	border-radius: 12px;
	padding: 0;
	margin-bottom: 12px;
	overflow: hidden;
}

.a360-cx-faq-item > summary {
	list-style: none;
	cursor: pointer;
	padding: 18px 20px;
	font-weight: 600;
	font-size: 16px;
	color: #1B1B1B;
	position: relative;
	padding-right: 48px;
}

.a360-cx-faq-item > summary::-webkit-details-marker { display: none; }

.a360-cx-faq-item > summary::after {
	content: "+";
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 24px;
	font-weight: 400;
	color: #00964B;
	line-height: 1;
}

.a360-cx-faq-item[open] > summary::after {
	content: "−";
}

.a360-cx-faq-item[open] > summary {
	border-bottom: 1px solid #F0F0F0;
}

.a360-cx-faq-item > p {
	padding: 16px 20px 20px;
	margin: 0;
	color: #3a3a3a;
	font-size: 16px;
	line-height: 1.6;
}

.a360-cx-cta {
	background: #1B1B1B;
	color: #fff;
	margin: 40px -24px 0;
}
.a360-cx-cta h2 { color: #fff; }
.a360-cx-cta p { color: #d8d8d8; }
.a360-cx-cta a { color: #37b977; }
.a360-cx-cta a:hover { color: #69cb99; }
.a360-cx-cta strong { color: #fff; }

.a360-cx-contact {
	list-style: none;
	padding: 0;
	margin: 16px 0;
}
.a360-cx-contact li { color: #d8d8d8; }

.a360-cx-tagline {
	color: #b8b8b8;
	font-size: 16px;
	margin-top: 18px;
}

@media (max-width: 560px) {
	.a360-cx-wrap { padding: 32px 18px; }
	.a360-cx-section { margin-left: -18px; margin-right: -18px; padding: 24px 18px; }
	.a360-cx-cta { margin-left: -18px; margin-right: -18px; }
}
