:root {
  --bg: #d7e0de;
  --paper: #e8eeeb;
  --ink: #102130;
  --muted: #42566b;
  --accent: #1b8f73;
  --accent-dark: #0f6752;
  --line: #bccbc8;
  --radius: 18px;
}
* { box-sizing: border-box; }
body { margin: 0; font-family: Manrope, system-ui, sans-serif; color: var(--ink); background: radial-gradient(circle at 18% 0%, #cfe3db 0%, var(--bg) 44%); }
a { color: inherit; }
.container { width: min(1140px, 92%); margin: 0 auto; }
.site-header { position: sticky; top: 0; z-index: 20; backdrop-filter: blur(8px); background: rgba(215,224,222,.86); border-bottom: 1px solid var(--line); }
.nav { display: flex; justify-content: space-between; gap: 12px; align-items: center; padding: 10px 0; }
.brand { display: flex; align-items: center; gap: 12px; text-decoration: none; }
.brand img { width: 58px; height: 58px; border-radius: 14px; }
.brand-name { margin: 0; font-weight: 800; }
.brand-tag { margin: 0; color: var(--muted); font-size: .9rem; }
.nav-actions { display: flex; align-items: center; gap: 8px; }
.icon-btn { border: 1px solid var(--line); background: var(--paper); border-radius: 999px; display: inline-flex; align-items: center; gap: 8px; padding: 10px 14px; text-decoration: none; font-weight: 700; }
.icon-btn svg { width: 19px; height: 19px; }

.hero { padding: 68px 0 56px; position: relative; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background-image: linear-gradient(120deg, rgba(215,224,222,.86) 0%, rgba(215,224,222,.58) 55%, rgba(215,224,222,.76) 100%), url('assets/hero-cleaner-photo.webp'); background-size: cover; background-position: center 24%; filter: saturate(.88) contrast(.92); }
.hero-grid { position: relative; z-index: 2; display: grid; grid-template-columns: 1.05fr .95fr; gap: 28px; align-items: center; }
.hero-logo-wrap { display:flex; justify-content:flex-end; }
.hero-logo-wrap img { width:min(460px, 92%); max-height: 310px; object-fit: contain; filter: drop-shadow(0 16px 30px rgba(8,24,34,.2)); opacity: .94; }
.eyebrow { color: var(--accent-dark); text-transform: uppercase; letter-spacing: .08em; font-size: .82rem; font-weight: 800; }
h1 { font-size: clamp(2rem, 4.4vw, 4rem); line-height: 1.04; margin: 10px 0 14px; }
.lead { color: var(--muted); font-size: 1.15rem; max-width: 55ch; }
.hero-cta { margin-top: 22px; display: flex; gap: 12px; flex-wrap: wrap; }

.section { padding: 62px 0; }
h2 { font-size: clamp(1.6rem, 2.4vw, 2.4rem); margin: 0 0 10px; }
.cards { margin-top: 18px; display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.service-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 20px; box-shadow: 0 8px 22px rgba(31,53,81,.06); position: relative; overflow: hidden; min-height: 214px; }
.service-card::before { content:""; position:absolute; inset:0; background: linear-gradient(165deg, rgba(232,238,235,.72), rgba(232,238,235,.64)); z-index:1; }
.service-card::after { content:""; position:absolute; width:90px; height:90px; right:-26px; top:-26px; background: radial-gradient(circle, #c8e4d8 0%, rgba(200,228,216,0) 70%); z-index:2; }
.service-card > * { position: relative; z-index: 3; }
.service-weekly { background-image: url('assets/living-room.webp'); background-size: cover; background-position: center; }
.service-kitchen { background-image: url('assets/kitchen-detail.webp'); background-size: cover; background-position: center; }
.service-schedule { background-image: linear-gradient(rgba(232,238,235,.52), rgba(232,238,235,.52)), url('assets/calendar-graphic.webp'); background-size: cover; background-position: center; }
.service-icon { width: 42px; height: 42px; border-radius: 12px; background: linear-gradient(160deg, #d0e7de, #e8f2ee); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 12px; }
.service-icon svg { width: 22px; height: 22px; stroke: #0f6752; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; fill: none; }
.trust-strip { padding: 14px 0 20px; }
.trust-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
.trust-grid div { background:var(--paper); border:1px solid var(--line); border-radius: 14px; padding: 14px 16px; display:flex; flex-direction:column; gap:4px; }
.trust-grid strong { font-size:.95rem; }
.trust-grid span { color: var(--muted); font-size:.88rem; }
.section.alt { background: linear-gradient(180deg, #e6efec, #dae6e1); border-top: 1px solid #c7d8d1; border-bottom: 1px solid #c7d8d1; }
.contact-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; }
.contact-form { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px; display: grid; gap: 10px; }
input, textarea { width: 100%; border: 1px solid #ccd8ea; border-radius: 12px; padding: 11px 12px; font: inherit; }
.btn { border: 0; border-radius: 999px; padding: 12px 18px; text-decoration: none; font-weight: 800; display: inline-flex; align-items: center; justify-content: center; }
.btn-primary { background: var(--accent); color: #fff; }
.btn-dark { background: #162033; color: #fff; }
.btn-light { background: var(--paper); color: #12213c; border: 1px solid var(--line); }
.site-footer { background: var(--paper); border-top: 1px solid var(--line); padding: 20px 0; }
.foot { display: flex; align-items: center; gap: 10px; }
.foot img { width: 34px; height: 34px; border-radius: 8px; }
@media (max-width: 980px) {
  .hero-grid, .cards, .contact-wrap, .trust-grid { grid-template-columns: 1fr; }
  .hero-logo-wrap { justify-content: flex-start; }
  .hero-logo-wrap img { width:min(360px, 74%); max-height: 230px; }
}
@media (max-width: 640px) {
  .nav { flex-wrap: wrap; }
  .nav-actions { width: 100%; justify-content: flex-start; }
}
.wa-logo-btn { width: 44px; height: 44px; border-radius: 999px; display:inline-flex; align-items:center; justify-content:center; text-decoration:none; background:#25D366; color:#fff; box-shadow: 0 6px 16px rgba(37,211,102,.35); }
.wa-logo-btn svg { width:22px; height:22px; }
