/* Parent Communicator — landing page styles.
 * Scoped to .pc-landing and form/cards so they don't clash with theme styles.
 * Brand colors come from inline CSS variables injected by the plugin (see wp_head). */

.pc-landing {
	--pc-bg: #fbfaf7;
	--pc-card: #ffffff;
	--pc-text: #1a1a1a;
	--pc-muted: #5a5a5a;
	--pc-border: #e3dfd8;
	--pc-soft: #f0ede6;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	color: var(--pc-text);
	line-height: 1.55;
	background: var(--pc-bg);
	border-radius: 8px;
	overflow: hidden;
}
.pc-landing * { box-sizing: border-box; }

.pc-landing .pc-hero {
	text-align: center;
	padding: 60px 24px 70px;
}
.pc-landing .pc-ribbon {
	display: inline-block;
	background: #fff3cd;
	color: #8a6d00;
	padding: 6px 14px;
	border-radius: 999px;
	font-size: 13px;
	font-weight: 500;
	margin-bottom: 24px;
}
.pc-landing .pc-h1 {
	font-size: 44px;
	line-height: 1.1;
	letter-spacing: -0.02em;
	margin: 0 0 18px;
	color: var(--pc-text);
}
.pc-landing .pc-h1 em {
	color: var(--pc-brand, #1f6f5c);
	font-style: normal;
}
.pc-landing .pc-lede {
	font-size: 18px;
	color: var(--pc-muted);
	max-width: 640px;
	margin: 0 auto 30px;
}
.pc-landing .pc-cta-row {
	display: flex;
	gap: 12px;
	justify-content: center;
	flex-wrap: wrap;
}

.pc-landing .pc-btn,
.pc-landing a.pc-btn {
	display: inline-block;
	padding: 12px 22px;
	border-radius: 8px;
	font-weight: 500;
	font-size: 15px;
	text-decoration: none;
	cursor: pointer;
	border: 0;
	font-family: inherit;
}
.pc-landing .pc-btn-primary,
.pc-landing a.pc-btn-primary,
.pc-form-card .pc-btn-primary {
	background: var(--pc-brand, #1f6f5c);
	color: #fff;
}
.pc-landing .pc-btn-primary:hover,
.pc-landing a.pc-btn-primary:hover,
.pc-form-card .pc-btn-primary:hover {
	background: var(--pc-brand-dark, #154a3e);
	color: #fff;
}
.pc-landing .pc-btn-secondary {
	background: #fff;
	color: var(--pc-text);
	border: 1px solid var(--pc-border);
}
.pc-landing .pc-btn-full,
.pc-form-card .pc-btn-full {
	display: block;
	width: 100%;
	text-align: center;
}

.pc-landing .pc-section {
	padding: 60px 24px;
}
.pc-landing .pc-alt {
	background: #fff;
	border-top: 1px solid var(--pc-border);
	border-bottom: 1px solid var(--pc-border);
}
.pc-landing .pc-h2 {
	font-size: 30px;
	letter-spacing: -0.015em;
	text-align: center;
	margin: 0 0 12px;
}
.pc-landing .pc-section-lede {
	font-size: 16px;
	color: var(--pc-muted);
	text-align: center;
	max-width: 600px;
	margin: 0 auto 40px;
}

/* grids */
.pc-landing .pc-grid {
	display: grid;
	gap: 18px;
	max-width: 1040px;
	margin: 0 auto;
}
.pc-landing .pc-grid-4 {
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

/* problem cards */
.pc-landing .pc-card {
	background: var(--pc-card);
	border: 1px solid var(--pc-border);
	border-radius: 10px;
	padding: 22px;
}
.pc-landing .pc-card-mono {
	width: 38px;
	height: 38px;
	border-radius: 50%;
	background: var(--pc-brand, #1f6f5c);
	color: #fff;
	font-family: Georgia, serif;
	font-weight: 700;
	font-size: 18px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 14px;
}
.pc-landing .pc-card h3 {
	margin: 0 0 6px;
	font-size: 17px;
}
.pc-landing .pc-card p {
	margin: 0;
	color: var(--pc-muted);
	font-size: 14.5px;
}

/* steps */
.pc-landing .pc-step {
	text-align: center;
	padding: 0 8px;
}
.pc-landing .pc-step-num {
	width: 38px; height: 38px;
	margin: 0 auto 14px;
	background: var(--pc-brand, #1f6f5c);
	color: #fff;
	border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	font-weight: 600;
}
.pc-landing .pc-step h3 { font-size: 17px; margin: 0 0 8px; }
.pc-landing .pc-step p { font-size: 14.5px; color: var(--pc-muted); margin: 0; }

/* pricing */
.pc-landing .pc-price-card {
	max-width: 460px;
	margin: 0 auto;
	background: var(--pc-card);
	border: 2px solid var(--pc-brand, #1f6f5c);
	border-radius: 14px;
	padding: 34px 30px;
	text-align: center;
	box-shadow: 0 4px 24px rgba(31,111,92,0.08);
}
.pc-landing .pc-price-big {
	font-size: 54px;
	font-weight: 700;
	color: var(--pc-brand-dark, #154a3e);
	letter-spacing: -0.02em;
}
.pc-landing .pc-price-small {
	font-size: 17px;
	color: var(--pc-muted);
	font-weight: 400;
}
.pc-landing .pc-feature-list {
	text-align: left;
	list-style: none;
	padding: 0;
	margin: 22px 0;
	font-size: 14.5px;
}
.pc-landing .pc-feature-list li {
	padding: 7px 0 7px 26px;
	position: relative;
}
.pc-landing .pc-feature-list li::before {
	content: "✓";
	position: absolute;
	left: 0;
	color: var(--pc-brand, #1f6f5c);
	font-weight: 700;
}
.pc-landing .pc-price-note {
	font-size: 13px;
	color: var(--pc-muted);
	margin-top: 12px;
}

/* form (shared between landing + form shortcode) */
.pc-form-card {
	max-width: 540px;
	margin: 0 auto;
	background: #fff;
	border: 1px solid #e3dfd8;
	border-radius: 12px;
	padding: 28px;
	position: relative;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}
.pc-form-row {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 14px;
}
.pc-form-row > * { flex: 1; min-width: 200px; }
.pc-form-full { margin-bottom: 14px; }
.pc-form-card label {
	font-size: 13px;
	color: #5a5a5a;
	display: block;
	margin-bottom: 5px;
}
.pc-form-card input,
.pc-form-card select,
.pc-form-card textarea {
	width: 100%;
	padding: 10px 13px;
	border: 1px solid #e3dfd8;
	border-radius: 7px;
	font-size: 14.5px;
	font-family: inherit;
	background: #fff;
}
.pc-form-card input:focus,
.pc-form-card select:focus,
.pc-form-card textarea:focus {
	outline: 2px solid var(--pc-brand, #1f6f5c);
	outline-offset: -1px;
}
.pc-form-card .pc-btn-primary { width: 100%; padding: 12px 18px; }
.pc-form-msg { margin-top: 14px; padding: 10px 14px; border-radius: 7px; font-size: 14px; display: none; }
.pc-form-msg.pc-ok { background: #e8f5ec; color: #154a3e; display: block; }
.pc-form-msg.pc-err { background: #fde8e8; color: #8b2222; display: block; }

/* FAQ */
.pc-landing .pc-faq {
	max-width: 740px;
	margin: 0 auto;
}
.pc-landing details {
	background: #fff;
	border: 1px solid var(--pc-border);
	border-radius: 8px;
	padding: 16px 20px;
	margin-bottom: 10px;
}
.pc-landing details summary {
	font-weight: 500;
	cursor: pointer;
	font-size: 15px;
}
.pc-landing details p {
	margin: 12px 0 0;
	color: var(--pc-muted);
	font-size: 14.5px;
}

/* small screens */
@media (max-width: 640px) {
	.pc-landing .pc-h1 { font-size: 32px; }
	.pc-landing .pc-h2 { font-size: 25px; }
	.pc-landing .pc-lede { font-size: 16px; }
	.pc-landing .pc-section { padding: 44px 18px; }
}
