/* ============================================================
   PAGES.CSS — page-specific layout (home, service, quote, blog)
   Built on top of styles.css tokens/components.
   ============================================================ */

/* ---------- Home: services grid ---------- */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; margin-top: 3rem; }
@media (max-width: 980px) { .svc-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px) { .svc-grid { grid-template-columns: 1fr; } }

.section-head { max-width: 640px; margin-bottom: 1rem; }
.section-head h2 { margin-top: 0.7rem; }
.section-head--center { margin-inline: auto; text-align: center; }
.section-head--center .eyebrow { justify-content: center; }

/* home about split image */
.media-frame { position: relative; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-lg); }
.media-frame img { width: 100%; aspect-ratio: 4/5; object-fit: cover; }
.media-frame__tag {
  position: absolute; bottom: 18px; left: 18px; background: var(--cobalt); color: #fff;
  padding: 0.8rem 1.2rem; border-radius: var(--radius); box-shadow: var(--shadow-md);
}
.media-frame__tag strong { font-family: var(--font-display); font-size: 1.9rem; display: block; line-height: 1; }
.media-frame__tag span { font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.9; }

/* trust badges row */
.badges { display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; }
.badge {
  text-align: center; padding: 1.6rem 1rem; border: 1px solid var(--line-light);
  border-radius: var(--radius); background: rgba(255,255,255,0.04);
}
.badge strong { font-family: var(--font-display); font-size: 2.2rem; color: var(--cobalt-bright); display: block; line-height: 1; }
.badge span { font-size: 0.82rem; letter-spacing: 0.06em; color: rgba(255,255,255,0.7); margin-top: 0.5rem; display: block; }
@media (max-width: 640px) { .badges { grid-template-columns: 1fr 1fr; } }

/* process steps */
.steps { counter-reset: step; display: grid; grid-template-columns: repeat(4,1fr); gap: 1.4rem; }
.step { position: relative; padding-top: 3.2rem; }
.step::before {
  counter-increment: step; content: "0" counter(step);
  position: absolute; top: 0; left: 0; font-family: var(--font-display);
  font-size: 2.4rem; color: var(--cobalt); opacity: 0.85;
}
.step::after { content: ""; position: absolute; top: 1.4rem; left: 3.4rem; right: -0.7rem; height: 1px; background: var(--line); }
.step:last-child::after { display: none; }
.step h3 { font-size: 1.15rem; margin-bottom: 0.4rem; }
.step p { font-size: 0.92rem; color: rgba(27,38,59,0.75); }
@media (max-width: 760px) { .steps { grid-template-columns: 1fr 1fr; } .step::after { display: none; } }

/* ---------- Service page layout ---------- */
.svc-layout { display: grid; grid-template-columns: 1fr 340px; gap: clamp(32px,5vw,64px); align-items: start; }
@media (max-width: 980px) { .svc-layout { grid-template-columns: 1fr; } }

.neighborhood-strip { display: flex; flex-wrap: wrap; gap: 0.6rem; margin: 1.4rem 0; }
.neighborhood-strip a {
  font-size: 0.85rem; font-weight: 600; padding: 0.45em 1em; border: 1px solid var(--line);
  border-radius: 100px; color: var(--charcoal); border-bottom: 1px solid var(--line); transition: all 0.2s;
}
.neighborhood-strip a:hover { background: var(--cobalt); color: #fff; border-color: var(--cobalt); }

.svc-gallery { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; margin: 1.8rem 0; }
.svc-gallery img { aspect-ratio: 1; object-fit: cover; border-radius: var(--radius); }
@media (max-width: 640px) { .svc-gallery { grid-template-columns: 1fr 1fr; } }

.related-services { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; margin-top: 1.5rem; }
.related-services a {
  display: block; padding: 1.1rem 1.3rem; border: 1px solid var(--line); border-radius: var(--radius);
  background: #fff; font-weight: 600; color: var(--charcoal); transition: all 0.25s var(--ease);
}
.related-services a:hover { border-color: var(--cobalt); color: var(--cobalt); transform: translateY(-3px); box-shadow: var(--shadow-sm); }
.related-services a span { display: block; font-size: 0.8rem; color: var(--cobalt); font-weight: 700; margin-bottom: 0.3rem; letter-spacing: 0.05em; }
@media (max-width: 760px) { .related-services { grid-template-columns: 1fr; } }

/* ---------- Quote page ---------- */
.quote-layout { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,5vw,64px); align-items: start; }
@media (max-width: 880px) { .quote-layout { grid-template-columns: 1fr; } }
.form-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: clamp(1.8rem,4vw,2.6rem); box-shadow: var(--shadow-md); }
.field { margin-bottom: 1.2rem; }
.field label { display: block; font-weight: 600; font-size: 0.88rem; margin-bottom: 0.5rem; color: var(--charcoal); }
.field input, .field select, .field textarea {
  width: 100%; padding: 0.85em 1em; border: 1px solid var(--line); border-radius: var(--radius);
  font-family: var(--font-body); font-size: 0.96rem; color: var(--charcoal); background: var(--concrete);
  transition: border-color 0.2s, background 0.2s;
}
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--cobalt); background: #fff; box-shadow: 0 0 0 3px rgba(0,91,234,0.1); }
.field textarea { resize: vertical; min-height: 110px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 480px) { .field-row { grid-template-columns: 1fr; } }
.quote-perks { display: grid; gap: 1.3rem; margin-top: 2rem; }

/* ---------- Blog ---------- */
.blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.6rem; margin-top: 2.5rem; }
@media (max-width: 980px) { .blog-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .blog-grid { grid-template-columns: 1fr; } }
.post-meta { font-size: 0.8rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--cobalt); font-weight: 700; }

/* ---------- TOC (service) ---------- */
.toc { background: var(--concrete); border-left: 3px solid var(--cobalt); padding: 1.2rem 1.4rem; border-radius: var(--radius); margin: 1.5rem 0; }
.toc strong { font-family: var(--font-body); font-size: 0.8rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--charcoal); }
.toc ul { display: grid; gap: 0.5rem; margin-top: 0.8rem; }
.toc a { font-size: 0.92rem; }
