/*
Theme Name: Business Accountings
Theme URI: https://www.businessaccountings.com/
Author: Business Accountings
Author URI: https://www.businessaccountings.com/
Description: Custom WordPress theme for Business Accountings. Certified QuickBooks ProAdvisors and bookkeeping specialists serving USA small businesses.
Version: 4.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: Proprietary
Text Domain: business-accountings
*/

/* ═══════════════════════════════════════════
   1. VARIABLES & RESET
═══════════════════════════════════════════ */
:root {
  --navy: #14283c; --navy-mid: #1a3450; --navy-dark: #0a1d2e;
  --green: #28a028; --green-dark: #1e7d1e; --green-light: #e8f7e8; --green-soft: #f0faf0;
  --text: #1f2937; --muted: #5a6a7a; --light: #f8fafb; --border: #e2eae0; --white: #ffffff;
  --shadow: 0 20px 60px rgba(20,40,60,0.12); --shadow-sm: 0 8px 24px rgba(20,40,60,0.08);
  --radius: 20px; --max: 1180px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Arial,sans-serif;color:var(--text);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
ul,ol{list-style:none}
button{font-family:inherit}
.container{width:min(var(--max),calc(100% - 40px));margin:0 auto}

/* ═══════════════════════════════════════════
   2. TYPOGRAPHY
═══════════════════════════════════════════ */
h1{font-size:clamp(32px,4.5vw,52px);font-weight:800;line-height:1.08;letter-spacing:-0.04em;color:var(--navy)}
h2{font-size:clamp(26px,3.5vw,38px);font-weight:700;line-height:1.15;letter-spacing:-0.03em;color:var(--navy)}
h3{font-size:clamp(20px,2.5vw,26px);font-weight:600;line-height:1.2;letter-spacing:-0.02em;color:var(--navy)}
h4{font-size:clamp(16px,2vw,20px);font-weight:500;line-height:1.3;color:var(--navy)}
h5{font-size:16px;font-weight:400;line-height:1.4;color:var(--navy)}
p{font-size:15.5px;color:var(--muted);line-height:1.72}

/* ═══════════════════════════════════════════
   3. TOP BAR & HEADER
═══════════════════════════════════════════ */
.top-bar{background:var(--navy);color:rgba(255,255,255,.88);font-size:13px;font-weight:500}
.top-bar-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:38px}
.top-bar a{color:rgba(255,255,255,.88);transition:color .15s}
.top-bar a:hover,.top-bar strong{color:#7ee87e}
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);box-shadow:0 2px 12px rgba(20,40,60,.06)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:76px}
.logo-wrap img{height:46px;width:auto;display:block}
.site-nav{display:flex;align-items:center;gap:28px;font-size:14.5px;font-weight:600;color:#344258}
.site-nav a{transition:color .15s;position:relative}
.site-nav a::after{content:"";position:absolute;bottom:-3px;left:0;width:0;height:2px;background:var(--green);border-radius:2px;transition:width .2s}
.site-nav a:hover,.site-nav a[aria-current="page"]{color:var(--green-dark)}
.site-nav a:hover::after{width:100%}
.header-actions{display:flex;align-items:center;gap:10px}
.mobile-toggle{display:none;width:44px;height:44px;border:1.5px solid var(--border);border-radius:12px;background:#fff;color:var(--navy);font-size:22px;cursor:pointer;align-items:center;justify-content:center}

/* ═══════════════════════════════════════════
   4. BUTTONS
═══════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:46px;padding:0 22px;border-radius:999px;font-weight:700;font-size:14.5px;transition:all .2s;cursor:pointer;border:2px solid transparent;white-space:nowrap;text-decoration:none}
.btn-primary{background:var(--green);color:#fff;box-shadow:0 8px 24px rgba(40,160,40,.28)}
.btn-primary:hover{background:var(--green-dark);box-shadow:0 12px 30px rgba(40,160,40,.36);transform:translateY(-1px)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-mid);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--border)}
.btn-ghost:hover{border-color:var(--green);color:var(--green-dark)}
.btn-white{background:#fff;color:var(--green-dark)}
.btn-white:hover{background:var(--green-soft)}
.btn-outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-outline-white:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.8)}
.btn-lg{min-height:52px;padding:0 30px;font-size:15.5px}
.btn-sm{min-height:38px;padding:0 16px;font-size:13px}

/* ═══════════════════════════════════════════
   5. SHARED SECTION STYLES
═══════════════════════════════════════════ */
section{padding:80px 0}
.section-label{font-size:12.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--green-dark);margin-bottom:12px}
.section-head{text-align:center;max-width:720px;margin:0 auto 52px}
.section-head h2{margin-bottom:14px}
.section-head p{font-size:17px;color:var(--muted);line-height:1.7}
.bg-light{background:var(--light)}
.bg-green-soft{background:var(--green-soft)}
.bg-navy{background:var(--navy)}

/* ═══════════════════════════════════════════
   6. PAGE HERO (All inner pages)
═══════════════════════════════════════════ */
.page-hero{background:linear-gradient(150deg,#28a028 0%,#5cc85c 35%,#b8f0b8 65%,#ffffff 100%);padding:60px 0 52px;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;opacity:.4;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.06'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.page-hero-content{position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(20,40,60,.65);margin-bottom:18px;font-weight:600;flex-wrap:wrap}
.breadcrumb a{color:var(--navy);transition:color .15s}
.breadcrumb a:hover{color:var(--green-dark)}
.breadcrumb span{color:var(--navy);opacity:.5}
.page-hero h1{font-size:clamp(32px,4.5vw,52px);font-weight:800;color:var(--navy);letter-spacing:-0.04em;line-height:1.08;margin-bottom:14px}
.page-hero p,.page-hero .lead{font-size:17.5px;color:#1a3c1a;max-width:620px;line-height:1.7;font-weight:500;margin-bottom:0}
.hero-stats-row{display:flex;gap:32px;flex-wrap:wrap;margin-top:26px}
.hero-stat strong{font-size:32px;font-weight:800;color:var(--navy);display:block;line-height:1}
.hero-stat span{font-size:13px;color:#2a5c2a;font-weight:600}

/* ═══════════════════════════════════════════
   7. HOMEPAGE HERO
═══════════════════════════════════════════ */
.hero{position:relative;overflow:hidden;padding:82px 0 64px;background:linear-gradient(150deg,#28a028 0%,#5cc85c 30%,#b8f0b8 60%,#ffffff 100%)}
.hero::before{content:"";position:absolute;inset:0;opacity:.4;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.06'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2V6h4V4h-4z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;align-items:center;gap:60px;position:relative;z-index:1}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:rgba(255,255,255,.25);border:1px solid rgba(255,255,255,.45);border-radius:999px;font-size:13px;font-weight:700;color:#fff;margin-bottom:22px;backdrop-filter:blur(8px)}
.hero-eyebrow span{width:8px;height:8px;border-radius:50%;background:#fff;display:block}
.hero h1{color:var(--navy);margin-bottom:20px}
.hero h1 em{font-style:normal;color:#fff;text-shadow:0 2px 8px rgba(20,40,60,.2)}
.hero-desc{font-size:18px;color:#1a3c1a;line-height:1.7;margin-bottom:32px;max-width:580px;font-weight:500}
.hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:32px}
.hero-trust{display:flex;flex-wrap:wrap;gap:10px}
.trust-chip{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.6);border-radius:999px;padding:7px 13px;font-size:13px;font-weight:700;color:var(--navy);backdrop-filter:blur(8px)}
.trust-chip::before{content:"✓";color:var(--green-dark);font-weight:900}
.hero-card{background:rgba(255,255,255,.92);border-radius:24px;padding:28px;box-shadow:0 24px 60px rgba(20,40,60,.18);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.8)}
.hc-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.hc-dots{display:flex;gap:6px}
.hc-dots span{width:10px;height:10px;border-radius:50%}
.hc-dots span:nth-child(1){background:#ff5f57}
.hc-dots span:nth-child(2){background:#febc2e}
.hc-dots span:nth-child(3){background:#28c840}
.hc-label{font-size:13px;font-weight:700;color:var(--muted)}
.hc-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.stat-box{background:var(--green-soft);border-radius:14px;padding:14px 16px}
.stat-box small{font-size:11.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:4px}
.stat-box strong{font-size:26px;font-weight:800;color:var(--navy);display:block;line-height:1}
.stat-box .trend{font-size:12px;color:var(--green-dark);font-weight:700;margin-top:4px}
.hc-tasks{background:var(--light);border-radius:14px;padding:14px 16px;margin-bottom:14px}
.hc-tasks-head{display:flex;justify-content:space-between;font-size:13px;font-weight:700;color:var(--navy);margin-bottom:12px}
.task-item{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border);font-size:13.5px;color:#344258}
.task-item:last-child{border-bottom:none}
.status-tag{font-size:11.5px;font-weight:700;padding:3px 10px;border-radius:999px}
.status-done{background:#d1fae5;color:#065f46}
.status-ready{background:var(--green-light);color:var(--green-dark)}
.status-ok{background:#fef9c3;color:#713f12}
.hc-badge{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--navy),var(--navy-mid));border-radius:14px;padding:12px 16px;color:#fff}
.hc-badge-icon{font-size:24px}
.hc-badge-text strong{display:block;font-size:13.5px;font-weight:800}
.hc-badge-text span{font-size:12px;color:rgba(255,255,255,.72)}

/* ═══════════════════════════════════════════
   8. STATS STRIP
═══════════════════════════════════════════ */
.stats-strip{background:var(--navy);padding:48px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);text-align:center}
.stat-item{padding:16px 24px;border-right:1px solid rgba(255,255,255,.1)}
.stat-item:last-child{border-right:none}
.stat-num{font-size:42px;font-weight:800;color:#7ee87e;letter-spacing:-.04em;line-height:1;margin-bottom:8px}
.stat-text{font-size:14px;color:rgba(255,255,255,.72);font-weight:500}

/* ═══════════════════════════════════════════
   9. SERVICES
═══════════════════════════════════════════ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service-card{border:1.5px solid var(--border);border-radius:var(--radius);padding:30px 28px;transition:all .2s;background:#fff}
.service-card:hover{border-color:var(--green);box-shadow:0 12px 36px rgba(40,160,40,.12);transform:translateY(-3px)}
.svc-icon{width:52px;height:52px;border-radius:14px;background:var(--green-light);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:18px}
.svc-link{font-size:13.5px;font-weight:700;color:var(--green-dark);display:inline-flex;align-items:center;gap:5px;margin-top:14px}

/* ═══════════════════════════════════════════
   10. SOFTWARE / QUICKBOOKS
═══════════════════════════════════════════ */
.software-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.check-list{display:grid;gap:12px;margin-bottom:28px}
.check-item{display:flex;gap:11px;align-items:flex-start;font-size:15px;font-weight:600;color:#2d3a4a}
.check-icon{width:22px;height:22px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;margin-top:1px}
.qbo-cards{display:grid;gap:14px}
.qbo-card{background:#fff;border-radius:16px;padding:18px 20px;border:1.5px solid var(--border);box-shadow:var(--shadow-sm);display:flex;gap:14px;align-items:flex-start}
.qbo-card-icon{width:42px;height:42px;border-radius:12px;background:var(--green-light);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.qbo-card-body h4{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:5px}
.qbo-card-body p{font-size:13.5px;color:var(--muted);line-height:1.6}

/* ═══════════════════════════════════════════
   11. PROCESS STEPS (Homepage)
═══════════════════════════════════════════ */
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;position:relative}
.process-steps::before{content:"";position:absolute;top:27px;left:14%;right:14%;height:2px;background:linear-gradient(90deg,var(--green),var(--green-light));z-index:0}
.step-card{text-align:center;position:relative;z-index:1}
.step-num{width:56px;height:56px;border-radius:50%;background:var(--green);color:#fff;font-size:20px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;box-shadow:0 8px 20px rgba(40,160,40,.28)}

/* ═══════════════════════════════════════════
   12. WHY US (Homepage)
═══════════════════════════════════════════ */
.why-us{background:var(--navy);color:#fff}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.why-list{display:grid;gap:18px}
.why-item{display:flex;gap:14px;align-items:flex-start}
.why-icon{width:44px;height:44px;border-radius:12px;background:rgba(40,160,40,.2);border:1px solid rgba(40,160,40,.3);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.why-creds{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cred-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);border-radius:16px;padding:18px;text-align:center;transition:all .2s}
.cred-card:hover{background:rgba(40,160,40,.15);border-color:rgba(40,160,40,.4);transform:translateY(-3px)}
.cred-icon{font-size:22px;margin-bottom:10px}
.cred-card h5{font-size:14px;font-weight:700;color:#7ee87e;margin-bottom:6px}
.cred-card p{font-size:13px;color:rgba(255,255,255,.62)}

/* ═══════════════════════════════════════════
   13. TESTIMONIALS
═══════════════════════════════════════════ */
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonial-card{background:var(--green-soft);border-radius:var(--radius);padding:28px;border:1.5px solid var(--border)}
.stars{color:#f59e0b;font-size:16px;letter-spacing:1px;margin-bottom:14px}
.testimonial-card blockquote{font-size:15px;color:#2d3a4a;line-height:1.7;margin-bottom:18px;font-style:italic}
.testimonial-author{display:flex;gap:12px;align-items:center}
.t-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--navy));display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;color:#fff;flex-shrink:0}
.author-info strong{font-size:14px;font-weight:700;color:var(--navy);display:block}
.author-info span{font-size:12.5px;color:var(--muted)}

/* ═══════════════════════════════════════════
   14. PRICING
═══════════════════════════════════════════ */
.pricing-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px}
.pricing-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);padding:30px 26px;text-align:center}
.pricing-card.featured{background:var(--navy);border-color:var(--navy);box-shadow:var(--shadow)}
.pricing-icon{font-size:36px;margin-bottom:14px}
.pricing-quote-block{background:var(--green-soft);border:1.5px solid var(--border);border-radius:22px;padding:38px 42px;display:grid;grid-template-columns:1fr auto;gap:32px;align-items:center}
.pricing-features{display:flex;gap:20px;flex-wrap:wrap;margin-top:14px}
.pricing-feat{display:flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:#2d3a4a}
.pricing-feat::before{content:"✓";color:var(--green-dark);font-weight:900}
.pricing-btns{display:flex;flex-direction:column;gap:12px;min-width:200px}

/* ═══════════════════════════════════════════
   15. FAQ ACCORDION
═══════════════════════════════════════════ */
.faq-wrap{max-width:860px;margin:0 auto;display:grid;gap:12px}
.faq-item{border:1.5px solid var(--border);border-radius:16px;overflow:hidden;background:#fff}
.faq-item.open{border-color:var(--green)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:18px 22px;background:#fff;border:none;font-size:16px;font-weight:700;color:var(--navy);text-align:left;cursor:pointer}
.faq-q svg{flex-shrink:0;transition:transform .2s}
.faq-item.open .faq-q svg{transform:rotate(180deg)}
.faq-a{display:none;padding:0 22px 18px;font-size:15px;color:var(--muted);line-height:1.7}
.faq-item.open .faq-a{display:block}

/* ═══════════════════════════════════════════
   16. FINAL CTA (Homepage)
═══════════════════════════════════════════ */
.final-cta{padding:84px 0;background:linear-gradient(135deg,var(--green),var(--green-dark));text-align:center;position:relative;overflow:hidden}
.final-cta::before{content:"";position:absolute;top:-60px;right:-60px;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.07)}
.final-cta h2{color:#fff;margin:0 auto 14px;max-width:700px;position:relative;z-index:1}
.final-cta p{color:rgba(255,255,255,.88);max-width:580px;margin:0 auto 32px;font-size:17.5px;position:relative;z-index:1}
.final-cta-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;position:relative;z-index:1}

/* ═══════════════════════════════════════════
   17. ABOUT US — STORY
═══════════════════════════════════════════ */
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.story-content h2{font-size:clamp(26px,3vw,38px);font-weight:800;color:var(--navy);letter-spacing:-0.03em;margin-bottom:18px;line-height:1.15}
.story-content p{font-size:16px;color:var(--muted);line-height:1.75;margin-bottom:16px}
.story-visual{display:grid;gap:16px}
.story-stat{background:var(--green-soft);border-radius:18px;padding:22px 24px;border:1.5px solid var(--border)}
.story-stat strong{font-size:38px;font-weight:800;color:var(--green-dark);display:block;line-height:1;margin-bottom:6px}
.story-stat span{font-size:15px;color:var(--navy);font-weight:600;display:block}
.story-stat p{font-size:13.5px;color:var(--muted);margin-top:4px}
.story-stats-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ═══════════════════════════════════════════
   18. ABOUT US — CREDENTIALS GRID (Dark bg)
═══════════════════════════════════════════ */
.credentials{background:var(--navy)}
.credentials .section-label{color:#7ee87e}
.credentials .section-head h2{color:#fff}
.credentials .section-head p{color:rgba(255,255,255,.7)}
.creds-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cred-cert{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);border-radius:18px;padding:22px 18px;text-align:center;transition:all .2s}
.cred-cert:hover{background:rgba(40,160,40,.15);border-color:rgba(40,160,40,.4);transform:translateY(-3px)}
.cred-badge{font-size:28px;margin-bottom:12px}
.cred-cert h4{font-size:14.5px;font-weight:700;color:#7ee87e;margin-bottom:8px;line-height:1.3}
.cred-cert p{font-size:13px;color:rgba(255,255,255,.62);line-height:1.55}

/* ═══════════════════════════════════════════
   19. ABOUT US — VALUES
═══════════════════════════════════════════ */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.value-card{background:#fff;border-radius:var(--radius);padding:28px;border:1.5px solid var(--border)}
.value-icon{width:50px;height:50px;border-radius:14px;background:var(--green-light);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:16px}
.value-card h3{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:10px}
.value-card p{font-size:14.5px;color:var(--muted);line-height:1.65}

/* ═══════════════════════════════════════════
   20. ABOUT US — TEAM
═══════════════════════════════════════════ */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.team-card{background:var(--green-soft);border-radius:var(--radius);padding:28px;border:1.5px solid var(--border);text-align:center}
.team-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--navy));display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:800;color:#fff;margin:0 auto 14px}
.team-card h4{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:4px}
.team-card .role{font-size:13.5px;color:var(--green-dark);font-weight:700;margin-bottom:10px}
.team-card p{font-size:14px;color:var(--muted);line-height:1.6}
.creds-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;margin-top:14px}
.cred-tag{font-size:11.5px;font-weight:700;background:var(--navy);color:#fff;border-radius:999px;padding:4px 10px}

/* ═══════════════════════════════════════════
   21. CTA STRIP (About Us bottom, green)
═══════════════════════════════════════════ */
.cta-strip{background:linear-gradient(135deg,var(--green),var(--green-dark));padding:64px 0;text-align:center}
.cta-strip h2{font-size:clamp(26px,3.5vw,38px);font-weight:800;color:#fff;letter-spacing:-0.03em;margin-bottom:14px}
.cta-strip p{font-size:17px;color:rgba(255,255,255,.88);max-width:560px;margin:0 auto 28px}
.cta-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.cta-btn-white{background:#fff;color:var(--green-dark);min-height:50px;padding:0 28px;border-radius:999px;font-size:15.5px;font-weight:800;display:inline-flex;align-items:center;gap:8px;box-shadow:0 10px 30px rgba(0,0,0,.12);transition:all .2s}
.cta-btn-white:hover{background:var(--green-soft);transform:translateY(-2px)}
.cta-btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.5);min-height:50px;padding:0 28px;border-radius:999px;font-size:15.5px;font-weight:700;display:inline-flex;align-items:center;gap:8px;transition:all .2s}
.cta-btn-outline:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.8)}

/* ═══════════════════════════════════════════
   22. CONTACT US
═══════════════════════════════════════════ */
.contact-layout{display:grid;grid-template-columns:1.15fr .85fr;gap:52px;align-items:start}
.form-card{background:#fff;border:1.5px solid var(--border);border-radius:24px;padding:38px 36px;box-shadow:var(--shadow)}
.form-title{font-size:22px;font-weight:800;color:var(--navy);margin-bottom:8px}
.form-subtitle{font-size:15px;color:var(--muted);margin-bottom:28px;line-height:1.6}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:13.5px;font-weight:700;color:var(--navy);margin-bottom:7px}
.form-group label .req{color:var(--green-dark);margin-left:2px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 15px;border:1.5px solid var(--border);border-radius:12px;font-size:15px;font-family:inherit;color:var(--text);background:#fff;transition:border-color .15s,box-shadow .15s;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(40,160,40,.1)}
.form-group textarea{min-height:110px;resize:vertical}
.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235a6a7a' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
.form-submit{width:100%;min-height:52px;background:var(--green);color:#fff;border:none;border-radius:999px;font-size:16px;font-weight:800;cursor:pointer;transition:all .2s;box-shadow:0 8px 24px rgba(40,160,40,.3)}
.form-submit:hover{background:var(--green-dark);transform:translateY(-1px)}
.form-note{font-size:12.5px;color:var(--muted);text-align:center;margin-top:12px}
.info-panel{display:grid;gap:18px}
.info-card{background:var(--green-soft);border:1.5px solid var(--border);border-radius:18px;padding:22px}
.info-card-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.info-icon{width:40px;height:40px;border-radius:12px;background:var(--green);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;color:#fff}
.info-card-head h4{font-size:15px;font-weight:700;color:var(--navy)}
.info-card p{font-size:14px;color:var(--muted);line-height:1.65}
.info-card a{color:var(--green-dark);font-weight:700}
.phone-big{font-size:20px;font-weight:800;color:var(--navy);display:block;margin-bottom:4px}
.hours-list{list-style:none;display:grid;gap:6px}
.hours-list li{display:flex;justify-content:space-between;font-size:13.5px;color:#344258;padding:6px 0;border-bottom:1px solid var(--border)}
.hours-list li:last-child{border-bottom:none}
.hours-list span{color:var(--muted)}
.response-badge{display:flex;align-items:center;gap:10px;background:var(--navy);border-radius:14px;padding:14px 16px}
.response-badge-icon{font-size:22px}
.response-badge-text strong{font-size:14px;font-weight:800;color:#7ee87e;display:block}
.response-badge-text span{font-size:12.5px;color:rgba(255,255,255,.7)}
.trust-list{list-style:none;display:grid;gap:8px}
.trust-list li{display:flex;align-items:center;gap:9px;font-size:13.5px;color:#2d3a4a;font-weight:600}
.trust-list li::before{content:"✓";color:var(--green-dark);font-weight:900;font-size:14px}

/* ═══════════════════════════════════════════
   23. BLOG LISTING
═══════════════════════════════════════════ */
.category-bar{padding:24px 0;background:var(--white);border-bottom:1px solid var(--border)}
.cats{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cat-btn{padding:8px 16px;border:1.5px solid var(--border);border-radius:999px;font-size:13.5px;font-weight:700;color:#344258;background:#fff;cursor:pointer;transition:all .15s}
.cat-btn:hover,.cat-btn.active{background:var(--green);color:#fff;border-color:var(--green)}
.blog-layout{display:grid;grid-template-columns:1fr 300px;gap:48px;align-items:start}
.featured-post{margin-bottom:48px}
.featured-post article{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center;background:var(--green-soft);border:1.5px solid var(--border);border-radius:24px;overflow:hidden;padding:36px}
.featured-img-wrap{border-radius:16px;overflow:hidden;background:linear-gradient(135deg,var(--green),var(--navy));height:220px;display:flex;align-items:center;justify-content:center;font-size:60px}
.featured-eyebrow{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.featured-tag{font-size:12px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--green-dark);background:var(--green-light);border-radius:999px;padding:4px 12px}
.featured-label{font-size:12px;font-weight:700;color:var(--muted)}
.featured-post h2{font-size:clamp(20px,2.5vw,26px);font-weight:800;color:var(--navy);letter-spacing:-0.03em;line-height:1.25;margin-bottom:12px}
.featured-post h2 a:hover{color:var(--green-dark)}
.featured-post p{font-size:15px;color:var(--muted);line-height:1.7;margin-bottom:18px}
.post-meta{display:flex;align-items:center;gap:14px;font-size:12.5px;color:var(--muted);margin-bottom:20px;flex-wrap:wrap}
.post-meta span{display:flex;align-items:center;gap:4px}
.read-more{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:700;color:var(--green-dark);border:2px solid var(--green);border-radius:999px;padding:9px 18px;transition:all .15s}
.read-more:hover{background:var(--green);color:#fff}
.posts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.post-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .2s}
.post-card:hover{border-color:var(--green);box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.post-card-thumb,.post-thumb{height:160px;background:linear-gradient(135deg,var(--green-soft),var(--green-light));display:flex;align-items:center;justify-content:center;font-size:42px}
.post-card-body,.post-body{padding:20px}
.post-cat{font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--green-dark);margin-bottom:8px}
.post-card h3{font-size:16px;font-weight:700;color:var(--navy);line-height:1.35;margin-bottom:8px}
.post-card h3 a:hover{color:var(--green-dark)}
.post-card p{font-size:13.5px;color:var(--muted);line-height:1.6;margin-bottom:14px}
.post-card-footer,.post-footer{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--muted);padding-top:12px;border-top:1px solid var(--border)}
.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:42px;flex-wrap:wrap}
.page-btn,.pagination .page-numbers{width:40px;height:40px;border-radius:10px;border:1.5px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#344258;cursor:pointer;transition:all .15s;text-decoration:none}
.page-btn.active,.page-btn:hover,.pagination .current,.pagination .page-numbers:hover{background:var(--green);color:#fff;border-color:var(--green)}

/* ═══════════════════════════════════════════
   24. BLOG SIDEBAR
═══════════════════════════════════════════ */
.sidebar{display:grid;gap:24px}
.sidebar-card{background:var(--green-soft);border:1.5px solid var(--border);border-radius:16px;padding:22px}
.sidebar-card h4{font-size:15px;font-weight:800;color:var(--navy);margin-bottom:14px;padding-bottom:10px;border-bottom:1.5px solid var(--border)}
.sidebar-card p{font-size:13.5px;color:var(--muted);line-height:1.6;margin-bottom:12px}
.sidebar-call-btn,.sidebar-cta-phone{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--green);color:#fff;border-radius:999px;padding:11px 18px;font-size:14px;font-weight:800;transition:all .15s;width:100%;margin-bottom:10px}
.sidebar-call-btn:hover,.sidebar-cta-phone:hover{background:var(--green-dark)}
.sidebar-secondary-btn,.sidebar-cta-consult{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--navy);color:#fff;border-radius:999px;padding:11px 18px;font-size:14px;font-weight:700;transition:all .15s;width:100%}
.sidebar-secondary-btn:hover,.sidebar-cta-consult:hover{background:var(--navy-mid)}
.cat-list{list-style:none;display:grid;gap:6px}
.cat-list li a{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:13.5px;font-weight:600;color:#344258;transition:color .15s}
.cat-list li:last-child a{border-bottom:none}
.cat-list a:hover{color:var(--green-dark)}
.cat-list .count{font-size:12px;color:var(--muted);background:#fff;border-radius:999px;padding:2px 8px}
.popular-list{list-style:none;display:grid;gap:14px}
.popular-list li a{font-size:13.5px;font-weight:600;color:#344258;line-height:1.45;transition:color .15s;display:block}
.popular-list li a:hover{color:var(--green-dark)}
.popular-list .meta{font-size:12px;color:var(--muted);margin-top:3px}

/* ═══════════════════════════════════════════
   25. BLOG POST — HERO
═══════════════════════════════════════════ */
.post-cat-tag{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--green-dark);background:var(--green-light);border-radius:999px;padding:5px 13px;margin-bottom:14px}
.post-meta-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap;font-size:13.5px;color:#2d4a2d;font-weight:600;margin-top:14px}
.post-meta-row .divider{color:rgba(20,40,60,.3)}

/* ═══════════════════════════════════════════
   26. BLOG POST — ARTICLE LAYOUT
═══════════════════════════════════════════ */
.article-layout{display:grid;grid-template-columns:1fr 280px;gap:52px;align-items:start}
.article-body{max-width:720px}
.article-intro{font-size:17.5px;color:#2d3a4a;line-height:1.75;margin-bottom:32px;padding:20px 22px;background:var(--green-soft);border-left:4px solid var(--green);border-radius:0 12px 12px 0;font-weight:500}
.article-body h2{font-size:24px;font-weight:800;color:var(--navy);letter-spacing:-0.03em;margin:40px 0 14px;padding-top:12px;border-top:2px solid var(--border);line-height:1.2}
.article-body h2:first-of-type{border-top:none;margin-top:0}
.article-body h3{font-size:18.5px;font-weight:700;color:var(--navy);margin:28px 0 12px}
.article-body h4{font-size:16px;font-weight:700;color:var(--navy);margin:20px 0 10px}
.article-body p{font-size:16px;color:#2d3a4a;line-height:1.78;margin-bottom:18px}
.article-body ul,.article-body ol{margin:0 0 20px 20px}
.article-body li{font-size:15.5px;color:#2d3a4a;line-height:1.7;margin-bottom:8px}
.article-body strong{color:var(--navy);font-weight:700}
.article-body a{color:var(--green-dark);text-decoration:underline;text-underline-offset:3px}
.article-body a:hover{color:var(--navy)}

/* ═══════════════════════════════════════════
   27. BLOG POST — CALLOUTS & STEP BLOCKS
═══════════════════════════════════════════ */
.callout{border-radius:14px;padding:18px 20px;margin:28px 0}
.callout-tip{background:var(--green-soft);border:1.5px solid var(--green-light)}
.callout-tip::before{content:"💡 Pro Tip: ";font-weight:800;color:var(--green-dark)}
.callout-warning{background:#fffbeb;border:1.5px solid #fde68a}
.callout-warning::before{content:"⚠️ Watch Out: ";font-weight:800;color:#92400e}
.callout p{font-size:15px;color:#2d3a4a;line-height:1.7;margin:0;display:inline}
.steps{display:grid;gap:20px;margin:24px 0}
.step{display:flex;gap:16px;align-items:flex-start}
.step-num{width:34px;height:34px;border-radius:50%;background:var(--green);color:#fff;font-size:15px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.step-body h4{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:6px}
.step-body p{font-size:15px;color:var(--muted);line-height:1.65;margin:0}
.key-takeaways{background:var(--navy);border-radius:18px;padding:26px 28px;margin:36px 0}
.key-takeaways h4{font-size:16px;font-weight:800;color:#7ee87e;margin-bottom:14px}
.key-takeaways ul{list-style:none;display:grid;gap:10px;margin:0;padding:0}
.key-takeaways li{font-size:15px;color:rgba(255,255,255,.85);display:flex;gap:9px;align-items:flex-start}
.key-takeaways li::before{content:"✓";color:#7ee87e;font-weight:900;flex-shrink:0}
.inline-cta{background:linear-gradient(135deg,var(--green),var(--green-dark));border-radius:18px;padding:28px;margin:36px 0;text-align:center}
.inline-cta h4{font-size:18px;font-weight:800;color:#fff;margin-bottom:8px}
.inline-cta p{font-size:14.5px;color:rgba(255,255,255,.85);margin-bottom:16px}
.inline-cta-btns{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.icta-white{background:#fff;color:var(--green-dark);border-radius:999px;padding:10px 22px;font-size:14px;font-weight:800;display:inline-flex;align-items:center;gap:6px;transition:all .15s}
.icta-white:hover{background:var(--green-soft)}
.icta-outline{border:2px solid rgba(255,255,255,.5);color:#fff;border-radius:999px;padding:10px 22px;font-size:14px;font-weight:700;display:inline-flex;align-items:center;gap:6px;transition:all .15s}
.icta-outline:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.8)}

/* ═══════════════════════════════════════════
   28. BLOG POST — AUTHOR & RELATED
═══════════════════════════════════════════ */
.author-box{display:flex;gap:20px;align-items:flex-start;background:var(--green-soft);border:1.5px solid var(--border);border-radius:18px;padding:24px;margin:44px 0 0}
.author-box-avatar,.author-avatar-block{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--navy));display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;color:#fff;flex-shrink:0}
.author-info h4,.author-box-info h4{font-size:16px;font-weight:800;color:var(--navy);margin-bottom:3px}
.author-role{font-size:13px;color:var(--green-dark);font-weight:700;margin-bottom:8px}
.author-box-info p,.author-info p{font-size:14px;color:var(--muted);line-height:1.65}
.author-social{display:flex;gap:8px;margin-top:10px}
.author-social a{font-size:12.5px;font-weight:700;color:var(--green-dark);border:1.5px solid var(--border);border-radius:999px;padding:4px 12px;transition:all .15s}
.author-social a:hover{background:var(--green);color:#fff;border-color:var(--green)}
.related-posts{padding:52px 0;background:var(--light)}
.related-posts h2{font-size:24px;font-weight:800;color:var(--navy);margin-bottom:28px}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.related-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .2s}
.related-card:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.related-thumb{height:130px;background:linear-gradient(135deg,var(--green-soft),var(--green-light));display:flex;align-items:center;justify-content:center;font-size:36px}
.related-body{padding:18px}
.related-cat{font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--green-dark);margin-bottom:6px}
.related-body h4{font-size:15px;font-weight:700;color:var(--navy);line-height:1.35;margin-bottom:8px}
.related-body h4 a:hover{color:var(--green-dark)}
.related-meta{font-size:12.5px;color:var(--muted)}

/* ═══════════════════════════════════════════
   29. BLOG POST — SIDEBAR (TOC + share)
═══════════════════════════════════════════ */
.article-sidebar{display:grid;gap:22px;position:sticky;top:96px}
.toc-list{list-style:none;display:grid;gap:4px;padding:0;margin:0}
.toc-list li a{font-size:13.5px;color:#344258;display:block;padding:6px 10px;border-radius:8px;font-weight:600;transition:all .15s;line-height:1.4}
.toc-list li a:hover{background:var(--green-light);color:var(--green-dark)}
.toc-list li.active a{background:var(--green);color:#fff}
.share-btns{display:flex;gap:8px}
.share-btn{flex:1;text-align:center;padding:9px 10px;border:1.5px solid var(--border);border-radius:10px;font-size:12.5px;font-weight:700;color:#344258;background:#fff;transition:all .15s}
.share-btn:hover{border-color:var(--green);color:var(--green-dark)}

/* ═══════════════════════════════════════════
   30. FOOTER
═══════════════════════════════════════════ */
.site-footer{background:var(--navy-dark);color:rgba(255,255,255,.7);padding:64px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;margin-bottom:48px}
.footer-brand img{height:40px;margin-bottom:14px;filter:brightness(0) invert(1);opacity:.9}
.footer-brand p{font-size:14px;line-height:1.7;margin-bottom:18px}
.footer-social{display:flex;gap:10px}
.social-icon{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:16px;transition:background .15s}
.social-icon:hover{background:var(--green)}
.footer-col h5{font-size:13.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#fff;margin-bottom:16px}
.footer-col ul{list-style:none;display:grid;gap:9px}
.footer-col li{font-size:14px}
.footer-col a{color:rgba(255,255,255,.65);transition:color .15s}
.footer-col a:hover{color:#7ee87e}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:28px;border-top:1px solid rgba(255,255,255,.1);font-size:13px}
.footer-bottom a{color:rgba(255,255,255,.5)}
.footer-bottom a:hover{color:#7ee87e}

/* ═══════════════════════════════════════════
   31. RESPONSIVE
═══════════════════════════════════════════ */
@media(max-width:1024px){
  .hero-grid,.software-grid,.why-grid,.story-grid,.contact-layout{grid-template-columns:1fr}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .process-steps{grid-template-columns:repeat(2,1fr)}
  .process-steps::before{display:none}
  .creds-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .pricing-quote-block{grid-template-columns:1fr}
  .blog-layout{grid-template-columns:1fr}
  .article-layout{grid-template-columns:1fr}
  .article-sidebar{position:static}
  .related-grid{grid-template-columns:repeat(2,1fr)}
  .sidebar{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .contact-layout{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:768px){
  .site-nav{display:none}
  .mobile-toggle{display:flex}
  .site-nav.open{display:flex;flex-direction:column;position:absolute;top:76px;left:0;right:0;background:#fff;padding:16px 20px 24px;border-bottom:1px solid var(--border);box-shadow:0 12px 30px rgba(0,0,0,.1);gap:4px;z-index:99}
  .site-nav.open a{padding:10px 0;border-bottom:1px solid var(--border);font-size:15px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
  .services-grid,.testimonial-grid,.team-grid,.values-grid,.why-creds,.pricing-cards{grid-template-columns:1fr}
  .featured-post article{grid-template-columns:1fr;padding:22px}
  .posts-grid{grid-template-columns:1fr}
  .related-grid{grid-template-columns:1fr}
  .sidebar{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .form-card{padding:24px 20px}
  .author-box{flex-direction:column}
  section{padding:56px 0}
  .hero-stats-row{gap:20px}
}
@media(max-width:480px){
  .hero-actions,.final-cta-actions,.cta-actions,.inline-cta-btns{flex-direction:column;align-items:stretch}
  .btn-lg{width:100%;justify-content:center}
  .cta-btn-white,.cta-btn-outline{justify-content:center}
}
