/* ============================================================
   ULTIMATE CLEANING SERVICE — Redesign 2026
   Shared Design System
   ============================================================ */

/* ===== RESET & VARIABLES ===== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --cream: #F5F0EB;
  --cream-dark: #EDE7DF;
  --warm-white: #FDFBF9;
  --charcoal: #1A1A1A;
  --charcoal-light: #2D2D2D;
  --taupe: #8B7E74;
  --taupe-light: #A89F97;
  --gold: #C4A265;
  --gold-light: #D4B87A;
  --white: #FFFFFF;
  --border: rgba(0,0,0,0.06);
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --radius: 8px;
  --radius-lg: 16px;
  /* Angi accent */
  --angi: #39B54A;
}

html { scroll-behavior:smooth; }
body {
  font-family: var(--sans);
  color: var(--charcoal);
  background: var(--warm-white);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ===== ANIMATIONS ===== */
@keyframes fadeUp { from { opacity:0; transform:translateY(40px); } to { opacity:1; transform:translateY(0); } }
@keyframes letterReveal { from { opacity:0; letter-spacing:0.3em; } to { opacity:1; letter-spacing:0.15em; } }
@keyframes scaleIn { from { opacity:0; transform:scale(0.92); } to { opacity:1; transform:scale(1); } }

.reveal { opacity:0; transform:translateY(40px); transition: opacity 0.8s cubic-bezier(.25,.46,.45,.94), transform 0.8s cubic-bezier(.25,.46,.45,.94); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-left { opacity:0; transform:translateX(-60px); transition: opacity 0.8s ease, transform 0.8s ease; }
.reveal-left.visible { opacity:1; transform:translateX(0); }
.reveal-right { opacity:0; transform:translateX(60px); transition: opacity 0.8s ease, transform 0.8s ease; }
.reveal-right.visible { opacity:1; transform:translateX(0); }
.stagger-1 { transition-delay:0.1s; } .stagger-2 { transition-delay:0.2s; }
.stagger-3 { transition-delay:0.3s; } .stagger-4 { transition-delay:0.4s; }
.stagger-5 { transition-delay:0.5s; } .stagger-6 { transition-delay:0.6s; }

/* ===== LAYOUT ===== */
.container { max-width:1200px; margin:0 auto; padding:0 24px; }
.container-narrow { max-width:760px; margin:0 auto; padding:0 24px; }
.section { padding:100px 0; }
.section-alt { background:var(--cream); }

/* ===== TOP BAR ===== */
.top-bar { background:var(--charcoal); color:rgba(255,255,255,.7); padding:10px 0; font-size:13px; letter-spacing:.02em; }
.top-bar .container { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; }
.top-bar a { color:var(--gold-light); text-decoration:none; font-weight:600; transition:color .3s; }
.top-bar a:hover { color:var(--white); }
.tb-badges { display:flex; gap:20px; font-size:12px; }

/* ===== HEADER ===== */
.header { background:var(--warm-white); position:sticky; top:0; z-index:1000; transition:box-shadow .4s ease, background .4s ease; border-bottom:1px solid var(--border); }
.header.scrolled { background:rgba(253,251,249,.95); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); box-shadow:0 4px 30px rgba(0,0,0,.04); }
.header .container { display:flex; align-items:center; justify-content:space-between; padding-top:16px; padding-bottom:16px; }
.logo { text-decoration:none; display:flex; align-items:center; gap:12px; }
.logo-icon { width:48px; height:48px; background:var(--charcoal); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--gold); font-size:18px; font-weight:700; font-family:var(--serif); }
.logo-text { display:flex; flex-direction:column; }
.logo-name { font-family:var(--serif); font-size:26px; font-weight:700; color:var(--charcoal); line-height:1; }
.logo-tag { font-size:10px; color:var(--taupe); text-transform:uppercase; letter-spacing:.15em; font-weight:500; margin-top:3px; }
.nav { display:flex; align-items:center; gap:4px; }
.nav a { color:var(--taupe); text-decoration:none; font-weight:500; font-size:14px; padding:8px 14px; border-radius:6px; transition:all .3s ease; position:relative; }
.nav a::after { content:''; position:absolute; bottom:4px; left:50%; width:0; height:1px; background:var(--charcoal); transition:all .3s ease; transform:translateX(-50%); }
.nav a:hover { color:var(--charcoal); }
.nav a:hover::after { width:60%; }
.nav-phone { color:var(--charcoal)!important; font-weight:700!important; font-size:15px!important; }
.nav-cta { background:var(--charcoal)!important; color:var(--warm-white)!important; font-weight:600!important; padding:10px 22px!important; border-radius:6px!important; transition:all .4s ease!important; }
.nav-cta:hover { background:var(--gold)!important; color:var(--charcoal)!important; transform:translateY(-1px); }
.nav-cta::after { display:none!important; }
.hamburger { display:none; background:none; border:none; cursor:pointer; padding:8px; }
.hamburger span { display:block; width:24px; height:1.5px; background:var(--charcoal); margin:6px 0; border-radius:2px; transition:.3s; }

