/* Mobile-first, modern CSS for Cook County Buyers */
:root {
  --bg: #ffffff;
  --text: #222;
  --muted: #5b5b5b;
  --primary: #111111;
  --accent: #d4af37;
  --radius: 16px;
  --space: 1rem;
}
* { box-sizing: border-box; }
html, body { margin:0 1rem 0 1rem; padding:0; background:var(--bg); color:var(--text); font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Inter, Helvetica, Arial, 'Apple Color Emoji','Segoe UI Emoji','Segoe UI Symbol'; }
img { max-width:100%; height:auto; display:block; border-radius: var(--radius); }
a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }
.skip-link { position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }
.skip-link:focus { left: 0; top: 0; background:#fff; padding:.5rem 1rem; z-index: 9999; }

.wrap { max-width: 1100px; margin: 0 auto; padding: 0 1rem; }
.site-header { position: sticky; top:0; z-index: 1000; background: #fff; border-bottom: 1px solid #eee; }
.site-header .wrap { display:flex; gap: .75rem; align-items:center; justify-content: space-between; padding: .75rem 1rem; }
.brand { display: inline-flex; align-items:center; gap:.5rem; font-weight: 700; font-size: 1rem; color: var(--primary); }
.brand-mark { background: var(--primary); color:#fff; border-radius: 999px; padding: .35rem .6rem; font-size:.8rem; letter-spacing:.5px; text-align: center }
.nav-toggle { background:#fff; border:1px solid #ddd; padding:.5rem .75rem; border-radius: .75rem; }
.nav { display:none; }
.nav.open { display:block; }
.nav ul { list-style:none; margin:0; padding:0; display:flex; flex-direction: column; gap:.25rem; }
.nav a { display:block; padding:.5rem; border-radius:.5rem; }
.nav a:hover { background:#f6f6f6; text-decoration:none; }
.cta-header { display:none; gap:.5rem; }

.btn { display:inline-block; padding:.8rem 1rem; border: 1px solid var(--primary); color: var(--primary); border-radius: .75rem; font-weight: 600; }
.btn:hover { text-decoration:none; background:#f8f8f8; }
.btn-primary { background: var(--primary); color:#fff; border-color: var(--primary); }
.btn-primary:hover { background: #000; }
.btn-call { background: var(--accent); border-color: var(--accent); color:#111; }
.btn-text { background: #111; border-color: #111; color:#fff; }

.hero { background: linear-gradient(180deg, #fff, #faf7f0); padding: 2rem 0 1rem; border-bottom: 1px solid #eee; }
.hero h1 { font-size: 1.65rem; line-height: 1.2; }
.hero .lead { color: var(--muted); margin: .5rem 0 1rem; }
.hero .actions { display:flex; gap:.5rem; flex-wrap: wrap; }
.accent { color: var(--accent); }

.cards { display:grid; grid-template-columns: 1fr 1fr; gap: 1rem; padding: 1.5rem 0; }
.card { background:#fff; border:1px solid #eee; padding: .75rem; border-radius: var(--radius); transition: transform .15s ease; }
.card:hover { transform: translateY(-2px); }
.card h2 { margin:.5rem 0 .25rem; font-size:1.1rem; }
.card p { margin:0; color:var(--muted); font-size:.95rem; }

.feature { display:grid; grid-template-columns: 1fr; gap:1rem; padding: 1rem 0 2rem; }
.feature aside { background:#fff; border:1px solid #eee; border-radius: var(--radius); padding: 1rem; }

.checklist { list-style: none; padding:0; margin:0; }
.checklist li::before { content: "✓"; margin-right:.5rem; color: var(--accent); }

.faq details { background:#fff; border:1px solid #eee; border-radius: var(--radius); padding: .75rem 1rem; margin-bottom: .5rem; }

.prose { padding: 1rem 0 2rem; }
.prose h1 { font-size: 1.6rem; }
.steps { counter-reset: st; list-style:none; padding:0; }
.steps > li { counter-increment: st; position: relative; background:#fff; border:1px solid #eee; border-radius: var(--radius); padding: .75rem .75rem .75rem 3rem; margin:.5rem 0; }
.steps > li::before { content: counter(st); position:absolute; left:.75rem; top:.75rem; width:1.6rem; height:1.6rem; border-radius:999px; background: var(--primary); color:#fff; display:grid; place-items:center; font-weight:700; }

.contact-form { display:grid; gap:.5rem; background:#fff; border:1px solid #eee; border-radius: var(--radius); padding: 1rem; }
.contact-form input, .contact-form textarea { border:1px solid #ddd; border-radius:.5rem; padding:.7rem; font: inherit; }
.hint { color: var(--muted); font-size:.9rem; }

.site-footer { background:#0d0d0d; color:#d9d9d9; margin-top: 2rem; }
.site-footer a { color:#d9d9d9; }
.site-footer .wrap { padding: 1.25rem 1rem; }
.site-footer .grid { display:grid; grid-template-columns: 1fr; gap: 1rem; }
.site-footer h3 { margin:0 0 .5rem; color:#fff; }
.site-footer .legal { display:flex; justify-content: space-between; align-items:center; border-top:1px solid #222; padding: .75rem 1rem; color:#9a9a9a; flex-wrap: wrap; gap:.5rem; }

.mobile-cta { position: sticky; bottom:0; z-index: 1000; display:grid; grid-template-columns: 1fr 1fr; }
.mobile-cta__button { background:#111; color:#fff; text-align:center; padding: .9rem 1rem; font-weight: 700; }
.mobile-cta__button + .mobile-cta__button { background: var(--accent); color:#111; }

.badges { display:flex; gap:.5rem; padding:0; list-style:none; margin:1rem 0 0; flex-wrap: wrap; }
.badges li { background:#fff; border:1px solid #eee; border-radius: 999px; padding: .4rem .7rem; font-size:.9rem; color:#444; }

.list-plain { list-style:none; padding:0; margin:0; }
blockquote { border-left: 4px solid var(--accent); margin: 1rem 0; padding:.25rem 1rem; color:#333; background:#fff; border-radius: 0 var(--radius) var(--radius) 0; }


@media (min-width: 769px ) and (max-width: 1200px) {
	.hideBrand {display: none; }
}
@media (min-width: 769px ) and (max-width: 1025px) {
	.hideBrand-mark {display: none; }
}
@media (min-width: 769px ) and (max-width: 975px) {
	.hideLocation {display: none; }
}
@media (min-width: 769px ) and (max-width: 925px) {
	.hideEstate {display: none; }
}
@media (min-width: 769px ) and (max-width: 875px) {
	.hideDesigner {display: none; }
}


@media (min-width: 768px) {
  .hero h1 { font-size: 2rem; }
  .nav { display:block; }
  .nav ul { flex-direction: row; gap:.25rem; }
  .nav-toggle { display:none; }
  .cta-header { display:flex; }
  .cards { grid-template-columns: repeat(4, 1fr); }
  .feature { grid-template-columns: 2fr 1fr; }
  .site-footer .grid { grid-template-columns: 1.2fr 1fr 1fr; }
}

/* A11y focus outlines + reduced motion */
:where(a, button, .btn, .nav-toggle):focus-visible { outline: 3px solid var(--accent); outline-offset: 2px; }
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}
:where(h1, h2, h3, h4, h5, h6)[id] { scroll-margin-top: 4.25rem; } /* avoids sticky-header overlap on anchor jumps */
