
:root{
  --navy:#4B382A;              /* Espresso */
  --blue:#4B382A;              /* Accent same as espresso */
  --blue-soft:#EDE9E6;         /* Soft beige pill */
  --bg:#ffffff;
  --muted:#FAF8F6;             /* warm background tint */
  --text:#0f172a;
  --sub:#475569;
  --border:#e5e7eb;
  --ring:rgba(75,56,42,.25);
  --shadow:0 10px 20px rgba(2,6,23,.06), 0 2px 6px rgba(2,6,23,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:"Baskerville Old Face", Baskerville, "Times New Roman", Georgia, serif;color:var(--text);background:var(--bg)}
a{color:var(--blue);text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* Header */
header{position:sticky;top:0;z-index:50;background:#ffffffcc;backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.nav{min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:10px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:90px;width:auto;object-fit:contain}
.brand-title{font-weight:900;font-size:24px;letter-spacing:.02em;color:var(--navy)}
.links{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.links a{color:#0f172a;font-size:15px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:12px;font-weight:700;border:1px solid var(--blue);background:var(--blue);color:#fff !important;text-decoration:none}
 .btn.ghost{background:#fff;color:#4B382A;border-color:#4B382A}

/* Hero */
.hero{padding:84px 0;background:radial-gradient(900px 300px at 50% -40px, rgba(75,56,42,.12), transparent), linear-gradient(#fff, var(--muted));align-items:start}
.pill{display:inline-block;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700;background:var(--blue-soft);color:var(--navy);border:1px solid #d6cec9}
h1{font-size:52px;line-height:1.05;margin:10px 0 12px 0;font-weight:900;letter-spacing:-.02em;color:#111827}
h1 .accent{color:var(--blue)}
.lead{font-size:18px;color:var(--sub)}

.grid{display:grid;gap:24px}
@media(min-width:1000px){.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}}

.card{background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:16px}
.card h3{margin:0 0 8px 0;color:var(--navy)}

/* Checklist */
ul.checks{list-style:none;padding:0;margin:0;display:grid;gap:8px}
ul.checks.two-col{grid-template-columns:1fr 1fr;gap:8px 22px}
ul.checks li{display:flex;align-items:center;gap:10px;line-height:1.3}
ul.checks li .dot{width:20px;height:20px;border-radius:50%;background:#EDE9E6;border:1px solid #d3c7bf;display:flex;align-items:center;justify-content:center;color:var(--navy);font-weight:900;font-size:14px;line-height:1}

/* Icon row */
.icon-row{display:grid;gap:18px}
@media(min-width:900px){.icon-row{grid-template-columns:repeat(4,1fr)}}
.icon{display:flex;gap:12px;align-items:flex-start;background:linear-gradient(180deg,#fbfaf9,#f6f2ef);border:1px solid #efe7e2;border-radius:16px;padding:16px;box-shadow:0 1px 0 rgba(0,0,0,.02)}
.icon .circle{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:#F5EFEA;border:1px solid #e7ddd6;color:var(--navy)}
.icon h4{margin:0 0 6px 0}

/* Sections */
section{padding:72px 0}
.section-title{font-size:28px;font-weight:800;color:var(--navy);margin:0 0 8px 0;text-align:center}
.section-sub{color:var(--sub);text-align:center;max-width:720px;margin:0 auto 20px auto}

/* Footer */
footer{background:#fff;border-top:1px solid var(--border);padding:28px 0;color:var(--sub)}
.footer-grid{display:grid;gap:24px}
@media(min-width:900px){.footer-grid{grid-template-columns:2fr 1fr 1.5fr}}
.footer-col h5{margin:0 0 10px 0;color:var(--navy)}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:6px}

/* Pricing */
table{border-collapse:collapse;width:100%}
table.pricing th, table.pricing td{border-bottom:1px solid var(--border);padding:12px 10px;text-align:left;font-size:14px}
table.pricing th{font-size:12px;color:var(--navy);text-transform:uppercase;letter-spacing:.05em;background:#f8f5f3}
.price-number{font-size:28px;font-weight:800;color:#111827}
.pricing-cards{display:grid;gap:24px}
@media(min-width:900px){.pricing-cards{grid-template-columns:repeat(3,1fr)}}

/* Contact form */
.form{display:grid;gap:12px;grid-template-columns:1fr 1fr}
.form input,.form textarea{width:100%;padding:12px 14px;border:1px solid #cbd5e1;border-radius:12px;font:inherit}
.form input:focus,.form textarea:focus{outline:none;box-shadow:0 0 0 3px var(--ring);border-color:#c5b1a8}
.form textarea{min-height:140px;grid-column:1/-1}
@media(max-width:720px){.form{grid-template-columns:1fr}}

/* CTA band */
.cta{background:linear-gradient(180deg,var(--blue),var(--navy));color:#fff;padding:5px 0;margin-top:80px}
.cta .wrap{display:grid;gap:1px;align-items:center;justify-items:center}
.cta h2{margin:0 0 4px 0; color:#fff}

.nav .btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:12px;font-weight:700;border:1px solid var(--blue);background:var(--blue);color:#fff !important;text-decoration:none}

.btn *, .nav .btn *{color:#fff !important}

.icon-row{margin-bottom:36px}
.icon-row + section.container{margin-top:30px;padding-top:20px}

footer{margin-top:80px}


/* Explicit spacing after hero on all pages */
.hero + section.container,
.hero + .container,
.hero + .container.icon-row { margin-top: 60px !important; }

/* Extra spacing between icon row and services on Home */
.icon-row { margin-top: 20px; margin-bottom: 40px !important; }
.icon-row + section.container { margin-top: 60px !important; }

/* Bottom breathing room before footer */
footer { margin-top: 90px !important; }

/* Headings breathing room inside sections */
.section-title, .container > h2 { margin-top: 0; margin-bottom: 22px; }

/* New button variant for "About Us" */
.btn.alt { background:#7B5E57; border-color:#7B5E57; color:#fff !important; }
.btn.alt:hover { filter: brightness(0.95); }



/* Ensure CTA button text is visible (white bg, espresso text) */
.cta .btn{background:#fff !important;color:var(--navy) !important;border-color:#fff !important}



/* ===== Pricing page typography & spacing (scoped) ===== */
body.pricing-page .pricing-hero{padding-bottom:32px;margin-bottom:28px}
body.pricing-page .pricing-section{margin-top:36px;margin-bottom:36px}
body.pricing-page h1{font-size:46px}
body.pricing-page h2{font-size:26px;font-weight:800;margin-bottom:14px;color:var(--navy)}
body.pricing-page table.pricing th{font-size:14px;font-weight:800;letter-spacing:.08em}
body.pricing-page table.pricing td{font-size:16px}
body.pricing-page .price-number{font-size:36px;font-weight:900;color:#111827}



/* ===== Pricing page readability tweaks ===== */
body.pricing-page table.pricing td{font-size:17px; color:#2f2f2f}
body.pricing-page .card{padding:18px}
body.pricing-page .card h3{font-weight:800;color:#1f2937}
body.pricing-page .card .lead{font-size:15.5px !important;color:#2f2f2f;line-height:1.5}
body.pricing-page .card p{color:#2f2f2f}
body.pricing-page .card ul{margin-top:8px}
body.pricing-page .price-number{font-size:38px;font-weight:900;color:#111827}



/* ===== Pricing page: bigger fonts for readability ===== */
body.pricing-page table.pricing th{font-size:16px;font-weight:800}
body.pricing-page table.pricing td{font-size:18px;color:#222;line-height:1.6}

/* Card titles and body (Calls / Letters / Mailing, captions under prices) */
body.pricing-page .card h3{font-size:20px;font-weight:900;color:#1f2937;margin-bottom:6px}
body.pricing-page .card .lead,
body.pricing-page .card p{font-size:16.5px !important;color:#222;line-height:1.55}

/* Price numbers remain prominent */
body.pricing-page .price-number{font-size:40px;font-weight:900;color:#111827}



/* ===== Force big bold price numbers on Pricing page ===== */
body.pricing-page .price,
body.pricing-page .price-amount,
body.pricing-page .price-number,
body.pricing-page .card strong:first-child {
  font-size: 20px !important;
  font-weight: 900 !important;
  color: #111827 !important;
  letter-spacing: 0.2px;
}
/* Slightly bigger small captions under prices */
body.pricing-page .card small,
body.pricing-page .card .caption,
body.pricing-page .price-caption{
  font-size: 16px !important;
  color: #2a2a2a !important;
}



/* Make right column (rates) in the bookkeeping table large & bold */
body.pricing-page table.pricing td:last-child{
  font-size:20px !important;
  font-weight:800 !important;
  color:#111827 !important;
}



/* Enlarge only card prices on Pricing page */
body.pricing-page .card .price-number,
body.pricing-page .card strong:first-child {
  font-size:15px !important;
  font-weight:900 !important;
  color:#111827 !important;
  line-height:1.2;
}



/* Footer contact sizing adjusted — nth-child removed */
/* Bigger phone & email on contact page only */
body.contact-page .card .lead > div:nth-child(1) > div,
body.contact-page .card .lead a[href^="mailto"]{
  font-size: 20px !important;
  font-weight: 900 !important;
}
/* Label (Phone / Email) slightly bolder */
body.contact-page .card .lead > div > strong{
  font-weight: 800;
}



/* Footer: ensure Services list is not bold */
footer .footer-col ul li,
footer .footer-col ul li a {
  font-weight: 400 !important;
  color: #4b5563; /* neutral gray */
}



/* Footer uniform list weight */
footer .footer-col ul li,
footer .footer-col ul li a {
  font-weight: 400 !important;
}

/* Footer contact: make email a bit larger without affecting services */
footer .footer-col a[href^="mailto"]{
  font-size: 18px !important;
  font-weight: 700 !important;
}

@media (max-width: 768px) {
  header nav {
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 16px !important;
  }

  header nav > a {
    display: inline-block !important;
    margin: 0 6px !important;
    text-align: center !important;
  }

  header .btn,
  header a.btn {
    display: block !important;
    margin: 12px auto !important;
    text-align: center !important;
  }
}

.hero {
  padding: 40px 0 !important;
  background-color: #f5e9df !important;
  border-radius: 8px;
}

@media (max-width: 768px) {
  .hero h1 {
    font-size: 28px !important;
    line-height: 1.3 !important;
  }
}