/* ===== BUTTONS ===== */
.btn-p { background:var(--charcoal); color:var(--warm-white); padding:16px 36px; border-radius:6px; font-size:15px; font-weight:600; text-decoration:none; display:inline-flex; align-items:center; gap:10px; transition:all .4s cubic-bezier(.25,.46,.45,.94); letter-spacing:.02em; }
.btn-p:hover { background:var(--gold); color:var(--charcoal); transform:translateY(-2px); box-shadow:0 12px 40px rgba(196,162,101,.25); }
.btn-o { border:1.5px solid var(--charcoal); color:var(--charcoal); padding:15px 32px; border-radius:6px; font-size:15px; font-weight:600; text-decoration:none; transition:all .4s ease; background:transparent; letter-spacing:.02em; }
.btn-o:hover { background:var(--charcoal); color:var(--warm-white); transform:translateY(-2px); }
.btn-sm { padding:12px 24px; font-size:14px; }
.btn-gold { background:var(--gold); color:var(--charcoal); }
.btn-gold:hover { background:var(--gold-light); color:var(--charcoal); }

/* ===== HERO ===== */
.hero { background:var(--cream); padding:0; position:relative; overflow:hidden; min-height:85vh; display:flex; align-items:center; }
.hero::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg, var(--cream) 0%, var(--cream-dark) 50%, rgba(196,162,101,.08) 100%); z-index:1; }
.hero .container { position:relative; z-index:2; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; padding-top:60px; padding-bottom:60px; }
.hero-content { max-width:560px; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.15em; color:var(--taupe); margin-bottom:28px; animation:letterReveal 1s ease forwards; }
.hero-badge::before { content:''; width:40px; height:1px; background:var(--gold); }
.hero h1 { font-family:var(--serif); font-size:56px; font-weight:600; color:var(--charcoal); line-height:1.1; margin-bottom:24px; animation:fadeUp 1s .2s ease both; }
.hero h1 .hl { color:var(--gold); font-style:italic; }
.hero-sub { font-size:17px; color:var(--taupe); line-height:1.8; margin-bottom:36px; max-width:480px; animation:fadeUp 1s .4s ease both; }
.hero-stars { display:flex; align-items:center; gap:10px; margin-bottom:32px; animation:fadeUp 1s .5s ease both; }
.stars { color:var(--gold); font-size:18px; letter-spacing:3px; }
.star-text { color:var(--taupe-light); font-size:13px; font-weight:500; }
.hero-ctas { display:flex; gap:16px; flex-wrap:wrap; animation:fadeUp 1s .6s ease both; }
.hero-img { border-radius:var(--radius-lg); overflow:hidden; box-shadow:0 30px 80px rgba(0,0,0,.12); animation:scaleIn 1.2s .3s ease both; position:relative; }
.hero-img img { width:100%; height:520px; object-fit:cover; display:block; transition:transform 8s ease; }
.hero-img:hover img { transform:scale(1.05); }

/* Hero — city page variant (smaller) */
.hero-city { min-height:auto; padding:60px 0 80px; }
.hero-city h1 { font-size:48px; }
.hero-city .hero-img img { height:420px; }

/* Hero — centered variant (blog, toolkit) */
.hero-centered { text-align:center; }
.hero-centered .container { display:block; }
.hero-centered .hero-content { max-width:700px; margin:0 auto; }
.hero-centered .hero-sub { margin-left:auto; margin-right:auto; }
.hero-centered .hero-ctas { justify-content:center; }

