/* Geo's Handyman — main stylesheet
   Mobile-first, no external fonts, system stack for instant FCP.
   Color tokens + minimal layout primitives. ~12 KB unminified. */

:root {
	--c-bg: #ffffff;
	--c-surface: #f8fafc;
	--c-surface-2: #f1f5f9;
	--c-text: #0f172a;
	--c-muted: #475569;
	--c-border: #e2e8f0;
	--c-primary: #0b2545;       /* navy */
	--c-primary-2: #134074;
	--c-accent: #f97316;        /* safety orange */
	--c-accent-2: #ea580c;
	--c-success: #16a34a;
	--c-link: #1d4ed8;

	--radius: 10px;
	--radius-lg: 16px;
	--shadow-sm: 0 1px 2px rgba(15,23,42,.06), 0 1px 3px rgba(15,23,42,.05);
	--shadow-md: 0 4px 12px rgba(15,23,42,.08);

	--container: 1180px;
	--container-narrow: 760px;

	--space-1: .25rem;
	--space-2: .5rem;
	--space-3: .75rem;
	--space-4: 1rem;
	--space-5: 1.5rem;
	--space-6: 2rem;
	--space-8: 3rem;
	--space-10: 4.5rem;

	--font-stack: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

@media (prefers-color-scheme: dark) {
	/* keep light mode — local biz sites convert better in light */
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: var(--font-stack);
	font-size: 17px;
	line-height: 1.55;
	color: var(--c-text);
	background: var(--c-bg);
	-webkit-font-smoothing: antialiased;
}
img, svg { max-width: 100%; height: auto; display: block; }

a { color: var(--c-link); text-decoration-thickness: 1px; text-underline-offset: 2px; }
a:hover { text-decoration-thickness: 2px; }

h1, h2, h3, h4 { line-height: 1.18; margin: 0 0 var(--space-4); color: var(--c-text); letter-spacing: -.01em; }
h1 { font-size: clamp(1.85rem, 4.5vw, 3rem); font-weight: 800; }
h2 { font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 700; }
h3 { font-size: 1.2rem; font-weight: 700; }
h4 { font-size: 1.05rem; font-weight: 700; }
p  { margin: 0 0 var(--space-4); }

.muted   { color: var(--c-muted); }
.small   { font-size: .9rem; }
.center  { text-align: center; }
.sr-only { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link { position: absolute; left: -9999px; top: 0; background: var(--c-primary); color: #fff; padding: .5rem 1rem; z-index: 100; }
.skip-link:focus { left: 0; }

/* Layout */
.container { max-width: var(--container); margin: 0 auto; padding: 0 var(--space-5); }
.container.narrow { max-width: var(--container-narrow); }
.section { padding: var(--space-10) 0; }
.section-alt { background: var(--c-surface); }

.section-head { text-align: center; max-width: 700px; margin: 0 auto var(--space-8); }
.eyebrow { color: var(--c-accent-2); text-transform: uppercase; letter-spacing: .08em; font-size: .8rem; font-weight: 700; margin: 0 0 var(--space-2); }

/* Buttons / CTAs */
.cta {
	display: inline-flex; align-items: center; gap: .5rem;
	padding: .85rem 1.25rem; border-radius: var(--radius);
	font-weight: 700; text-decoration: none; line-height: 1;
	border: 2px solid transparent; transition: transform .08s ease, background .15s ease;
	white-space: nowrap;
}
.cta:active { transform: translateY(1px); }
.cta-call    { background: var(--c-accent); color: #fff; }
.cta-call:hover { background: var(--c-accent-2); }
.cta-primary { background: var(--c-primary); color: #fff; }
.cta-primary:hover { background: var(--c-primary-2); }
.cta-secondary { background: #fff; color: var(--c-primary); border-color: var(--c-primary); }
.cta-secondary:hover { background: var(--c-primary); color: #fff; }
.cta + .cta { margin-left: .5rem; }
.cta.block   { display: block; text-align: center; margin-top: var(--space-4); }

/* Header */
.site-header { position: sticky; top: 0; z-index: 50; background: #fff; border-bottom: 1px solid var(--c-border); }
.header-row { display: flex; align-items: center; gap: var(--space-5); padding-block: var(--space-3); }
.brand { display: inline-flex; align-items: center; gap: var(--space-3); text-decoration: none; color: var(--c-text); }
.brand-mark {
	width: 40px; height: 40px; border-radius: 8px;
	background: var(--c-primary); color: #fff;
	display: grid; place-items: center; font-weight: 800; font-size: 1.2rem;
}
.brand-text { display: flex; flex-direction: column; line-height: 1.1; }
.brand-name { font-weight: 800; font-size: 1.05rem; }
.brand-sub { color: var(--c-muted); font-size: .78rem; }

.primary-nav { margin-left: auto; }
.nav-toggle {
	display: none; background: transparent; border: 1px solid var(--c-border);
	padding: .5rem .7rem; border-radius: 8px; cursor: pointer;
}
.nav-toggle .bars { display: block; width: 22px; height: 2px; background: var(--c-text); position: relative; }
.nav-toggle .bars::before, .nav-toggle .bars::after {
	content: ''; position: absolute; left: 0; right: 0; height: 2px; background: var(--c-text);
}
.nav-toggle .bars::before { top: -6px; } .nav-toggle .bars::after { top: 6px; }

.menu { list-style: none; display: flex; gap: var(--space-5); margin: 0; padding: 0; }
.menu a { color: var(--c-text); text-decoration: none; font-weight: 600; font-size: .95rem; }
.menu a:hover { color: var(--c-primary); }

.header-cta { font-size: .95rem; padding: .6rem 1rem; }

@media (max-width: 880px) {
	.header-cta span:last-child { display: none; }
	.nav-toggle { display: inline-flex; }
	.primary-nav .menu {
		display: none; position: absolute; top: 100%; left: 0; right: 0;
		background: #fff; border-bottom: 1px solid var(--c-border);
		flex-direction: column; padding: var(--space-3) var(--space-5);
	}
	.primary-nav.open .menu { display: flex; }
	.primary-nav .menu a { padding: .65rem 0; border-bottom: 1px solid var(--c-border); }
}

/* Hero */
.hero { background: linear-gradient(180deg, var(--c-surface), #fff); padding: var(--space-10) 0; }
.hero-grid { display: grid; gap: var(--space-8); grid-template-columns: 1.1fr 1fr; align-items: center; }
.hero-text h1 { margin-bottom: var(--space-4); }
.lede { font-size: 1.15rem; color: var(--c-muted); }
.hero-cta { margin: var(--space-5) 0 var(--space-4); }
.trust-row { list-style: none; padding: 0; margin: var(--space-4) 0 0; display: flex; flex-wrap: wrap; gap: var(--space-4); color: var(--c-muted); font-size: .9rem; }
.trust-row li { padding-right: var(--space-4); border-right: 1px solid var(--c-border); }
.trust-row li:last-child { border: 0; }
.hero-img img { border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }

@media (max-width: 880px) {
	.hero-grid { grid-template-columns: 1fr; }
	.hero-img { order: -1; }
}

/* Cards */
.cards { display: grid; gap: var(--space-5); grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.cards-3 { display: grid; gap: var(--space-5); grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.card {
	display: block; padding: var(--space-5); background: #fff; border: 1px solid var(--c-border);
	border-radius: var(--radius); text-decoration: none; color: inherit; transition: border-color .15s, box-shadow .15s, transform .08s;
}
.card:hover { border-color: var(--c-primary); box-shadow: var(--shadow-md); transform: translateY(-1px); }
.card-title { color: var(--c-primary); margin-bottom: var(--space-2); }
.card-text { color: var(--c-muted); margin-bottom: var(--space-3); }
.card-meta { font-size: .85rem; color: var(--c-muted); margin: 0 0 var(--space-3); }
.card-cta { color: var(--c-accent-2); font-weight: 700; }

.card-soft { padding: var(--space-5); background: #fff; border-radius: var(--radius); box-shadow: var(--shadow-sm); }
.group-h { margin: var(--space-6) 0 var(--space-4); color: var(--c-primary); }

/* Chip list (service area) */
.chip-list { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: var(--space-3); justify-content: center; }
.chip {
	display: inline-block; padding: .55rem 1rem; background: #fff; border: 1px solid var(--c-border);
	border-radius: 999px; text-decoration: none; color: var(--c-primary); font-weight: 600; font-size: .92rem;
}
.chip:hover { background: var(--c-primary); color: #fff; }

/* Reviews */
.review .stars { color: #f59e0b; font-size: 1.1rem; letter-spacing: 2px; margin-bottom: var(--space-2); }
.review-meta { margin: var(--space-2) 0 0; color: var(--c-muted); font-size: .9rem; }

/* FAQ */
.faq-list { display: grid; gap: var(--space-3); }
.faq-item { background: #fff; border: 1px solid var(--c-border); border-radius: var(--radius); padding: var(--space-4) var(--space-5); }
.faq-q { cursor: pointer; font-weight: 700; color: var(--c-primary); list-style: none; }
.faq-q::-webkit-details-marker { display: none; }
.faq-q::before { content: '+'; display: inline-block; width: 1.2em; color: var(--c-accent-2); font-weight: 800; }
.faq-item[open] .faq-q::before { content: '–'; }
.faq-a { padding-top: var(--space-3); color: var(--c-text); }

/* CTA band */
.cta-band { background: var(--c-primary); color: #fff; padding: var(--space-8) 0; }
.cta-band h2 { color: #fff; margin: 0 0 var(--space-2); }
.cta-band p { margin: 0; color: #cbd5e1; }
.cta-band-row { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--space-5); }
.cta-band-actions .cta-secondary { background: transparent; color: #fff; border-color: #fff; }
.cta-band-actions .cta-secondary:hover { background: #fff; color: var(--c-primary); }

/* Footer */
.site-footer { background: #0a1c34; color: #cbd5e1; padding: var(--space-8) 0 var(--space-5); }
.footer-grid { display: grid; gap: var(--space-6); grid-template-columns: 1.2fr 1fr 1fr 1fr; }
.footer-h { color: #fff; font-size: 1rem; margin-bottom: var(--space-3); }
.footer-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .35rem; }
.footer-list a { color: #cbd5e1; text-decoration: none; }
.footer-list a:hover { color: #fff; }
.site-footer a { color: #93c5fd; }
.footer-bottom { margin-top: var(--space-6); padding-top: var(--space-5); border-top: 1px solid #1e3a5c; }

@media (max-width: 880px) {
	.footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px) {
	.footer-grid { grid-template-columns: 1fr; }
}

/* Page articles */
.page-head { margin: var(--space-6) 0 var(--space-6); }
.page-article, .post-article, .service-page, .city-page, .faq-page, .contact-page { padding: var(--space-6) 0 var(--space-10); }
.page-figure { margin: 0 0 var(--space-6); }
.page-figure img { border-radius: var(--radius-lg); }

.prose h2 { margin-top: var(--space-6); }
.prose h3 { margin-top: var(--space-5); }
.prose ul, .prose ol { padding-left: 1.25rem; }
.prose li { margin-bottom: .35rem; }
.prose a { color: var(--c-link); }

/* Service / city template grids */
.service-grid { display: grid; gap: var(--space-6); grid-template-columns: 1.5fr 1fr; align-items: start; margin-top: var(--space-5); }
@media (max-width: 880px) { .service-grid { grid-template-columns: 1fr; } }

.service-side .kv { display: grid; grid-template-columns: auto 1fr; gap: .35rem var(--space-4); margin: 0 0 var(--space-4); }
.service-side .kv dt { color: var(--c-muted); font-weight: 600; }
.service-side .kv dd { margin: 0; }

/* Contact form */
.contact-grid { display: grid; gap: var(--space-6); grid-template-columns: 1fr 2fr; align-items: start; }
@media (max-width: 880px) { .contact-grid { grid-template-columns: 1fr; } }

.lead-form label { display: block; margin: 0 0 var(--space-4); font-weight: 600; }
.lead-form input, .lead-form select, .lead-form textarea {
	width: 100%; padding: .7rem .85rem; margin-top: .35rem;
	border: 1px solid var(--c-border); border-radius: 8px; font: inherit; background: #fff;
}
.lead-form input:focus, .lead-form select:focus, .lead-form textarea:focus {
	outline: 2px solid var(--c-primary); outline-offset: 1px; border-color: var(--c-primary);
}
.lead-form .grid-2 { display: grid; gap: var(--space-4); grid-template-columns: 1fr 1fr; }
@media (max-width: 580px) { .lead-form .grid-2 { grid-template-columns: 1fr; } }
.lead-form .hp { position: absolute; left: -9999px; top: -9999px; }
.alert { background: #fef3c7; border: 1px solid #fcd34d; padding: .75rem 1rem; border-radius: 8px; }

/* Breadcrumbs */
.breadcrumbs ol { list-style: none; padding: 0; margin: 0 0 var(--space-3); display: flex; flex-wrap: wrap; gap: .35rem; font-size: .88rem; color: var(--c-muted); }
.breadcrumbs a { color: var(--c-muted); text-decoration: none; }
.breadcrumbs a:hover { color: var(--c-primary); }
.breadcrumbs [aria-current="page"] { color: var(--c-text); font-weight: 600; }

/* Post CTA box */
.post-cta { margin: var(--space-8) 0 0; padding: var(--space-5); background: var(--c-surface); border-radius: var(--radius); border: 1px solid var(--c-border); }
.post-cta h2 { margin-top: 0; }

/* Misc */
.post-list { display: grid; gap: var(--space-5); }
.post-card { padding: var(--space-5); background: #fff; border: 1px solid var(--c-border); border-radius: var(--radius); }
.post-card h2 { margin: 0 0 var(--space-2); font-size: 1.25rem; }
.post-card a { color: var(--c-primary); text-decoration: none; }
.post-card a:hover { color: var(--c-accent-2); }
