/* ---------- Contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 2fr; gap: var(--space-6); }
@media (max-width: 800px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-info p { margin-bottom: var(--space-3); }
.contact-map-wide iframe { display: block; width: 100%; }

.contact-form .field { margin-bottom: var(--space-4); }
.contact-form label { display: block; font-weight: 600; margin-bottom: var(--space-1); font-size: .9rem; }
.contact-form input,
.contact-form textarea {
	width: 100%; padding: .75rem .9rem; border: 1px solid var(--c-line);
	border-radius: var(--radius); font: inherit; background: #fff;
}
.contact-form input:focus,
.contact-form textarea:focus { outline: 2px solid var(--c-accent); outline-offset: 1px; }
.contact-form .hp { position: absolute; left: -9999px; }

.alert { padding: var(--space-3) var(--space-4); border-radius: var(--radius); margin-bottom: var(--space-4); }
.alert--success { background: #e8f5ee; color: #1b5e20; border: 1px solid #b7e4c7; }
.alert--error   { background: #fdecea; color: #b71c1c; border: 1px solid #f5c2c0; }

/* ---------- About ---------- */
.about-grid { display: grid; grid-template-columns: 1fr 2fr; gap: var(--space-6); align-items: start; }
.about-grid__media img { border-radius: var(--radius-lg); }
@media (max-width: 800px) { .about-grid { grid-template-columns: 1fr; } }

/* ---------- Project metrics ---------- */
.metrics { text-align: center; }
.metric__value {
	display: block; font-family: var(--font-display);
	font-size: clamp(2rem, 5vw, 3rem); font-weight: 700; color: var(--c-accent);
}
.metric__label { display: block; font-size: .9rem; color: var(--c-muted); text-transform: uppercase; letter-spacing: .08em; }

/* ---------- FAQ ---------- */
.faq__item {
	border-bottom: 1px solid var(--c-line); padding: var(--space-3) 0;
}
.faq__item summary {
	cursor: pointer; font-weight: 600; font-size: 1.05rem;
	color: var(--c-primary); list-style: none; position: relative; padding-right: 2rem;
}
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary::after {
	content: '+'; position: absolute; right: 0; top: 0;
	font-size: 1.5rem; line-height: 1; color: var(--c-accent);
}
.faq__item[open] summary::after { content: '−'; }
.faq__item > div { padding-top: var(--space-3); color: var(--c-muted); }

/* ---------- Search results ---------- */
.result-list { list-style: none; padding: 0; }
.result-list li { padding: var(--space-4) 0; border-bottom: 1px solid var(--c-line); }
.result-list h3 { margin: 0 0 var(--space-2); }