/* ===== PROOF / TRUST BAR ===== */
.trust-bar { background:var(--white); padding:48px 0; border-bottom:1px solid var(--border); }
.trust-items { display:grid; grid-template-columns:repeat(4,1fr); gap:40px; text-align:center; }
.trust-item { display:flex; flex-direction:column; align-items:center; gap:12px; transition:transform .4s ease; }
.trust-item:hover { transform:translateY(-4px); }
.trust-icon { width:52px; height:52px; border:1.5px solid var(--charcoal); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:22px; transition:all .4s ease; }
.trust-item:hover .trust-icon { background:var(--charcoal); color:var(--warm-white); border-color:var(--charcoal); }
.trust-item h4 { font-family:var(--serif); font-size:18px; font-weight:600; color:var(--charcoal); }
.trust-item p { font-size:13px; color:var(--taupe); }

/* Inline proof badges (city pages) */
.proof-row { display:flex; gap:24px; flex-wrap:wrap; margin-bottom:28px; animation:fadeUp 1s .45s ease both; }
.proof-badge { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--taupe); font-weight:500; }
.proof-badge .proof-icon { width:36px; height:36px; border:1.5px solid var(--border); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:16px; }

/* ===== STATS ===== */
.stats-section { background:var(--charcoal); padding:70px 0; position:relative; overflow:hidden; }
.stats-section::before { content:''; position:absolute; top:-50%; left:-10%; width:120%; height:200%; background:radial-gradient(ellipse at center, rgba(196,162,101,.06) 0%, transparent 70%); }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:40px; text-align:center; position:relative; }
.stat-item h3 { font-family:var(--serif); font-size:56px; color:var(--gold); font-weight:600; line-height:1; margin-bottom:8px; }
.stat-item p { color:rgba(255,255,255,.5); font-size:12px; font-weight:500; text-transform:uppercase; letter-spacing:.15em; }

/* ===== SECTION HEADERS ===== */
.sh { text-align:center; margin-bottom:20px; }
.sl { display:inline-flex; align-items:center; gap:12px; color:var(--taupe); font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.15em; margin-bottom:16px; }
.sl::before, .sl::after { content:''; width:30px; height:1px; background:var(--gold); }
.st { font-family:var(--serif); font-size:44px; color:var(--charcoal); font-weight:600; line-height:1.15; margin-bottom:16px; }
.sd { font-size:16px; color:var(--taupe); max-width:600px; margin:0 auto; line-height:1.7; }

/* ===== SERVICES GRID ===== */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:56px; }
.sc { background:var(--white); border-radius:var(--radius-lg); overflow:hidden; transition:all .5s cubic-bezier(.25,.46,.45,.94); border:1px solid var(--border); }
.sc:hover { transform:translateY(-12px); box-shadow:0 20px 60px rgba(0,0,0,.08); }
.si { height:220px; overflow:hidden; position:relative; }
.si::after { content:''; position:absolute; bottom:0; left:0; right:0; height:60px; background:linear-gradient(to top, rgba(255,255,255,.8), transparent); pointer-events:none; }
.si img { width:100%; height:100%; object-fit:cover; transition:transform .8s cubic-bezier(.25,.46,.45,.94); }
.sc:hover .si img { transform:scale(1.08); }
.sb { padding:28px 28px 32px; }
.sb h3 { font-family:var(--serif); font-size:24px; color:var(--charcoal); font-weight:600; margin-bottom:10px; }
.sb p { color:var(--taupe); font-size:14px; line-height:1.7; margin-bottom:20px; }
.slink { color:var(--charcoal); font-weight:600; text-decoration:none; font-size:13px; text-transform:uppercase; letter-spacing:.1em; display:inline-flex; align-items:center; gap:8px; transition:all .3s ease; }
.slink::after { content:''; width:24px; height:1px; background:var(--charcoal); transition:width .3s ease; }
.slink:hover { color:var(--gold); }
.slink:hover::after { width:40px; background:var(--gold); }

/* Services list variant (city pages, 2-col) */
.services-list { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-top:48px; }
.svc-card { background:var(--white); padding:28px; border-radius:var(--radius); border:1px solid var(--border); transition:all .4s ease; display:flex; gap:16px; align-items:flex-start; }
.svc-card:hover { transform:translateY(-4px); box-shadow:0 8px 30px rgba(0,0,0,.06); border-color:var(--gold); }
.svc-card .svc-icon { width:44px; height:44px; min-width:44px; border:1.5px solid var(--border); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:18px; transition:all .4s ease; }
.svc-card:hover .svc-icon { background:var(--charcoal); border-color:var(--charcoal); color:var(--warm-white); }
.svc-card h4 { font-family:var(--serif); font-size:20px; color:var(--charcoal); font-weight:600; margin-bottom:4px; }
.svc-card p { color:var(--taupe); font-size:14px; line-height:1.6; }

