/* ==================== Homepage promo cards ==================== */
/* Sits between blog-subfooter and the marketing footer. Six cards, indigo accent,
   inline SVG icons (no Font Awesome dependency). Class prefix .hp-promo- to
   avoid collisions with .blog-* classes. */
.hp-promo-section {
	background: linear-gradient(180deg, #fbfbfd 0%, #ffffff 100%);
	border-top: 1px solid #e9ecef;
	padding: 48px 0 56px;
	margin-top: 0;
}
.hp-promo-head { text-align: center; margin-bottom: 1.8rem; }
.hp-promo-eyebrow {
	display: inline-block;
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: #4338ca;
	background: #fff;
	border: 1px solid #e0e2ff;
	padding: .3rem .85rem;
	border-radius: 999px;
	margin-bottom: .9rem;
}
.hp-promo-head h2 {
	font-size: clamp(1.4rem, 3.2vw, 1.85rem);
	font-weight: 800;
	letter-spacing: -.02em;
	color: #1a1d22;
	margin: 0 0 .35rem;
}
.hp-promo-head p {
	color: #6c757d;
	font-size: .98rem;
	margin: 0 auto;
	max-width: 540px;
	line-height: 1.5;
}
.hp-promo-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
}
@media (max-width: 768px) {
	.hp-promo-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
	.hp-promo-grid { grid-template-columns: 1fr; }
}
.hp-promo-card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid #e9ecef;
	border-left: 3px solid #6366f1;
	border-radius: 14px;
	padding: 1.4rem 1.4rem 1.25rem;
	text-decoration: none;
	color: inherit;
	transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
	position: relative;
	min-height: 180px;
}
.hp-promo-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 28px rgba(0,0,0,.07);
	border-color: #c7d2fe;
	border-left-color: #4338ca;
	color: inherit;
	text-decoration: none;
}
.hp-promo-icon {
	width: 44px;
	height: 44px;
	border-radius: 12px;
	background: linear-gradient(135deg, #eef2ff 0%, #e0e7ff 100%);
	color: #4338ca;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1rem;
	transition: background .15s ease, color .15s ease;
}
.hp-promo-card:hover .hp-promo-icon {
	background: linear-gradient(135deg, #6366f1 0%, #4338ca 100%);
	color: #fff;
}
.hp-promo-icon svg { width: 24px; height: 24px; display: block; }
.hp-promo-name {
	font-size: 1.05rem;
	font-weight: 800;
	letter-spacing: -.012em;
	color: #1a1d22;
	margin: 0 0 .35rem;
	line-height: 1.25;
}
.hp-promo-desc {
	font-size: .85rem;
	color: #6c757d;
	line-height: 1.45;
	margin: 0 0 .9rem;
	flex: 1;
}
.hp-promo-cta {
	font-size: .82rem;
	font-weight: 700;
	color: #4338ca;
	letter-spacing: .02em;
	display: inline-flex;
	align-items: center;
	gap: .25rem;
}
.hp-promo-cta::after {
	content: "→";
	transition: transform .15s ease;
}
.hp-promo-card:hover .hp-promo-cta::after {
	transform: translateX(4px);
}

/* ==================== Final CTA band: free MC lookup ==================== */
/* Moved from carrier-packets.php — renders below the promo cards, just
   before the marketing footer. Different visual register from .hp-promo-*:
   dark navy, full-bleed, mock-lookup card on the right. Class prefix
   .cp-cta- preserved from the original to avoid having to retest. */
.cp-cta-band {
	background: linear-gradient(135deg, #0a1628 0%, #0d2240 50%, #112f5a 100%);
	color: #f1f3f5;
	padding: 80px 0 90px;
	position: relative;
	overflow: hidden;
}
.cp-cta-band::before {
	content: ""; position: absolute; inset: 0;
	background-image:
		radial-gradient(circle at 20% 25%, rgba(13,110,253,.18) 0%, transparent 38%),
		radial-gradient(circle at 80% 75%, rgba(255,255,255,.05) 0%, transparent 40%);
	pointer-events: none;
}
.cp-cta-band > .container { position: relative; z-index: 1; }
.cp-cta-eyebrow {
	display: inline-block;
	background: rgba(13,110,253,.20); color: #6cb4ff;
	padding: .4rem 1.1rem; border-radius: 999px;
	font-size: .8rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
	margin-bottom: 1.3rem; border: 1px solid rgba(13,110,253,.3);
}
.cp-cta-band h2 {
	font-size: clamp(2rem, 4.5vw, 3rem);
	font-weight: 900; letter-spacing: -.02em; line-height: 1.05;
	margin-bottom: .8rem;
	background: linear-gradient(180deg, #ffffff 0%, #c0c8d0 100%);
	-webkit-background-clip: text; background-clip: text; color: transparent;
}
.cp-cta-band .lead { font-size: 1.22rem; opacity: .92; margin-bottom: 1rem; max-width: 620px; }
.cp-cta-body { opacity: .85; max-width: 620px; line-height: 1.65; }
.cp-cta-benefits { list-style: none; padding: 0; margin: 1.5rem 0 0; max-width: 580px; }
.cp-cta-benefits li {
	display: flex; align-items: flex-start; gap: .75rem;
	padding: .55rem 0; font-size: 1.02rem;
	border-bottom: 1px solid rgba(255,255,255,.06);
}
.cp-cta-benefits li:last-child { border-bottom: 0; }
.cp-cta-benefits li::before {
	content: "✓"; color: #6cb4ff; font-weight: 800; flex-shrink: 0;
	width: 1.5rem; height: 1.5rem;
	background: rgba(13,110,253,.18); border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	font-size: .85rem;
}
.cp-cta-btn {
	display: inline-block;
	background: linear-gradient(135deg, #0d6efd 0%, #0a58ca 100%);
	color: #fff; padding: 1rem 2.4rem;
	font-size: 1.1rem; font-weight: 800;
	border: 0; border-radius: 10px; text-decoration: none;
	margin-top: 1.8rem;
	transition: transform .15s ease, box-shadow .15s ease;
	box-shadow: 0 8px 20px rgba(13,110,253,.30);
}
.cp-cta-btn:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 12px 28px rgba(13,110,253,.40); }
.cp-cta-meta { font-size: .9rem; opacity: .65; margin-top: 1rem; }
.cp-cta-mock {
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.10);
	border-radius: 14px; padding: 1.4rem;
	box-shadow: 0 25px 60px rgba(0,0,0,.35);
	backdrop-filter: blur(4px);
}
.cp-cta-mock-label { font-size: .72rem; text-transform: uppercase; letter-spacing: .1em; color: #6cb4ff; margin-bottom: .25rem; }
.cp-cta-mock-mc { font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace; font-size: 1.6rem; font-weight: 800; color: #fff; margin-bottom: 1rem; letter-spacing: .04em; }
.cp-cta-mock-row { display: flex; justify-content: space-between; padding: .55rem 0; border-bottom: 1px solid rgba(255,255,255,.06); font-size: .92rem; }
.cp-cta-mock-row:last-child { border-bottom: 0; }
.cp-cta-mock-row .k { opacity: .6; }
.cp-cta-mock-row .v { font-weight: 600; color: #fff; }
.cp-cta-mock-row .v.ok { color: #6dd99c; }
.cp-cta-mock-row .v.warn { color: #ffd24a; }
@media (max-width: 991px) {
	.cp-cta-mock { margin-top: 2.5rem; max-width: 480px; margin-left: auto; margin-right: auto; }
}
