/* generic_hp — static category-domain homepage. Matches the reference visual
   design at docs/superpowers/specs/2026-06-25-generic-hp-reference.html. */
:root{
  --ink:#1f2733; --muted:#5b6675; --line:#e6e9ef; --bg:#ffffff;
  --soft:#f6f8fb; --brand:#2f6df0; --brand-dark:#1f4fbf; --star:#f5a623;
  --maxw:1080px;
}
*{box-sizing:border-box;}
body{margin:0;font-family:"Open Sans",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
a{color:var(--brand);text-decoration:none;}
a:hover{text-decoration:underline;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px;}
h1,h2,h3,h4{color:var(--ink);line-height:1.25;margin:0 0 .5em;}
section{padding:56px 0;}
section:nth-child(even){background:var(--soft);}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line);}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:64px;}
.brand-logo{font-size:1.25rem;font-weight:800;letter-spacing:.2px;color:var(--ink);}
.site-nav{display:flex;gap:22px;}
.site-nav a{color:var(--muted);font-weight:600;font-size:.95rem;}
.nav-toggle{display:none;background:none;border:0;font-size:1.4rem;cursor:pointer;color:var(--ink);}

/* Hero */
.hero{background:linear-gradient(180deg,#eef3fb 0%,#ffffff 100%);text-align:center;padding:72px 0;}
.hero h1{font-size:2.4rem;font-weight:800;margin-bottom:.2em;}
.hero .hero-sub{font-size:1.3rem;font-weight:700;color:var(--brand-dark);margin-bottom:1em;}
.hero p{max-width:760px;margin:0 auto .8em;color:var(--muted);font-size:1.05rem;}

/* Generic section heading */
.section-title{text-align:center;font-size:1.8rem;font-weight:800;margin-bottom:.4em;}
.section-intro{text-align:center;max-width:760px;margin:0 auto 2em;color:var(--muted);}

/* About */
.about p{max-width:840px;margin:0 auto 1em;color:var(--muted);}

/* Services grid */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.card-item{background:#fff;border:1px solid var(--line);border-radius:12px;padding:26px 22px;
  box-shadow:0 1px 3px rgba(16,24,40,.04);}
.card-item h3{font-size:1.1rem;margin-bottom:.5em;}
.card-item p{color:var(--muted);margin:0;font-size:.95rem;}

/* FAQ */
.faq{max-width:820px;margin:0 auto;}
.faq-item{border:1px solid var(--line);border-radius:10px;margin-bottom:12px;background:#fff;overflow:hidden;}
.faq-q{width:100%;text-align:left;background:none;border:0;padding:18px 20px;font-size:1.02rem;
  font-weight:700;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;}
.faq-q::after{content:"+";font-size:1.4rem;color:var(--brand);margin-left:12px;}
.faq-item.open .faq-q::after{content:"\2013";}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease;color:var(--muted);}
.faq-item.open .faq-a{max-height:400px;}
.faq-a p{padding:0 20px 18px;margin:0;}

/* Reviews */
.reviews{text-align:center;}
.review-track{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:1.5em;}
.review-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:24px 20px;text-align:left;}
.review-stars{color:var(--star);letter-spacing:2px;margin-bottom:.6em;}
.review-card .quote{color:var(--ink);font-style:italic;margin-bottom:1em;}
.review-name{font-weight:800;color:var(--ink);}
.review-loc{color:var(--muted);font-size:.9rem;}

/* Footer */
.site-footer{background:#13202f;color:#c4cdd9;padding:40px 0 28px;}
.site-footer a{color:#c4cdd9;}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:0 20px;text-align:center;}
.site-footer .footer-links{display:flex;flex-wrap:wrap;gap:8px 22px;justify-content:center;margin-bottom:18px;}
.site-footer .footer-disclaimer{font-size:.85rem;color:#8a97a8;max-width:820px;margin:0 auto;}

@media (max-width:860px){
  .cards,.review-track{grid-template-columns:1fr 1fr;}
}
@media (max-width:640px){
  .cards,.review-track{grid-template-columns:1fr;}
  .site-nav{display:none;position:absolute;top:64px;left:0;right:0;background:#fff;flex-direction:column;
    gap:0;border-bottom:1px solid var(--line);padding:8px 0;}
  .site-nav.open{display:flex;}
  .site-nav a{padding:12px 20px;}
  .nav-toggle{display:block;}
  .hero h1{font-size:1.8rem;}
}