/* ===== WHY US ===== */
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; margin-top:56px; }
.why-image { border-radius:var(--radius-lg); overflow:hidden; position:relative; box-shadow:0 20px 60px rgba(0,0,0,.1); }
.why-image img { width:100%; height:520px; object-fit:cover; display:block; transition:transform .8s ease; }
.why-image:hover img { transform:scale(1.03); }
.why-badge { position:absolute; bottom:28px; left:28px; background:var(--white); color:var(--charcoal); padding:18px 24px; border-radius:var(--radius); font-weight:600; font-size:14px; display:flex; align-items:center; gap:12px; box-shadow:0 8px 30px rgba(0,0,0,.1); }
.why-badge .num { font-family:var(--serif); font-size:40px; color:var(--gold); line-height:1; font-weight:600; }
.why-list { display:flex; flex-direction:column; gap:28px; }
.wi { display:flex; gap:20px; align-items:flex-start; padding:20px; border-radius:var(--radius); transition:all .4s ease; }
.wi:hover { background:var(--cream); }
.wi-icon { width:48px; height:48px; min-width:48px; border:1.5px solid var(--border); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:20px; transition:all .4s ease; }
.wi:hover .wi-icon { background:var(--charcoal); border-color:var(--charcoal); filter:grayscale(1) brightness(5); }
.wi h4 { font-family:var(--serif); font-size:20px; color:var(--charcoal); font-weight:600; margin-bottom:4px; }
.wi p { color:var(--taupe); font-size:14px; }

/* Why — card grid variant (city pages, 3-col) */
.why-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
.wc { background:var(--white); padding:32px; border-radius:var(--radius-lg); border:1px solid var(--border); transition:all .4s ease; text-align:center; }
.wc:hover { transform:translateY(-6px); box-shadow:0 12px 40px rgba(0,0,0,.06); }
.wc .wc-icon { width:52px; height:52px; border:1.5px solid var(--border); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:22px; margin:0 auto 16px; transition:all .4s ease; }
.wc:hover .wc-icon { background:var(--charcoal); border-color:var(--charcoal); color:var(--warm-white); }
.wc h4 { font-family:var(--serif); font-size:20px; color:var(--charcoal); font-weight:600; margin-bottom:8px; }
.wc p { color:var(--taupe); font-size:14px; line-height:1.6; }

/* ===== TESTIMONIALS ===== */
.tg { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:56px; }
.tc { background:var(--white); border-radius:var(--radius-lg); padding:36px; border:1px solid var(--border); transition:all .4s ease; position:relative; }
.tc:hover { transform:translateY(-6px); box-shadow:0 16px 50px rgba(0,0,0,.06); }
.tc::before { content:'\201C'; font-family:var(--serif); font-size:80px; color:var(--gold); opacity:.2; position:absolute; top:16px; left:28px; line-height:1; }
.t-stars { color:var(--gold); font-size:15px; letter-spacing:3px; margin-bottom:20px; }
.t-text { color:var(--charcoal-light); font-size:15px; line-height:1.8; margin-bottom:24px; font-style:italic; }
.t-author { display:flex; align-items:center; gap:14px; }
.t-avatar { width:44px; height:44px; border-radius:50%; background:var(--charcoal); display:flex; align-items:center; justify-content:center; color:var(--warm-white); font-weight:600; font-size:14px; }
.t-author h5 { font-family:var(--serif); font-size:17px; color:var(--charcoal); font-weight:600; }
.t-author span { font-size:12px; color:var(--taupe-light); }

/* ===== ABOUT ===== */
.about-grid { display:grid; grid-template-columns:1fr 1.2fr; gap:80px; align-items:center; margin-top:56px; }
.about-photo { position:relative; border-radius:var(--radius-lg); overflow:hidden; box-shadow:0 20px 60px rgba(0,0,0,.1); }
.about-photo img { width:100%; height:540px; object-fit:cover; object-position:center top; display:block; transition:transform .8s ease; }
.about-photo:hover img { transform:scale(1.03); }
.about-overlay { position:absolute; bottom:0; left:0; right:0; padding:28px 32px; background:linear-gradient(to top, rgba(26,26,26,.9), transparent); color:var(--white); }
.about-overlay h4 { font-family:var(--serif); font-size:24px; font-weight:600; }
.about-overlay p { font-size:13px; color:rgba(255,255,255,.6); }
.about-content h3 { font-family:var(--serif); font-size:38px; color:var(--charcoal); font-weight:600; margin-bottom:24px; line-height:1.2; }
.about-content p { color:var(--taupe); font-size:15px; line-height:1.8; margin-bottom:16px; }
.about-hl { background:var(--cream); border-left:3px solid var(--gold); padding:24px 28px; border-radius:0 var(--radius) var(--radius) 0; margin:28px 0; }
.about-hl p { font-family:var(--serif); color:var(--charcoal)!important; font-weight:500; font-size:19px!important; font-style:italic; margin:0!important; }

