:root{
  --bg:#0b0f10;
  --card:#0f1517;
  --text:#d9e5e7;
  --muted:#9fb2b6;
  --mint:#41d6a3;
  --mint-pressed:#2bbd8d;
  --stroke:#1b2427;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif}
a{color:inherit}

.site-header,.site-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--stroke)}
.site-footer{border-top:1px solid var(--stroke);border-bottom:none;margin-top:40px;justify-content:center}
.brand{display:flex;align-items:center;font-weight:700;text-decoration:none;gap:10px}
.brand-dot{width:18px;height:18px;border-radius:6px;background:var(--mint);display:inline-block}
.top-nav{display:flex;align-items:center;gap:10px}
.top-nav a{text-decoration:none}
.top-nav .navlink{padding:8px 12px;border-radius:10px;border:1px solid var(--stroke);color:var(--text);font-weight:500}
.top-nav .navlink:hover{background:#0e1416;border-color:var(--muted)}

.site-main{max-width:1100px;margin:0 auto;padding:32px 20px}

.hero{padding:56px 0;animation:fadeIn 1s ease-out}
.hero-tags{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.chip{padding:6px 10px;border:1px solid var(--stroke);border-radius:999px;background:transparent;color:var(--muted);font-size:.9rem}

h1{font-size:3rem;line-height:1.1;margin:0 0 12px}
h2{font-size:1.35rem;line-height:1.3;margin:18px 0 8px}
h3{font-size:1.05rem;margin:8px 0 4px}
.lead{color:var(--muted);font-size:1.125rem;max-width:900px;line-height:1.55}
p{line-height:1.55}

.hero-bullets{display:flex;gap:12px;flex-wrap:wrap;margin:18px 0 28px}
.pill{padding:10px 14px;border:1px solid var(--stroke);border-radius:12px;background:#0e1416}

.cta-row,.ctas{display:flex;gap:12px;flex-wrap:wrap}

.btn{display:inline-block;padding:12px 16px;border-radius:12px;text-decoration:none;border:1px solid var(--stroke);font-weight:600;transition:all .2s ease}
.btn.small{padding:8px 12px;border-radius:10px}
.btn.xl{padding:14px 18px;border-radius:14px}
.btn.primary{background:var(--mint);color:#073326;border-color:var(--mint)}
.btn.primary:hover{box-shadow:0 0 12px rgba(0,255,200,.3);transform:translateY(-1px)}
.btn.primary:active{background:var(--mint-pressed)}
.btn.secondary{background:#222;color:#fff;border-color:#222}
.btn.outline{background:transparent;color:var(--text)}
.btn.outline:hover{background:#0e1416}

/* For /ql page compatibility */
.panel{padding:16px 0}
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.card{border:1px solid var(--stroke);border-radius:12px;padding:12px;background:var(--card)}
.bullet{padding-left:18px}
.bullet li{margin:6px 0}
.steps{padding-left:18px}
.muted{color:var(--muted)}
.note{font-size:0.95rem;color:var(--muted)}

@keyframes fadeIn{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}

@media (max-width: 520px){
  h1{font-size:2.2rem}
  .btn.xl{width:100%;text-align:center}
  .grid-3{grid-template-columns:1fr}
  .top-nav{flex-wrap:wrap;justify-content:flex-end}
}

/* — Epoxy homeowner polish — */
.fade-in{animation:fadeIn 1s ease-out}

.before-after{max-width:900px;margin:24px auto}
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ba-item{position:relative;border:1px solid var(--stroke);border-radius:12px;overflow:hidden}
.ba-item img{width:100%;height:auto;display:block}
.ba-label{position:absolute;top:12px;left:12px;background:rgba(15,21,23,0.9);color:var(--muted);padding:6px 12px;border-radius:8px;font-size:0.9rem;font-weight:600}

@media (max-width:640px){
  .ba-grid{grid-template-columns:1fr;gap:12px}
}

form input,form textarea{
  width:100%;padding:12px;border-radius:10px;border:1px solid var(--stroke);
  background:var(--card);color:var(--text);margin:8px 0;font-family:inherit;font-size:1rem
}
form button.btn{width:100%}
details{margin:12px 0;cursor:pointer}
details summary{font-weight:600;padding:8px 0}
details p{padding-left:12px;color:var(--muted)}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

@media (max-width:520px){
  .btn{min-height:48px;font-size:1rem}
  .cta-row .btn{width:100%}
}

/* — Service Areas & DC enhancements — */
.service-areas-grid{padding:24px 0}
.city-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.city-link{display:block;background:var(--card);border:1px solid var(--stroke);border-radius:10px;padding:14px;text-decoration:none;color:var(--text);transition:all .2s ease}
.city-link:hover{border-color:var(--mint);background:#0e1416}

.service-areas-cta{text-align:center;padding:32px 0;border-top:1px solid var(--stroke);margin-top:32px}

.dc-local{margin:32px 0}
.dc-local details{margin:12px 0}

.zip-finder{margin:32px 0;padding:24px;background:var(--card);border:1px solid var(--stroke);border-radius:12px}
.zip-form{display:flex;gap:8px;margin-top:12px}
.zip-form input{flex:1;max-width:200px;min-width:140px;padding:12px;border-radius:10px;border:1px solid var(--stroke);background:var(--card);color:var(--text);font-size:1rem}
.zip-form button{white-space:nowrap}

.internal-links{margin:24px 0;padding:16px 0;border-top:1px solid var(--stroke)}
.internal-links a{text-decoration:underline;color:var(--mint)}

.footer-content{text-align:center}
.footer-nav{margin:8px 0}
.footer-nav a{text-decoration:none;color:var(--text)}
.footer-nav a:hover{color:var(--mint)}

@media (max-width:640px){
  .city-list{grid-template-columns:1fr}
  .zip-form{flex-direction:column}
  .zip-form input{max-width:100%}
}