/* /app/pages/seo-pages.css
   Used only by SEO content pages: /services/, /locations/, and leaf pages.
*/

:root{
  --seo-max: 980px;

  /* fallbacks if your theme vars don't exist */
  --seo-text: var(--text, #0f172a);
  --seo-muted: var(--muted, #475569);
  --seo-bg: var(--page, #ffffff);
  --seo-card: var(--card, #ffffff);
  --seo-border: var(--border, rgba(15,23,42,.12));
  --seo-shadow: 0 10px 30px rgba(2,6,23,.08);
  --seo-shadow-sm: 0 6px 18px rgba(2,6,23,.08);
  --seo-radius: 16px;
}

.seo-page main.wrap{
  max-width: var(--seo-max);
}

/* Hero area */
.seo-page .seo-hero{
  padding: 18px 0 8px;
}
.seo-page .seo-hero .eyebrow{
  display:inline-flex;
  gap:8px;
  align-items:center;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 12px;
  color: var(--seo-muted);
}
.seo-page h1{
  margin: 10px 0 10px;
  font-size: clamp(28px, 4vw, 40px);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--seo-text);
}
.seo-page h2{
  margin: 0 0 12px;
  font-size: clamp(18px, 2.4vw, 24px);
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--seo-text);
}
.seo-page p{
  color: var(--seo-muted);
  line-height: 1.6;
}
.seo-page .lede{
  max-width: 820px;
  font-size: 16px;
}

/* Breadcrumb */
.seo-page .breadcrumb{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  font-size: 13px;
  color: var(--seo-muted);
}
.seo-page .breadcrumb a{
  color: inherit;
  text-decoration: none;
  border-bottom: 1px dotted transparent;
}
.seo-page .breadcrumb a:hover{
  border-bottom-color: currentColor;
}

/* Divider */
.seo-page .divider{
  margin: 22px 0;
  height: 1px;
  background: var(--seo-border);
}

/* Cards & grids */
.seo-page .grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
@media (max-width: 820px){
  .seo-page .grid{ grid-template-columns: 1fr; }
}

.seo-page .card{
  background: var(--seo-card);
  border: 1px solid var(--seo-border);
  border-radius: var(--seo-radius);
  padding: 16px 16px;
  box-shadow: var(--seo-shadow-sm);
}
.seo-page .card h3{
  margin: 0 0 8px;
  font-size: 16px;
  letter-spacing: -0.01em;
  color: var(--seo-text);
}
.seo-page .card p,
.seo-page .card .muted{
  margin: 0;
  color: var(--seo-muted);
}

/* CTA row */
.seo-page .cta-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin-top: 14px;
}
.seo-page .cta-row a.btn-primary,
.seo-page .cta-row a.btn-ghost{
  box-shadow: var(--seo-shadow-sm);
  border-radius: 12px;
}

/* FAQ details */
.seo-page details.card{
  padding: 0;
  overflow: hidden;
}
.seo-page details.card summary{
  cursor: pointer;
  list-style: none;
  padding: 14px 16px;
  user-select: none;
  display:flex;
  justify-content: space-between;
  gap: 12px;
  align-items:center;
}
.seo-page details.card summary::-webkit-details-marker{ display:none; }
.seo-page details.card summary strong{
  color: var(--seo-text);
}
.seo-page details.card summary::after{
  content: "▾";
  color: var(--seo-muted);
  font-size: 14px;
  transform: translateY(-1px);
}
.seo-page details[open].card summary::after{
  content: "▴";
}
.seo-page details.card > div{
  padding: 0 16px 14px;
  color: var(--seo-muted);
}

/* CTA panel polish */
.seo-page .cta-panel{
  border-radius: 20px;
  border: 1px solid var(--seo-border);
  background: linear-gradient(180deg, rgba(2,6,23,.03), rgba(2,6,23,.01));
  box-shadow: var(--seo-shadow);
  padding: 18px;
}