/* ===== NEIGHBORHOODS (city pages) ===== */
.nbh-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:48px; }
.nbh-card { background:var(--white); padding:24px; border-radius:var(--radius); text-align:center; border:1px solid var(--border); transition:all .4s ease; }
.nbh-card:hover { border-color:var(--gold); transform:translateY(-4px); box-shadow:0 8px 30px rgba(0,0,0,.06); }
.nbh-card h4 { font-family:var(--serif); font-size:18px; color:var(--charcoal); font-weight:600; }
.nbh-detail { margin-top:48px; }
.nbh-detail h3 { font-family:var(--serif); font-size:28px; color:var(--charcoal); font-weight:600; margin-bottom:12px; }
.nbh-detail p { color:var(--taupe); font-size:15px; line-height:1.8; margin-bottom:16px; }

/* ===== AREAS ===== */
.areas-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:56px; }
.ac { background:var(--white); padding:28px; border-radius:var(--radius); text-align:center; border:1px solid var(--border); transition:all .4s ease; display:block; text-decoration:none; color:inherit; }
.ac:hover { border-color:var(--gold); transform:translateY(-4px); box-shadow:0 8px 30px rgba(0,0,0,.06); }
.ac h4 { font-family:var(--serif); font-size:20px; color:var(--charcoal); font-weight:600; margin-bottom:4px; }
.ac p { font-size:12px; color:var(--taupe-light); text-transform:uppercase; letter-spacing:.1em; }
.areas-map { margin-top:32px; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border); }

/* ===== FAQ ===== */
.faq-list { max-width:800px; margin:56px auto 0; }
.fi { border:1px solid var(--border); border-radius:var(--radius); margin-bottom:12px; overflow:hidden; transition:all .3s ease; }
.fi:hover { border-color:rgba(0,0,0,.12); }
.fq { padding:22px 28px; display:flex; justify-content:space-between; align-items:center; cursor:pointer; font-family:var(--serif); font-weight:600; font-size:19px; color:var(--charcoal); background:var(--white); border:none; width:100%; text-align:left; }
.fq .icon { font-size:20px; color:var(--gold); transition:transform .4s ease; min-width:24px; text-align:center; }
.fi.open .fq .icon { transform:rotate(45deg); }
.fa { padding:0 28px; max-height:0; overflow:hidden; transition:all .4s cubic-bezier(.25,.46,.45,.94); }
.fi.open .fa { max-height:200px; padding:0 28px 24px; }
.fa p { color:var(--taupe); font-size:15px; line-height:1.8; }

/* ===== BLOG CARDS ===== */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:56px; }
.blog-card { background:var(--white); border-radius:var(--radius-lg); overflow:hidden; text-decoration:none; color:inherit; border:1px solid var(--border); transition:all .4s ease; }
.blog-card:hover { transform:translateY(-6px); box-shadow:0 16px 50px rgba(0,0,0,.06); }
.blog-card .blog-img { height:200px; overflow:hidden; }
.blog-card .blog-img img { width:100%; height:100%; object-fit:cover; transition:transform .8s ease; }
.blog-card:hover .blog-img img { transform:scale(1.06); }
.blog-card .blog-body { padding:28px; }
.blog-card .blog-date { font-size:12px; color:var(--taupe-light); text-transform:uppercase; letter-spacing:.1em; }
.blog-card .blog-cat { display:inline-block; background:var(--cream); color:var(--taupe); font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.1em; padding:4px 12px; border-radius:4px; margin-bottom:8px; }
.blog-card h3 { font-family:var(--serif); font-size:22px; color:var(--charcoal); font-weight:600; margin:10px 0; line-height:1.3; }
.blog-card p { color:var(--taupe); font-size:14px; line-height:1.6; }
.blog-card .blog-link { display:inline-flex; align-items:center; gap:8px; color:var(--charcoal); font-weight:600; font-size:12px; text-transform:uppercase; letter-spacing:.1em; margin-top:16px; }
.blog-card .blog-link::after { content:''; width:20px; height:1px; background:var(--charcoal); transition:width .3s ease; }
.blog-card:hover .blog-link::after { width:36px; }

