:root{
  --bg:#F4F7F5;      /* soft sage mist */
  --ink:#0f1f16;
  --muted:#5c6b62;
  --accent:#2E6F5E;
  --alt:#ffffff;
  --border:#E6ECE8;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,sans-serif;line-height:1.6}

.wrap{max-width:1060px;margin:0 auto;padding:0 20px}

.site-header{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--border);z-index:100;box-shadow:0 6px 14px rgba(0,0,0,.03)}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 20px}
.logo-img{max-height:52px;width:auto;display:block}
@media(max-width:860px){.logo-img{max-height:46px}}

.menu-toggle{display:none;background:transparent;border:1px solid var(--border);padding:8px 10px;border-radius:8px}
.menu-toggle span{display:block;width:22px;height:2px;background:var(--ink);margin:5px 0}

.nav{display:flex;gap:20px;align-items:center;flex-wrap:nowrap}
.nav a{text-decoration:none;color:var(--muted);font-weight:500;white-space:nowrap}
.nav a:hover{color:var(--accent)}
@media(max-width:860px){
  .menu-toggle{display:block}
  .nav{display:none;position:absolute;top:64px;right:16px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px;box-shadow:0 12px 32px rgba(0,0,0,.08)}
  .nav.open{display:flex;flex-direction:column;gap:12px}
}

/* ===== Hero ===== */
.hero{position:relative;color:#fff}
.hero.photo{background:url('img/hero-reformer.jpg') center/cover no-repeat;background-attachment:fixed}
.hero::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.45)}
/* Give the hero content horizontal padding by default */
.hero .wrap{position:relative;z-index:1;padding:100px 20px}
.hero h1{font-size:clamp(28px,4vw,44px);margin:0 0 10px}
.hero p{margin:0 0 18px;max-width:60ch}
.cta-row{display:flex;gap:12px;flex-wrap:wrap}
.btn{
  display:inline-block;padding:12px 18px;border-radius:8px;
  background:var(--accent);color:#fff;text-decoration:none;
  font-weight:600;border:1px solid transparent
}
.btn:hover{filter:brightness(.95)}
@media(max-width:860px){
  .hero.photo{background-attachment:scroll}
}
/* Extra breathing room on small phones */
@media(max-width:600px){
  .hero .wrap{padding:80px 28px}
  .cta-row{gap:14px}
}

/* Tighten stacked sections site-wide */
.section + .section {
  margin-top: 0;          /* ensure no margin gap */
  padding-top: 0.75rem;   /* small, consistent top padding */
}



/* ===== Sections / Cards ===== */
.section{padding:56px 0}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
.card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:18px}
.card h3{margin:0 0 6px}
.pill{display:inline-block;padding:4px 10px;border-radius:999px;background:#e7f1ee;border:1px solid #d4e6e0;color:#24574a;font-size:12px;font-weight:600}
.price{font-weight:800}
.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}
.kicker{color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-size:12px;margin:0 0 6px}
.note{font-size:14px;color:var(--muted)}
.rule{height:1px;background:var(--border);margin:24px 0}

/* ===== Policies ===== */
.policies{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.policies li{display:flex;gap:10px;align-items:flex-start;background:#fff;border:1px solid var(--border);border-radius:10px;padding:10px 12px}
.policies .dot{width:8px;height:8px;background:var(--accent);border-radius:999px;margin-top:8px}

/* ===== About ===== */
.about-portrait{width:100%;max-width:340px;border-radius:12px;justify-self:start}
.about-grid{display:grid;grid-template-columns:0.8fr 1.2fr;gap:24px;align-items:start}
@media(max-width:860px){.about-grid{grid-template-columns:1fr}}

/* ===== Footer ===== */
.site-footer{border-top:1px solid var(--border);padding:20px 0;color:var(--muted);font-size:14px;background:#fff}
.footer-row{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.footer-row a{color:var(--muted);text-decoration:none}
.footer-row a:hover{color:var(--accent)}

/* ===== Form ===== */
.form{background:#fff;border:1px solid var(--border);border-radius:12px;padding:18px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:700px){.form .row{grid-template-columns:1fr}}
label{display:block;font-weight:600;margin:10px 0 6px}
input, select, textarea{width:100%;padding:10px;border:1px solid var(--border);border-radius:8px;font:inherit;background:#fff}
textarea{min-height:120px}
.small{font-size:12px;color:var(--muted)}

/* ===== Provide grid ===== */
.provide{padding:56px 0}
.provide .cards{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.icon{font-size:28px;line-height:1;display:inline-block;margin-right:8px}
.provide h3{display:flex;align-items:center;gap:8px;margin:0 0 6px}

/* Make form inputs fill the card width */
.form input,
.form select,
.form textarea {
  width: 100%;
  box-sizing: border-box;
}

/* Stack the two-column rows on small screens */
@media (max-width: 700px) {
  .form .row { grid-template-columns: 1fr; }
}

.provide .card h3 {
  margin-bottom: 0.25rem;
}

.provide .card .sub {
  font-size: 0.85em;
  font-style: italic;
  color: #555;
  margin: 0 0 0.5rem 0;
}

