/* ============================================================
   Page-specific — single article, services, about, locations,
   contact, page head, scroll reveal, 404
   ============================================================ */

/* ---- Generic page head (non-hero) ---- */
.page-head { max-width: var(--container-narrow); margin: 0 auto clamp(2rem,4vw,3rem); }
.page-head__title { margin-top: 0.4rem; }

/* ---- Long-form article (service single + blog) ---- */
.prose { max-width: var(--container-narrow); margin-inline: auto; }
.prose > * + * { margin-top: 1.15rem; }
.prose p { color: var(--text); font-size: 1.08rem; }
.prose h2 { margin-top: 2.2rem; font-size: clamp(1.6rem, 2.6vw, 2.1rem); }
.prose h3 { margin-top: 1.6rem; }
.prose ul, .prose ol { padding-left: 1.4rem; color: var(--text); }
.prose li + li { margin-top: 0.4rem; }
.prose blockquote { border-left: 3px solid var(--rose); padding: 0.4rem 0 0.4rem 1.4rem; font-family: var(--font-display); font-style: italic; font-size: 1.25rem; color: var(--ink); }
.prose a { color: var(--rose-deep); text-decoration: underline; text-decoration-color: var(--rose-glow); text-underline-offset: 3px; }
.prose img { border-radius: var(--radius); margin-block: 1.5rem; }
.prose [class^="WRITE"], .prose mark.write { background: #fff4d6; padding: 0.1em 0.3em; border-radius: 4px; }

/* ---- Service single layout ---- */
.service-single__intro { display: grid; grid-template-columns: 1.4fr 0.6fr; gap: clamp(2rem,4vw,3.5rem); align-items: start; }
.service-aside { position: sticky; top: calc(var(--header-h) + 1rem); display: grid; gap: 1.5rem; }
.service-aside__card { background: var(--moon-2); border-radius: var(--radius); padding: 1.6rem; box-shadow: var(--shadow-soft); }
.service-aside__card h3 { font-size: 1.2rem; margin-bottom: 0.8rem; }
.service-cta-card { background: var(--aurora); color: var(--moon); }
.service-cta-card h3 { color: var(--moon); }
.service-cta-card p { color: rgba(244,241,236,0.85); margin-bottom: 1rem; }
.service-cta-card .btn-row { flex-direction: column; align-items: stretch; }

/* Related services */
.related-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.related-card { display: flex; gap: 1rem; align-items: center; background: #fff; border: 1.5px solid var(--line); border-radius: var(--radius); padding: 1.1rem; transition: box-shadow 0.3s var(--ease), transform 0.3s var(--ease); }
.related-card:hover { box-shadow: var(--shadow-soft); transform: translateY(-3px); }
.related-card__mask { flex: 0 0 76px; height: 76px; }
.related-card__mask img { width: 100%; height: 100%; object-fit: cover; }
.related-card__icon { flex: 0 0 76px; height: 76px; display: grid; place-items: center; background: var(--moon-2); border-radius: 50% 40% 55% 45%; color: var(--rose); }
.related-card h4 { font-size: 1.1rem; }
.related-card a { color: var(--ink); }
.related-card a:hover { color: var(--rose-deep); }

/* ---- Mini testimonials (service page) ---- */
.mini-testi { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.5rem; }
.mini-testi__item { background: var(--moon-2); border-radius: var(--radius); padding: 1.6rem; position: relative; }
.mini-testi__item::before { content: "“"; font-family: var(--font-display); font-size: 3rem; color: var(--rose); opacity: 0.4; position: absolute; top: 0.4rem; left: 1rem; line-height: 1; }
.mini-testi__quote { font-style: italic; color: var(--ink); margin: 0.8rem 0; }
.mini-testi__name { font-weight: 600; color: var(--rose-deep); font-size: 0.95rem; }

/* ---- About page ---- */
.about__lead-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(2rem,5vw,4rem); align-items: center; }
.about__portrait { aspect-ratio: 4/5; position: relative; box-shadow: var(--shadow-soft); }
.about__portrait img { width: 100%; height: 100%; object-fit: cover; }
.values-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 1.5rem; }
.value-card { background: #fff; border-radius: var(--radius); padding: 1.6rem; border: 1.5px solid var(--line); }
.value-card__icon { width: 52px; height: 52px; border-radius: 50% 42% 55% 45%; display: grid; place-items: center; background: var(--moon-2); color: var(--rose); margin-bottom: 1rem; }
.value-card h3 { font-size: 1.2rem; margin-bottom: 0.5rem; }
.badges { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 1.6rem; }
.badge { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.55rem 1.1rem; border-radius: var(--radius-pill); background: var(--moon-2); font-size: 0.9rem; font-weight: 500; }
.badge svg { color: var(--thread); }

/* ---- Locations page ---- */
.areas-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px,1fr)); gap: 1rem; }
.area-chip { background: #fff; border: 1.5px solid var(--line); border-radius: var(--radius-sm); padding: 1.1rem 1.2rem; }
.area-chip__name { font-family: var(--font-display); font-size: 1.15rem; color: var(--ink); display: flex; align-items: center; gap: 0.5rem; }
.area-chip__name svg { color: var(--rose); }
.area-chip__note { font-size: 0.9rem; color: var(--text-soft); margin-top: 0.3rem; }

/* ---- Contact page ---- */
.contact__grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(2rem,4vw,3.5rem); }
.contact-form { display: grid; gap: 1.1rem; }
.contact-form .form-row { display: grid; gap: 1.1rem; grid-template-columns: 1fr 1fr; }
.contact__details { display: grid; gap: 1.5rem; align-content: start; }
.contact__detail { display: flex; gap: 0.9rem; align-items: flex-start; }
.contact__detail-icon { flex: 0 0 44px; height: 44px; border-radius: 50% 42% 55% 45%; display: grid; place-items: center; background: var(--moon-2); color: var(--rose); }
.contact__detail a { color: var(--ink); font-weight: 500; }
.honeypot { position: absolute; left: -9999px; }
.form-note { font-size: 0.85rem; color: var(--text-soft); }
.form-message { padding: 1rem 1.2rem; border-radius: var(--radius-sm); }
.form-message--ok { background: #e7f3ec; color: #2c6e49; }
.form-message--err { background: #fbe9e9; color: #a33; }

/* ---- 404 ---- */
.error-404 { min-height: 60vh; display: grid; place-content: center; }
.error-404__title { font-size: clamp(4rem, 14vw, 9rem); color: var(--rose); line-height: 1; }
.error-404__lead { font-size: 1.2rem; margin-bottom: 1.6rem; }
.error-404__orb { position: absolute; width: 320px; aspect-ratio: 1; border-radius: 50%; background: var(--glow); filter: blur(70px); z-index: 0; left: 50%; top: 30%; transform: translateX(-50%); }
.error-404 > * { position: relative; z-index: 1; }
.error-404__search { margin-top: 2rem; display: flex; justify-content: center; }

/* ---- Scroll reveal (progressive enhancement) ---- */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.7s var(--ease), transform 0.7s var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* ---- Responsive collapses ---- */
@media (max-width: 880px) {
  .intro__grid, .service-row, .service-row--reverse,
  .location__grid, .service-single__intro, .about__lead-grid,
  .contact__grid, .related-grid, .mini-testi { grid-template-columns: 1fr; }
  .service-row--reverse .service-row__media { order: 0; }
  .service-aside { position: static; }
  .steps { grid-template-columns: 1fr; }
  .contact-form .form-row { grid-template-columns: 1fr; }
}
@media (min-width: 881px) and (max-width: 1024px) {
  .steps { grid-template-columns: repeat(3,1fr); }
}