/* Blog list variant (blog index) */
.blog-list { display:flex; flex-direction:column; gap:24px; margin-top:48px; }
.blog-list-card { display:grid; grid-template-columns:320px 1fr; gap:32px; background:var(--white); border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border); transition:all .4s ease; text-decoration:none; color:inherit; }
.blog-list-card:hover { transform:translateY(-4px); box-shadow:0 12px 40px rgba(0,0,0,.06); }
.blog-list-card .blog-img { overflow:hidden; }
.blog-list-card .blog-img img { width:100%; height:100%; object-fit:cover; transition:transform .8s ease; min-height:220px; }
.blog-list-card:hover .blog-img img { transform:scale(1.05); }
.blog-list-card .blog-body { padding:32px 32px 32px 0; display:flex; flex-direction:column; justify-content:center; }

/* Blog post content */
.post-header { padding:60px 0 40px; text-align:center; }
.breadcrumb { display:flex; gap:8px; justify-content:center; margin-bottom:24px; font-size:13px; }
.breadcrumb a { color:var(--taupe); text-decoration:none; transition:color .3s; }
.breadcrumb a:hover { color:var(--gold); }
.breadcrumb span { color:var(--taupe-light); }
.post-header h1 { font-family:var(--serif); font-size:48px; color:var(--charcoal); font-weight:600; line-height:1.15; margin-bottom:20px; }
.post-meta { display:flex; gap:16px; justify-content:center; align-items:center; font-size:13px; color:var(--taupe); }
.post-hero-img { max-width:1000px; margin:0 auto; border-radius:var(--radius-lg); overflow:hidden; }
.post-hero-img img { width:100%; height:400px; object-fit:cover; display:block; }
.post-content { padding:48px 0 80px; }
.post-content h2 { font-family:var(--serif); font-size:32px; color:var(--charcoal); font-weight:600; margin:40px 0 16px; }
.post-content h3 { font-family:var(--serif); font-size:26px; color:var(--charcoal); font-weight:600; margin:32px 0 12px; }
.post-content p { color:var(--taupe); font-size:16px; line-height:1.8; margin-bottom:16px; }
.post-content ul, .post-content ol { color:var(--taupe); font-size:16px; line-height:1.8; margin-bottom:16px; padding-left:24px; }
.post-content li { margin-bottom:8px; }
.post-content blockquote { background:var(--cream); border-left:3px solid var(--gold); padding:20px 24px; border-radius:0 var(--radius) var(--radius) 0; margin:24px 0; font-family:var(--serif); font-size:19px; font-style:italic; color:var(--charcoal); }

/* ===== TOOLKIT CARDS ===== */
.toolkit-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
.toolkit-card { background:var(--white); padding:32px; border-radius:var(--radius-lg); border:1px solid var(--border); transition:all .4s ease; text-align:center; }
.toolkit-card:hover { transform:translateY(-6px); box-shadow:0 12px 40px rgba(0,0,0,.06); border-color:var(--gold); }
.toolkit-card .tk-icon { font-size:32px; margin-bottom:16px; }
.toolkit-card h4 { font-family:var(--serif); font-size:20px; color:var(--charcoal); font-weight:600; margin-bottom:8px; }
.toolkit-card p { color:var(--taupe); font-size:14px; line-height:1.6; margin-bottom:20px; }

/* ===== CTA SECTION ===== */
.cta-section { background:var(--charcoal); padding:100px 0; position:relative; overflow:hidden; text-align:center; }
.cta-section::before { content:''; position:absolute; top:-50%; right:-20%; width:80%; height:200%; background:radial-gradient(ellipse at center, rgba(196,162,101,.05) 0%, transparent 70%); }
.cta-section h2 { font-family:var(--serif); font-size:46px; color:var(--white); font-weight:600; margin-bottom:16px; position:relative; }
.cta-section > .container > p { color:rgba(255,255,255,.5); font-size:16px; text-align:center; margin-bottom:48px; position:relative; }
.cta-btns { display:flex; justify-content:center; gap:16px; flex-wrap:wrap; position:relative; }

