/* ============================================================
   WALDORF PAVERS — SHARED STYLESHEET
   Design: Option 2 — Navy & Brass
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700;800&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#0F2044;
  --navy-mid:#1A3260;
  --navy-light:#2A4880;
  --dark:#0F2044;
  --brass:#B8860B;
  --brass-light:#D4A017;
  --brass-pale:#FBF6E7;
  --brass-border:#E8D080;
  --blue-pale:#EEF3FA;
  --blue-border:#C0D0E8;
  --white:#FFFFFF;
  --warm-white:#FAFAFA;
  --gray:#4A5568;
  --gray-mid:#2D3748;
  --border:#D1DCF0;
  --light:#F4F7FC;
}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--dark);background:var(--warm-white);line-height:1.6;font-size:16px}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}

/* ---- HEADER ---- */
header{position:sticky;top:0;z-index:1000;background:var(--navy);box-shadow:0 2px 16px rgba(15,32,68,0.35)}
.header-inner{display:flex;align-items:center;height:64px;gap:20px}
.logo{font-size:1.125rem;font-weight:800;color:#fff;white-space:nowrap;flex-shrink:0;letter-spacing:-0.3px}
.logo span{color:var(--brass-light);font-style:italic}
nav{display:flex;align-items:center;gap:2px;flex:1}
nav a{font-size:0.8125rem;font-weight:500;color:rgba(255,255,255,0.6);padding:6px 10px;border-radius:4px;white-space:nowrap;transition:all 0.15s}
nav a:hover,nav a.active{color:#fff;background:rgba(255,255,255,0.08)}
.header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}
.header-phone{display:flex;flex-direction:column;align-items:flex-end}
.header-phone a{font-size:1.25rem;font-weight:800;color:#FCD34D;letter-spacing:0.2px;white-space:nowrap}
.header-phone small{font-size:0.625rem;color:rgba(255,255,255,0.4);letter-spacing:0.06em;text-transform:uppercase}
.header-cta{background:var(--brass);color:#fff;font-size:0.8125rem;font-weight:700;padding:9px 16px;border-radius:4px;white-space:nowrap;transition:background 0.15s;flex-shrink:0}
.header-cta:hover{background:var(--brass-light)}

/* ---- HERO ---- */
.hero{background:var(--warm-white);border-bottom:1px solid var(--border);padding:64px 0}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.hero-eyebrow{font-size:0.6875rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--brass);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.hero-eyebrow::before{content:'';width:24px;height:2px;background:var(--brass);display:inline-block}
.hero h1{font-size:clamp(1.875rem,4vw,2.875rem);font-weight:900;color:var(--navy);line-height:1.1;letter-spacing:-0.5px;margin-bottom:16px}
.hero h1 em{color:var(--brass);font-style:normal}
.hero-sub{font-size:1.0625rem;color:var(--gray);margin-bottom:28px;line-height:1.7;max-width:480px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}
.btn-primary{background:var(--navy);color:#fff;font-size:1rem;font-weight:700;padding:14px 24px;border-radius:4px;display:inline-flex;align-items:center;gap:8px;transition:all 0.15s;border:none;cursor:pointer;white-space:nowrap}
.btn-primary:hover{background:var(--navy-mid);transform:translateY(-1px)}
.btn-brass{background:var(--brass);color:#fff;font-size:1rem;font-weight:700;padding:14px 24px;border-radius:4px;display:inline-flex;align-items:center;gap:8px;transition:all 0.15s;border:none;cursor:pointer;white-space:nowrap}
.btn-brass:hover{background:var(--brass-light);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--navy);border:2px solid var(--border);font-size:0.9375rem;font-weight:600;padding:13px 24px;border-radius:4px;display:inline-flex;align-items:center;gap:8px;transition:all 0.15s}
.btn-outline:hover{border-color:var(--navy);background:var(--light)}
.hero-trust{display:flex;gap:16px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:6px;font-size:0.8125rem;color:var(--gray-mid);font-weight:500}
.trust-item::before{content:'✓';color:var(--brass);font-weight:800;font-size:0.875rem}
.hero-image{position:relative;border-radius:10px;overflow:hidden;box-shadow:0 20px 48px rgba(15,32,68,0.2)}
.hero-image img{width:100%;height:460px;object-fit:cover;display:block}

/* ---- TRUST BAR ---- */
.trust-bar{background:#fff;border-bottom:1px solid var(--border);padding:20px 0;box-shadow:0 1px 4px rgba(0,0,0,0.04)}
.trust-bar-inner{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.trust-badge{display:flex;align-items:center;gap:10px}
.trust-icon{width:38px;height:38px;border-radius:50%;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;font-size:1.125rem;flex-shrink:0}
.trust-name{font-size:0.875rem;font-weight:700;color:var(--navy);display:block}
.trust-sub{font-size:0.75rem;color:var(--gray);display:block}

/* ---- SECTIONS ---- */
section{padding:64px 0}
.section-alt{background:#fff}
.section-navy{background:var(--navy)}
.eyebrow{font-size:0.6875rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--brass);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.eyebrow::before{content:'';width:20px;height:2px;background:var(--brass);display:inline-block}
h2{font-size:clamp(1.5rem,3vw,2.125rem);font-weight:800;color:var(--navy);line-height:1.15;letter-spacing:-0.3px;margin-bottom:8px}
.section-sub{font-size:1rem;color:var(--gray);margin-bottom:36px;max-width:560px;line-height:1.7}
p{color:var(--gray);line-height:1.75}

/* ---- SERVICE CARDS ---- */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:36px}
.svc-card{background:#fff;border:1px solid var(--border);border-radius:8px;padding:24px;transition:all 0.2s;border-top:3px solid transparent}
.svc-card:hover{box-shadow:0 8px 24px rgba(15,32,68,0.1);transform:translateY(-2px);border-top-color:var(--brass)}
.svc-card.featured{background:var(--blue-pale);border-color:var(--blue-border);border-top-color:var(--navy)}
.svc-icon{font-size:2rem;margin-bottom:12px}
.svc-card h3{font-size:1.0625rem;font-weight:700;color:var(--navy);margin-bottom:6px}
.svc-card p{font-size:0.875rem;line-height:1.6;margin-bottom:10px}
.svc-price{font-size:0.8125rem;font-weight:600;color:var(--brass)}
.svc-badge{display:inline-block;font-size:0.5625rem;padding:2px 6px;background:var(--brass);color:#fff;border-radius:2px;font-weight:700;letter-spacing:0.06em;margin-left:6px;vertical-align:middle}
.svc-link{font-size:0.8125rem;font-weight:600;color:var(--navy);display:inline-flex;align-items:center;gap:4px;margin-top:10px}
.svc-link:hover{text-decoration:underline}

/* ---- WHY US ---- */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-top:36px}
.why-card{text-align:center;padding:20px 16px}
.why-icon{font-size:2.25rem;margin-bottom:12px}
.why-card h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:6px}
.why-card p{font-size:0.875rem}

/* ---- PROCESS ---- */
.process-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:0;margin-top:36px;position:relative}
.process-step{padding:24px 20px;text-align:center;position:relative}
.step-num{width:44px;height:44px;border-radius:50%;background:var(--navy);color:#fff;font-size:1.125rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.step-title{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:6px}
.step-desc{font-size:0.875rem;color:var(--gray)}

/* ---- SERVICE AREAS ---- */
.area-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;margin-top:28px}
.area-tag{background:#fff;border:1px solid var(--border);border-radius:4px;padding:10px 12px;font-size:0.875rem;color:var(--gray);display:flex;align-items:center;gap:6px;transition:all 0.15s}
.area-tag:hover{border-color:var(--brass);color:var(--brass)}
.area-tag::before{content:'📍';font-size:0.75rem}

/* ---- FAQ ---- */
.faq-list{margin-top:28px;display:flex;flex-direction:column;gap:10px}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.faq-q{width:100%;background:none;border:none;cursor:pointer;padding:16px 20px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;text-align:left}
.faq-q-text{font-size:0.9375rem;font-weight:600;color:var(--navy);display:flex;gap:10px;align-items:flex-start}
.faq-q-text::before{content:'Q';background:var(--navy);color:#fff;min-width:20px;height:20px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:0.6875rem;font-weight:800;margin-top:1px;flex-shrink:0}
.faq-a{padding:0 20px 16px 50px;font-size:0.9375rem;color:var(--gray);line-height:1.7}

/* ---- PRICING ---- */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin:28px 0}
.price-card{background:#fff;border:1px solid var(--border);border-radius:8px;padding:20px;text-align:center}
.price-card.featured{border-color:var(--brass-border);background:var(--brass-pale);border-top:3px solid var(--brass)}
.price-label{font-size:0.875rem;font-weight:600;color:var(--gray-mid);margin-bottom:8px}
.price-range{font-size:1.5rem;font-weight:900;color:var(--navy);line-height:1.1;margin-bottom:4px}
.price-note{font-size:0.75rem;color:var(--gray)}

/* ---- CTA SECTION ---- */
.cta-section{background:var(--navy);padding:72px 0;text-align:center}
.cta-section h2{color:#fff;margin-bottom:8px}
.cta-section .section-sub{color:rgba(255,255,255,0.55);margin:0 auto 32px}
.cta-phone{font-size:2.25rem;font-weight:900;color:var(--brass-light);display:block;margin-bottom:4px;letter-spacing:0.3px}
.cta-available{font-size:0.75rem;color:rgba(255,255,255,0.35);margin-bottom:24px;letter-spacing:0.06em;text-transform:uppercase}
.cta-or{font-size:0.8125rem;color:rgba(255,255,255,0.3);margin:20px auto;display:flex;align-items:center;gap:16px;max-width:480px}
.cta-or::before,.cta-or::after{content:'';flex:1;height:1px;background:rgba(255,255,255,0.1)}

/* ---- CONTACT FORM ---- */
.contact-form{max-width:480px;margin:0 auto;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:8px;padding:28px;text-align:left}
.form-row{margin-bottom:14px}
.form-row label{display:block;font-size:0.75rem;font-weight:700;color:rgba(255,255,255,0.5);margin-bottom:5px;letter-spacing:0.06em;text-transform:uppercase}
.form-row input,.form-row select,.form-row textarea{width:100%;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);color:#fff;padding:11px 13px;border-radius:4px;font-size:0.9375rem;font-family:inherit;transition:border-color 0.15s}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--brass-light)}
.form-row textarea{height:88px;resize:vertical}
.form-row select option{background:var(--navy);color:#fff}
.form-submit{width:100%;background:var(--brass);color:#fff;border:none;padding:14px;border-radius:4px;font-size:1rem;font-weight:700;cursor:pointer;transition:background 0.15s;font-family:inherit}
.form-submit:hover{background:var(--brass-light)}
.form-note{font-size:0.75rem;color:rgba(255,255,255,0.3);text-align:center;margin-top:10px;line-height:1.5}

/* ---- PAGE HERO ---- */
.page-hero{background:var(--light);border-bottom:1px solid var(--border);padding:48px 0 40px}
.page-hero .eyebrow{margin-bottom:8px}
.page-hero h1{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:900;color:var(--navy);line-height:1.15;letter-spacing:-0.4px;margin-bottom:14px}
.page-hero .lead{font-size:1.0625rem;color:var(--gray);max-width:600px;line-height:1.7;margin-bottom:24px}
.page-hero-btns{display:flex;gap:12px;flex-wrap:wrap}

/* ---- BREADCRUMB ---- */
.breadcrumb{padding:12px 0;font-size:0.8125rem;color:var(--gray)}
.breadcrumb a{color:var(--brass)}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb span{margin:0 6px;color:var(--border)}

/* ---- PROSE ---- */
.prose h2{margin:32px 0 12px}
.prose h3{font-size:1.125rem;font-weight:700;color:var(--navy);margin:24px 0 8px}
.prose p{margin-bottom:16px}
.prose ul{margin:0 0 16px 20px}
.prose ul li{color:var(--gray);font-size:0.9375rem;line-height:1.7;margin-bottom:6px}
.prose ul li::marker{color:var(--brass)}

/* ---- FOOTER ---- */
footer{background:#081428;padding:48px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;margin-bottom:36px}
.footer-logo{font-size:1.125rem;font-weight:800;color:#fff;margin-bottom:10px}
.footer-logo span{color:var(--brass-light);font-style:italic}
.footer-nap{font-size:0.875rem;color:rgba(255,255,255,0.4);line-height:1.9}
.footer-head{font-size:0.6875rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:rgba(255,255,255,0.25);margin-bottom:14px}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links a{font-size:0.875rem;color:rgba(255,255,255,0.45);transition:color 0.15s}
.footer-links a:hover{color:var(--brass-light)}
.footer-bottom{padding-top:24px;border-top:1px solid rgba(255,255,255,0.06);display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}
.footer-copy{font-size:0.75rem;color:rgba(255,255,255,0.2)}
.footer-legal{font-size:0.75rem;color:rgba(255,255,255,0.2);max-width:580px;line-height:1.55}
.footer-legal a{color:rgba(255,255,255,0.35);text-decoration:underline}

/* ---- MOBILE ---- */
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:32px}
  .hero-image{max-height:340px}
  .hero-image img{height:340px}
  .footer-grid{grid-template-columns:1fr 1fr}
  nav{display:none}
}
@media(max-width:600px){
  .hero{padding:40px 0}
  section{padding:44px 0}
  .footer-grid{grid-template-columns:1fr}
  .trust-bar-inner{gap:14px}
  .header-phone small{display:none}
  .header-cta{padding:8px 12px;font-size:0.75rem}
}
