/* Waitlist page — extracted from waitlist.html prototype. */

.waitlist-grid {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 64px;
	align-items: start;
}
@media (max-width: 900px) { .waitlist-grid { grid-template-columns: 1fr; gap: 40px; } }

.waitlist-left h1 { font-size: clamp(2.2rem, 4.2vw, 3.4rem); }

.urgency-bar {
	display: flex; align-items: center; gap: 14px;
	background: var(--orange-soft); border-radius: 16px;
	padding: 14px 18px; margin-bottom: 28px;
}
.urgency-bar .icon {
	width: 36px; height: 36px; border-radius: 10px;
	background: var(--orange); color: white;
	display: flex; align-items: center; justify-content: center;
	flex-shrink: 0; font-size: 1.1rem;
}
.urgency-bar strong { color: var(--orange-deep); display: block; }
.urgency-bar span { font-size: 0.9rem; color: var(--ink-soft); }

.form-card {
	background: white;
	border-radius: var(--radius-lg);
	padding: 40px;
	box-shadow: var(--shadow);
	border: 1px solid var(--line);
}
.form-card h2 { font-size: 1.6rem; margin-bottom: 6px; }
.form-card .muted { font-size: 0.95rem; }

/* CF7 form styles for the waitlist. */
.form-card .wpcf7-form { display: flex; flex-direction: column; gap: 18px; margin-top: 24px; }
.form-card .wpcf7-form p { margin: 0; }
.form-card .wpcf7-form label {
	display: flex; flex-direction: column; gap: 6px;
	font-weight: 700; font-size: 0.9rem; color: var(--ink);
}
.form-card .wpcf7-form input[type="text"],
.form-card .wpcf7-form input[type="email"],
.form-card .wpcf7-form input[type="tel"],
.form-card .wpcf7-form textarea,
.form-card .wpcf7-form select {
	font-family: var(--f-body);
	font-size: 1rem;
	padding: 14px 16px;
	border: 1.5px solid var(--line);
	border-radius: 14px;
	background: white;
	color: var(--ink);
	transition: border-color 0.15s, box-shadow 0.15s;
	width: 100%;
}
.form-card .wpcf7-form input:focus,
.form-card .wpcf7-form textarea:focus,
.form-card .wpcf7-form select:focus {
	outline: 0;
	border-color: var(--orange);
	box-shadow: 0 0 0 4px rgba(244,123,63,0.15);
}
.form-card .wpcf7-form .wpcf7-submit {
	background: var(--orange); color: white;
	padding: 18px 28px;
	border: 0; border-radius: 999px;
	font-family: var(--f-body); font-size: 1.05rem; font-weight: 800;
	cursor: pointer;
	box-shadow: 0 8px 20px rgba(244,123,63,0.4);
	transition: transform 0.15s, box-shadow 0.15s;
	width: 100%;
}
.form-card .wpcf7-form .wpcf7-submit:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 28px rgba(244,123,63,0.5);
}

.steps-section { background: var(--cream-deep); }
.steps-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 40px; }
@media (max-width: 880px) { .steps-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .steps-grid { grid-template-columns: 1fr; } }
.step-card {
	background: white; border-radius: var(--radius-lg);
	padding: 28px; border: 1px solid var(--line);
	position: relative;
}
.step-num {
	font-family: var(--f-display); font-size: 1rem; font-weight: 700;
	color: var(--orange-deep); letter-spacing: 0.1em;
	margin-bottom: 12px;
}
.step-card h3 { font-size: 1.1rem; margin-bottom: 6px; }
.step-card p { font-size: 0.92rem; color: var(--ink-soft); margin: 0; }

.faq-list { display: flex; flex-direction: column; gap: 12px; margin-top: 32px; max-width: 820px; }
.faq-item {
	background: white; border: 1px solid var(--line);
	border-radius: 18px; overflow: hidden;
}
.faq-q {
	padding: 20px 24px;
	font-weight: 700; font-size: 1rem;
	cursor: pointer;
	display: flex; justify-content: space-between; align-items: center; gap: 16px;
	list-style: none;
}
.faq-q::-webkit-details-marker { display: none; }
.faq-q::after { content: "+"; color: var(--orange-deep); font-size: 1.5rem; font-weight: 300; transition: transform 0.2s; }
.faq-item[open] .faq-q::after { transform: rotate(45deg); }
.faq-a { padding: 0 24px 22px; color: var(--ink-soft); }