/* Quote form in CTA */
.quote-layout { display:grid; grid-template-columns:1fr 1fr; gap:48px; text-align:left; align-items:start; position:relative; }
.quote-form { background:rgba(255,255,255,.04); backdrop-filter:blur(10px); border:1px solid rgba(255,255,255,.08); border-radius:var(--radius-lg); padding:40px; }
.quote-form h3 { font-family:var(--serif); font-size:26px; color:var(--white); font-weight:600; margin-bottom:8px; }
.quote-form .form-sub { color:rgba(255,255,255,.4); font-size:14px; margin-bottom:28px; }
.quote-form label { display:block; color:rgba(255,255,255,.5); font-size:11px; font-weight:600; margin-bottom:6px; text-transform:uppercase; letter-spacing:.1em; }
.quote-form input, .quote-form select, .quote-form textarea { width:100%; padding:14px 18px; border:1px solid rgba(255,255,255,.1); border-radius:var(--radius); background:rgba(255,255,255,.04); color:var(--white); font-size:15px; font-family:var(--sans); margin-bottom:18px; transition:all .3s ease; box-sizing:border-box; }
.quote-form input::placeholder, .quote-form textarea::placeholder { color:rgba(255,255,255,.25); }
.quote-form input:focus, .quote-form select:focus, .quote-form textarea:focus { outline:none; border-color:var(--gold); background:rgba(255,255,255,.07); box-shadow:0 0 0 3px rgba(196,162,101,.15); }
.quote-form select { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23888' d='M6 8L0 0h12z'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center; cursor:pointer; }
.quote-form select option { background:var(--charcoal); color:var(--white); }
.quote-form .form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.quote-form button { width:100%; padding:16px; background:var(--gold); color:var(--charcoal); border:none; border-radius:var(--radius); font-size:15px; font-weight:700; cursor:pointer; transition:all .4s ease; margin-top:6px; letter-spacing:.02em; }
.quote-form button:hover { background:var(--gold-light); transform:translateY(-2px); box-shadow:0 8px 30px rgba(196,162,101,.3); }
.quote-or { display:flex; flex-direction:column; gap:24px; align-items:center; justify-content:center; }
.phone-block { background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08); border-radius:var(--radius-lg); padding:36px; width:100%; text-align:center; }
.phone-block h3 { font-family:var(--serif); font-size:24px; color:var(--white); font-weight:600; margin-bottom:12px; }
.phone-block p { color:rgba(255,255,255,.4); font-size:14px; margin-bottom:24px; line-height:1.7; }
.quote-success { display:none; text-align:center; padding:40px 20px; }
.quote-success h3 { font-family:var(--serif); font-size:28px; color:var(--white); margin-bottom:12px; }
.quote-success p { color:rgba(255,255,255,.5); font-size:16px; line-height:1.6; }

/* ===== FOOTER ===== */
.footer { background:var(--charcoal); color:rgba(255,255,255,.4); padding:72px 0 36px; border-top:1px solid rgba(255,255,255,.05); }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:48px; }
.footer h4 { font-family:var(--serif); color:var(--white); font-size:18px; font-weight:600; margin-bottom:24px; }
.footer a { color:rgba(255,255,255,.4); text-decoration:none; font-size:14px; transition:color .3s ease; }
.footer a:hover { color:var(--gold); }
.fl { display:flex; flex-direction:column; gap:12px; }
.fc { display:flex; flex-direction:column; gap:14px; }
.fc a { display:flex; align-items:center; gap:10px; font-size:14px; }
.fb { border-top:1px solid rgba(255,255,255,.06); margin-top:56px; padding-top:28px; display:flex; justify-content:space-between; font-size:12px; color:rgba(255,255,255,.25); }

/* ===== MOBILE CTA BAR ===== */
.mobile-cta { display:none; position:fixed; bottom:0; left:0; right:0; background:var(--white); padding:12px 16px; box-shadow:0 -4px 30px rgba(0,0,0,.08); z-index:999; gap:8px; }
.mobile-cta a { flex:1; text-align:center; padding:14px; border-radius:var(--radius); font-weight:700; font-size:14px; text-decoration:none; }
.mc-call { background:var(--charcoal); color:var(--warm-white); }
.mc-quote { background:var(--gold); color:var(--charcoal); }

