/* ============ TruFoam Base Styles ============ */
:root{
  --brand:#0ea5e9;        /* primary CTA blue (adjust to match your brand) */
  --brand-2:#4e9be0;      /* secondary button gradient end */
  --ink:#1f2937;          /* headings */
  --text:#444b55;         /* body text */
  --muted:#6b7280;        /* muted labels */
  --bg:#f7f8fb;           /* page background */
  --card:#ffffff;         /* card background */
  --accent:#f9fafb;       /* light backgrounds */
  --ring:rgba(14,165,233,.35);
  --shadow:0 10px 30px rgba(2,8,23,.08);
  --radius:18px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Poppins, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
}

/* Typography */
h1,h2,h3,h4{color:var(--ink);margin:0 0 10px}
h1{font-size:clamp(34px,5vw,52px);line-height:1.12;font-weight:800;letter-spacing:-.02em}
h2{font-size:clamp(26px,3.6vw,36px);font-weight:800}
h3{font-size:clamp(18px,2.4vw,22px);font-weight:700}
p{margin:0 0 12px}
.small{font-size:14px;color:var(--muted)}

/* Layout */
.container{max-width:1180px;margin:0 auto;padding:0 22px}
.section{padding:56px 0}
.section.tight{padding:28px 0}
.grid{display:grid;gap:22px}
.cards{display:grid;gap:22px;grid-template-columns:repeat(3,1fr)}
@media (max-width:980px){.cards{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.cards{grid-template-columns:1fr}}

.card{
  background:var(--card);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:22px;
  border:1px solid #eef1f6;
}

/* Header / Nav */
.navbar{
  position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid #eef1f6;
}
.navbar .inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img{height:28px}
.navlinks{display:flex;gap:18px;align-items:center}
.navlinks a{
  color:var(--ink);text-decoration:none;font-weight:600;opacity:.9
}
.navlinks a:hover{opacity:1}
.book-btn{margin-left:8px}
.menu-toggle{display:none}
@media (max-width:960px){
  .menu-toggle{display:block;border:0;background:#fff}
  .navlinks{position:fixed;inset:68px 0 auto 0;background:#fff;padding:18px 22px;display:none;flex-direction:column;border-bottom:1px solid #eef1f6}
  .navlinks.open{display:flex}
}

/* Buttons */
.btn{
  --pad-x:18px;--pad-y:12px;
  display:inline-flex;align-items:center;gap:10px;
  padding:var(--pad-y) var(--pad-x);
  border-radius:999px;font-weight:700;text-decoration:none;border:1px solid transparent;
  transition:.18s ease;user-select:none
}
.btn-primary{
  color:#fff;background:linear-gradient(180deg,var(--brand),var(--brand-2));
  box-shadow:0 10px 20px rgba(14,165,233,.25)
}
.btn-primary:hover{transform:translateY(-1px)}
.btn-outline{
  color:var(--ink);background:#fff;border-color:#e6edf5
}
.btn-outline:hover{border-color:var(--brand);box-shadow:0 0 0 6px var(--ring)}

/* Hero */
.hero{display:grid;grid-template-columns:1.25fr 1fr;gap:36px;align-items:center}
.hero .media{border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}
.hero .media img{width:100%;display:block}
@media (max-width:980px){.hero{grid-template-columns:1fr}}

/* Feature row */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:980px){.features{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.features{grid-template-columns:1fr}}
.feature{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}

/* Service cards */
.service-card img{
  width:100%;
  height:230px;           /* fixed frame height for ALL service images */
  object-fit:cover;       /* crop to fill while keeping aspect ratio */
  border-radius:16px;
  margin-bottom:12px;
}
.service-card ul{margin:10px 0 0;padding-left:18px}
.service-card li{margin:6px 0}

/* Pricing cards */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media (max-width:980px){.pricing{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.pricing{grid-template-columns:1fr}}
.price-card{position:relative}
.price-card.reco{outline:2px solid var(--brand)}
.badge{
  position:absolute;top:-12px;left:22px;background:#fde68a;color:#7a4d00;
  padding:6px 10px;border-radius:999px;font-weight:800;font-size:12px;box-shadow:var(--shadow)
}
.price{font-size:40px;font-weight:800;color:var(--ink);margin:4px 0}

/* Gallery */
.gallery{display:grid;gap:16px}
.gallery .large{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.gallery .large img{width:100%;border-radius:16px;display:block}
.gallery .thumbs{display:grid;grid-auto-flow:column;gap:10px;overflow:auto}
.gallery .thumbs img{height:64px;width:110px;object-fit:cover;border-radius:8px;opacity:.85;cursor:pointer;border:2px solid transparent}
.gallery .thumbs img.active{opacity:1;border-color:var(--brand)}

/* CTA bar */
.cta-bar{
  background:#fff;border-radius:22px;box-shadow:var(--shadow);padding:18px;
  display:flex;gap:12px;align-items:center;justify-content:center;flex-wrap:wrap;border:1px solid #eef1f6
}

/* Accordion (FAQs) */
.accordion{display:grid;gap:12px}
.acc-item{background:#fff;border:1px solid #e6edf5;border-radius:14px;overflow:hidden}
.acc-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;cursor:pointer;font-weight:700;color:var(--ink)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .3s ease}
.acc-item.open .acc-body{max-height:600px}
.acc-item.open .acc-head{box-shadow:inset 0 0 0 9999px rgba(14,165,233,.06)}

/* Footer */
.footer{border-top:1px solid #e6edf5;background:#fff}
.footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:24px}
.footer a{text-decoration:none;color:var(--text)}
.footer h4{margin-bottom:10px}
.service-areas{color:var(--muted);font-size:14px;margin-top:16px}
@media (max-width:980px){.footer .cols{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.footer .cols{grid-template-columns:1fr}}


