/* Austin Turnover Dispatch — shared stylesheet for service & area pages.
   Mirrors the design tokens used inline on index.html so every page reads
   as one brand. Keep index.html's inline styles as the source of truth for
   the homepage; this file styles the SEO content pages. */
:root {
  --bg: #faf8f4;
  --bg-warm: #f4f0e8;
  --ink: #16140f;
  --muted: #6b6660;
  --line: #e7e1d6;
  --gold: #b8893a;
  --gold-bright: #d4a85a;
  --green: #2d6a3f;
  --green-bright: #34a853;
  --serif: 'Fraunces', Georgia, serif;
  --sans: 'Inter', system-ui, sans-serif;
  --shadow: 0 20px 60px -20px rgba(22,20,15,0.25);
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body { background: var(--bg); color: var(--ink); font-family: var(--sans); line-height:1.6; -webkit-font-smoothing: antialiased; }
a { color: var(--gold); }

.topbar { background: var(--ink); color:#fff; text-align:center; font-size:12.5px; padding:8px 16px; }
.topbar strong { color: var(--gold-bright); }
.topbar a { color: var(--gold-bright); text-decoration: underline; }

nav {
  position: sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:14px 28px; background: rgba(250,248,244,0.9); backdrop-filter: blur(12px);
  border-bottom:1px solid var(--line);
}
.brand { font-family: var(--serif); font-weight:800; font-size:18px; letter-spacing:-0.02em; text-decoration:none; color:var(--ink); }
.brand span { color: var(--gold); }
.nav-links { display:flex; gap:22px; align-items:center; }
.nav-links a { font-size:14px; color: var(--muted); text-decoration:none; font-weight:500; }
.nav-links a:hover { color: var(--ink); }
.nav-cta { background: var(--ink); color:#fff !important; text-decoration:none; padding:9px 18px; border-radius:6px; font-size:13px; font-weight:600; }
.nav-cta:hover { background:#000; }

.wrap { max-width: 860px; margin: 0 auto; padding: 0 24px; }
.wrap-wide { max-width: 1100px; margin: 0 auto; padding: 0 24px; }

/* breadcrumb */
.crumb { font-size:13px; color: var(--muted); padding: 22px 0 0; }
.crumb a { color: var(--muted); text-decoration:none; }
.crumb a:hover { color: var(--ink); text-decoration: underline; }

/* article hero */
.page-hero { padding: 30px 0 18px; }
.eyebrow { font-size:12px; letter-spacing:0.16em; text-transform:uppercase; color:var(--gold); font-weight:700; margin-bottom:14px; }
.page-hero h1 { font-family: var(--serif); font-weight:800; font-size: clamp(32px, 4.6vw, 52px); line-height:1.05; letter-spacing:-0.025em; margin-bottom:18px; }
.page-hero h1 em { font-style:italic; color: var(--gold); }
.lede { font-size:19px; color:#3a362f; max-width: 680px; }

.cta-row { display:flex; gap:12px; flex-wrap:wrap; margin: 26px 0 8px; }
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:14px 26px; font-family:var(--sans); font-size:15px; font-weight:600; border-radius:8px; border:none; cursor:pointer; text-decoration:none; transition: transform .15s, background .15s; }
.btn-gold { background: var(--gold-bright); color:#1a1a1a; box-shadow:0 10px 30px -10px rgba(184,137,58,0.6); }
.btn-gold:hover { background: var(--gold); transform: translateY(-2px); }
.btn-ghost { background:transparent; color:var(--ink); border:1.5px solid var(--ink); }
.btn-ghost:hover { background:var(--ink); color:#fff; }

/* hero photo */
.hero-shot { width:100%; max-height:420px; object-fit:cover; border-radius:16px; box-shadow: var(--shadow); margin: 8px 0 6px; display:block; }

/* article body */
article { padding: 14px 0 40px; }
article h2 { font-family: var(--serif); font-weight:600; font-size: clamp(26px, 3.4vw, 36px); line-height:1.15; letter-spacing:-0.02em; margin: 44px 0 14px; }
article h3 { font-family: var(--serif); font-weight:600; font-size:21px; margin: 26px 0 8px; }
article p { font-size:17px; color:#3a362f; margin-bottom:16px; }
article ul, article ol { margin: 0 0 18px 22px; }
article li { font-size:17px; color:#3a362f; margin-bottom:8px; }
article strong { color: var(--ink); }

/* price table */
.ptable { width:100%; border-collapse:collapse; margin:18px 0 8px; border:1px solid var(--line); border-radius:12px; overflow:hidden; }
.ptable th, .ptable td { text-align:left; padding:14px 16px; font-size:15px; border-bottom:1px solid var(--line); }
.ptable th { background: var(--bg-warm); font-family:var(--sans); font-weight:700; font-size:12px; text-transform:uppercase; letter-spacing:0.06em; color:var(--muted); }
.ptable tr:last-child td { border-bottom:none; }
.ptable td:last-child { font-family:var(--serif); font-weight:700; white-space:nowrap; }

/* callout */
.callout { background: var(--bg-warm); border-left:3px solid var(--gold); border-radius:10px; padding:18px 20px; margin:22px 0; font-size:16px; }

/* faq */
.faq-item { border-bottom:1px solid var(--line); padding:18px 0; cursor:pointer; }
.faq-q { display:flex; justify-content:space-between; align-items:center; gap:16px; font-weight:600; font-size:17px; }
.faq-q .plus { font-size:22px; color:var(--gold); transition: transform .2s; flex-shrink:0; }
.faq-a { font-size:16px; color: var(--muted); max-height:0; overflow:hidden; transition: max-height .25s, margin .25s; }
.faq-item.open .faq-a { max-height: 320px; margin-top: 10px; }
.faq-item.open .plus { transform: rotate(45deg); }

/* related links cards */
.related { background: var(--bg-warm); padding: 56px 0; margin-top: 20px; }
.related h2 { font-family:var(--serif); font-size:28px; margin-bottom:22px; }
.link-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap:16px; }
.link-card { background:#fff; border:1px solid var(--line); border-radius:12px; padding:22px; text-decoration:none; color:var(--ink); transition: transform .18s, box-shadow .18s; display:block; }
.link-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.link-card .lc-t { font-family:var(--serif); font-weight:600; font-size:18px; margin-bottom:6px; }
.link-card .lc-d { font-size:14px; color: var(--muted); }

/* final cta band */
.cta-band { background: var(--ink); color:#fff; padding:60px 24px; text-align:center; }
.cta-band h2 { font-family:var(--serif); font-weight:600; font-size: clamp(26px,3.4vw,38px); margin-bottom:12px; color:#fff; }
.cta-band p { color: rgba(255,255,255,0.72); font-size:17px; max-width:560px; margin:0 auto 24px; }

footer { background:#100f0c; color:#8a857c; padding:48px 28px 32px; text-align:center; font-size:13px; }
footer .brand { color:#fff; margin-bottom:10px; display:inline-block; }
footer .foot-links { margin:14px 0; display:flex; gap:18px; justify-content:center; flex-wrap:wrap; }
footer .foot-links a { color:#b8b3a8; text-decoration:none; font-size:13px; }
footer .foot-links a:hover { color:#fff; }
footer .rule { color: var(--gold-bright); margin:14px 0; font-size:13px; }
footer .small { font-size:11px; opacity:0.6; margin-top:16px; }

@media (max-width: 720px) {
  .nav-links { display:none; }
  .lede { font-size:17px; }
  article p, article li { font-size:16px; }
}