/* ===== CALCULATOR (page-specific) ===== */
.calc-card { background:var(--white); border-radius:var(--radius-lg); padding:48px; max-width:720px; margin:0 auto; border:1px solid var(--border); box-shadow:0 8px 40px rgba(0,0,0,.04); }
.calc-card h2 { font-family:var(--serif); font-size:28px; color:var(--charcoal); font-weight:600; margin-bottom:8px; }
.calc-card .calc-sub { color:var(--taupe); font-size:14px; margin-bottom:32px; }
.progress-bar { height:4px; background:var(--cream); border-radius:2px; margin-bottom:32px; overflow:hidden; }
.progress-fill { height:100%; background:var(--gold); border-radius:2px; transition:width .4s ease; }
.steps-nav { display:flex; gap:8px; margin-bottom:32px; }
.step-tab { padding:8px 16px; border-radius:6px; font-size:13px; font-weight:600; color:var(--taupe-light); background:var(--cream); border:none; cursor:pointer; transition:all .3s ease; }
.step-tab.active { background:var(--charcoal); color:var(--warm-white); }
.calc-label { display:block; font-size:13px; font-weight:600; color:var(--charcoal); margin-bottom:8px; text-transform:uppercase; letter-spacing:.05em; }
.calc-input { width:100%; padding:14px 18px; border:1px solid var(--border); border-radius:var(--radius); font-size:15px; font-family:var(--sans); margin-bottom:20px; transition:all .3s ease; background:var(--warm-white); }
.calc-input:focus { outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(196,162,101,.15); }
.option-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:20px; }
.option-btn { padding:14px; border:1.5px solid var(--border); border-radius:var(--radius); background:var(--white); text-align:center; cursor:pointer; transition:all .3s ease; font-size:14px; font-weight:500; }
.option-btn:hover { border-color:var(--gold); }
.option-btn.selected { border-color:var(--gold); background:rgba(196,162,101,.08); color:var(--charcoal); font-weight:600; }

/* ===== ANGI LANDING (page-specific) ===== */
.angi-bar { background:linear-gradient(90deg, var(--angi), #2da83c); color:var(--white); padding:10px 0; font-size:13px; text-align:center; font-weight:600; }
.angi-hero .hero-badge { color:var(--angi); }
.angi-hero .hero-badge::before { background:var(--angi); }
.offer-strip { background:var(--white); padding:48px 0; border-bottom:1px solid var(--border); }
.offer-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.offer-card { background:var(--cream); padding:28px; border-radius:var(--radius); text-align:center; border:2px solid transparent; transition:all .4s ease; }
.offer-card:hover { border-color:var(--angi); transform:translateY(-4px); }
.offer-card h4 { font-family:var(--serif); font-size:20px; color:var(--charcoal); font-weight:600; margin-bottom:8px; }
.offer-card p { color:var(--taupe); font-size:14px; }

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .hero .container{grid-template-columns:1fr;text-align:center;gap:40px}
  .hero h1{font-size:42px}.hero-content{max-width:100%}.hero-sub{margin:0 auto 36px}
  .hero-ctas{justify-content:center}.hero-img{max-width:500px;margin:0 auto}.hero-img img{height:360px}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid,.about-grid{grid-template-columns:1fr}
  .tg{grid-template-columns:1fr 1fr}.stats-grid{grid-template-columns:repeat(2,1fr);gap:32px}
  .areas-grid,.nbh-grid{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:1fr 1fr}
  .blog-grid{grid-template-columns:1fr}.blog-list-card{grid-template-columns:1fr}
  .st{font-size:36px}.why-cards{grid-template-columns:repeat(2,1fr)}
  .services-list{grid-template-columns:1fr}.offer-grid{grid-template-columns:1fr}
  .toolkit-grid{grid-template-columns:repeat(2,1fr)}.proof-row{justify-content:center}
}
@media(max-width:768px){
  .top-bar .container{flex-direction:column;text-align:center;gap:4px}.tb-badges{display:none}
  .nav{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--white);padding:20px;box-shadow:0 10px 40px rgba(0,0,0,.08);border-top:1px solid var(--border)}
  .nav.open{display:flex}.hamburger{display:block}
  .hero{min-height:auto;padding:40px 0}.hero h1{font-size:36px}.hero-city h1{font-size:34px}
  .section{padding:72px 0}.services-grid,.tg,.why-cards{grid-template-columns:1fr}
  .areas-grid,.nbh-grid{grid-template-columns:repeat(2,1fr)}
  .quote-layout{grid-template-columns:1fr}.quote-form .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}.fb{flex-direction:column;gap:8px;text-align:center}
  .mobile-cta{display:flex}.cta-section h2{font-size:34px}.stat-item h3{font-size:42px}
  .post-header h1{font-size:34px}.toolkit-grid{grid-template-columns:1fr}
  .option-grid{grid-template-columns:repeat(2,1fr)}.calc-card{padding:28px}
}
