:root{
  --bg:#f3f3f4;
  --card:#ffffff;
  --ink:#162730;
  --muted:#52636d;
  --teal:#0b7880;
  --teal-dark:#09555b;
  --line:#e5e8ea;
  --shadow:0 10px 30px rgba(14,24,31,.06);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, sans-serif;
  background:radial-gradient(circle at top,#fafafa 0%,#efefef 60%,#e8e8e8 100%);
  color:var(--ink);
}
a{text-decoration:none;color:inherit}

.mockup-stage{
  width:min(1540px, calc(100% - 32px));
  margin:22px auto;
  display:grid;
  grid-template-columns:minmax(0,1200px) 300px;
  gap:28px;
  align-items:start;
}
.site-shell{
  background:var(--card);
  border-radius:22px;
  box-shadow:0 20px 60px rgba(0,0,0,.05);
  overflow:hidden;
}
.topbar{
  display:flex; align-items:center; justify-content:space-between;
  gap:18px; padding:18px 26px;
  background:#fff; border-bottom:1px solid #f0f1f2;
}
.brand img{height:36px; display:block}
.nav{display:flex; gap:24px; align-items:center; font-size:13px; font-weight:700}
.nav a{padding:6px 0; border-bottom:3px solid transparent}
.nav a.active,.nav a:hover{border-color:#1aa0a1}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  min-height:50px; padding:0 28px; border-radius:9px; font-weight:800;
}
.btn-small{min-height:46px; padding:0 22px; font-size:14px}
.btn-solid{background:linear-gradient(135deg,#0f898d,#0c6c72); color:#fff}
.btn-ghost{border:2px solid #9ac5c8; color:#21525b; background:#fff}
.btn-outline-light{border:1.5px solid rgba(255,255,255,.6); color:#fff; min-height:48px}

.hero{
  display:grid; grid-template-columns: 0.44fr 0.56fr; align-items:stretch;
  min-height:470px; background:#fff;
}
.hero-copy{padding:56px 36px 40px 38px}
.hero h1{
  margin:0; font-size:32px; line-height:1.16; letter-spacing:-.04em; font-weight:900; max-width:390px;
}
.hero h1 span{color:var(--teal)}
.hero p{
  margin:24px 0 0; max-width:440px; color:#33454f; font-size:15px; line-height:1.8;
}
.hero-cta{display:flex; gap:14px; margin-top:28px}
.hero-benefits{
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:34px; max-width:520px;
}
.hero-benefits > div{display:flex; gap:10px; align-items:flex-start}
.hero-benefits img{width:32px; height:32px}
.hero-benefits strong{display:block; font-size:13px; font-weight:800}
.hero-benefits small{display:block; font-size:12px; line-height:1.35; color:var(--muted)}

.hero-media{position:relative; min-height:470px; overflow:hidden; background:#eef5f8}
.hero-media img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
}
.hero-fade{
  position:absolute; z-index:2; left:0; top:0; bottom:0; width:34%;
  background:linear-gradient(90deg, rgba(255,255,255,.98) 0%, rgba(255,255,255,.82) 44%, rgba(255,255,255,.42) 68%, rgba(255,255,255,0) 100%);
}

.services-wrap{
  padding:28px 34px 20px;
  background:#fcfcfc;
  border-top:1px solid #f1f1f1;
}
.section-kicker{
  margin:0;
  text-align:center;
  color:#216770;
  text-transform:uppercase;
  letter-spacing:.13em;
  font-size:12px;
  font-weight:800;
}
.services-wrap h2, .process h2{
  margin:12px 0 30px;
  text-align:center;
  font-size:26px;
  letter-spacing:-.04em;
}
.cards{
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px;
}
.card{
  background:#fff; border:1px solid var(--line); border-radius:8px; box-shadow:var(--shadow);
  padding:22px 20px 18px; text-align:center; min-height:268px;
}
.card .service-icon{width:68px; height:68px; display:block; margin:0 auto 12px}
.card h3{margin:0 0 12px; font-size:17px}
.card p{margin:0 auto; max-width:215px; color:#3f525c; font-size:14px; line-height:1.65}
.card a{display:inline-flex; gap:8px; align-items:center; margin-top:18px; color:#0d7f83; font-weight:800; font-size:14px}
.card a span{font-size:18px}

.process{
  padding:28px 34px 26px;
  background:#f7f9fa;
  position:relative;
}
.process-line{
  position:absolute; left:96px; right:96px; top:143px; border-top:2px dotted #d7dfe2; z-index:0;
}
.steps{
  position:relative; z-index:1;
  display:grid; grid-template-columns:repeat(5,1fr); gap:10px; margin-top:20px;
}
.step{text-align:center; padding:0 10px}
.bubble{
  width:74px; height:74px; border-radius:50%; background:#fff; border:1px solid #dfe5e7;
  display:grid; place-items:center; margin:0 auto; box-shadow:0 6px 14px rgba(0,0,0,.04);
}
.bubble img{width:40px; height:40px}
.stepnum{
  width:26px; height:26px; border-radius:50%; background:#0c6f74; color:white;
  display:grid; place-items:center; margin:12px auto 10px; font-size:13px; font-weight:800;
}
.step h3{margin:0 0 8px; font-size:17px}
.step p{margin:0 auto; max-width:150px; font-size:13px; line-height:1.55; color:#4e5f69}

.assurance{
  display:grid; grid-template-columns:92px 1fr 170px; gap:18px; align-items:center;
  padding:28px 34px; color:#fff;
  background:linear-gradient(90deg,#08515d 0%, #076872 54%, #08515d 100%);
}
.assure-icon img{width:72px; height:72px}
.assure-copy h2{margin:0 0 10px; font-size:22px; letter-spacing:-.03em}
.assure-copy p{margin:8px 0; font-size:14px; line-height:1.7; color:#e3f1f2}
.assure-action{justify-self:end}

.footer{
  background:#fff; padding:26px 34px 0;
}
.footer-grid{
  display:grid; grid-template-columns:1.15fr 1fr 1fr .65fr; gap:28px; padding-bottom:22px;
}
.footer h4{
  margin:0 0 16px; font-size:12px; color:#245962; text-transform:uppercase; letter-spacing:.12em;
}
.footer p{margin:9px 0; color:#33454f; font-size:14px; line-height:1.55}
.contact-item{display:flex; gap:10px; align-items:flex-start}
.contact-item img{width:20px; height:20px; flex:0 0 auto; margin-top:1px}
.social{
  width:36px; height:36px; border-radius:50%; display:grid; place-items:center;
  background:#0e6c75; color:white; font-weight:800; font-family:Arial, sans-serif;
}
.footer-bottom{
  display:flex; justify-content:space-between; gap:20px;
  padding:18px 0; color:#dbe7ea; font-size:13px;
  border-top:1px solid #f0f2f3;
  background:linear-gradient(90deg,#08515d,#076a73 56%,#08515d);
  margin:0 -34px; padding-left:34px; padding-right:34px;
}

.phone-preview{
  width:300px;
  min-height:1060px;
  border:7px solid #183d40;
  border-radius:24px;
  background:white;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.08);
}
.phone-top{
  height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 18px;
  border-bottom:1px solid #eef1f2;
}
.phone-top img{width:125px}
.phone-top span{font-size:24px;font-weight:800}
.phone-content{padding:26px 20px}
.phone-content h2{
  margin:0;
  font-size:23px;
  line-height:1.22;
  letter-spacing:-.045em;
  font-weight:900;
}
.phone-content h2 span{color:#0a7b80}
.phone-content p{
  margin:18px 0 22px;
  font-size:13px;
  line-height:1.75;
  color:#334852;
}
.phone-content .btn{
  width:100%;
  margin-bottom:12px;
}
.phone-house{
  width:100%;
  display:block;
  margin:22px -20px 0;
  width:calc(100% + 40px);
}
.phone-benefits{padding-top:24px}
.phone-benefits div{display:flex; gap:13px; margin-bottom:24px; align-items:flex-start}
.phone-benefits img{width:34px; height:34px}
.phone-benefits strong{display:block; font-size:14px}
.phone-benefits small{display:block; font-size:12px; color:#566b74}

@media (max-width: 1300px){
  .mockup-stage{grid-template-columns:1fr}
  .phone-preview{display:none}
}
@media (max-width: 1080px){
  .nav{display:none}
  .hero{grid-template-columns:1fr}
  .hero-media{min-height:320px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .process-line{display:none}
  .assurance{grid-template-columns:1fr; text-align:left}
  .assure-action{justify-self:start}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 700px){
  .mockup-stage{width:min(100%, calc(100% - 16px)); margin:8px auto}
  .site-shell{border-radius:18px}
  .topbar{padding:16px 18px}
  .brand img{height:32px}
  .btn-small{display:none}
  .hero-copy{padding:32px 20px}
  .hero h1{font-size:26px; max-width:none}
  .hero p{font-size:15px}
  .hero-cta{flex-direction:column; align-items:flex-start}
  .hero-benefits{grid-template-columns:1fr}
  .hero-media{min-height:260px}
  .services-wrap,.process,.footer{padding-left:18px; padding-right:18px}
  .cards{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column; margin:0 -18px; padding-left:18px; padding-right:18px}
}

/* v9 cleanup: remove right-side preview, center the main mockup */
.mockup-stage{
  width:min(1240px, calc(100% - 32px)) !important;
  margin:22px auto !important;
  display:block !important;
}
.site-shell{
  width:100% !important;
  margin:0 auto !important;
}
.phone-preview{display:none !important;}
.hero{
  min-height:500px !important;
}
.hero-media{
  min-height:500px !important;
}
.hero-media img{
  object-position:center center;
}
.hero-fade{
  width:38% !important;
}
.bubble{
  width:78px !important;
  height:78px !important;
}
.bubble img{
  width:44px !important;
  height:44px !important;
}
.step h3{
  margin-top:2px;
}
@media (max-width: 1080px){
  .mockup-stage{
    width:min(100%, calc(100% - 20px)) !important;
  }
}

/* v10 polish based on Netlify screenshot review */
.site-shell{
  box-shadow:0 24px 70px rgba(0,0,0,.07) !important;
}

.topbar{
  min-height:82px !important;
  padding:18px 32px !important;
}
.brand img{
  height:44px !important;
}
.nav{
  gap:25px !important;
  font-size:14px !important;
}
.nav a.active{
  color:#0b6f77;
}
.btn-small{
  min-height:48px !important;
  padding:0 25px !important;
}

.hero{
  grid-template-columns:45% 55% !important;
  min-height:520px !important;
}
.hero-copy{
  padding:60px 36px 34px 40px !important;
}
.hero h1{
  font-size:38px !important;
  line-height:1.08 !important;
  max-width:430px !important;
  letter-spacing:-.055em !important;
}
.hero p{
  margin-top:26px !important;
  max-width:450px !important;
  font-size:16px !important;
  line-height:1.75 !important;
}
.hero-media{
  min-height:520px !important;
}
.hero-media img{
  object-position:center center !important;
}
.hero-fade{
  width:42% !important;
  background:linear-gradient(90deg, rgba(255,255,255,1) 0%, rgba(255,255,255,.92) 36%, rgba(255,255,255,.58) 66%, rgba(255,255,255,0) 100%) !important;
}
.hero-cta{
  margin-top:30px !important;
}
.hero-cta .btn{
  min-height:54px !important;
  padding:0 26px !important;
}
.hero-benefits{
  margin-top:32px !important;
  max-width:520px !important;
  gap:16px !important;
}
.hero-benefits img{
  width:28px !important;
  height:28px !important;
}
.hero-benefits strong{
  font-size:12.5px !important;
  line-height:1.1 !important;
}
.hero-benefits small{
  font-size:11.5px !important;
}

.services-wrap{
  padding-top:30px !important;
  padding-bottom:28px !important;
}
.services-wrap h2,.process h2{
  font-size:27px !important;
}
.cards{
  gap:20px !important;
}
.card{
  min-height:252px !important;
  padding:24px 22px 22px !important;
}
.card .service-icon{
  width:72px !important;
  height:72px !important;
}
.card p{
  font-size:13.6px !important;
  max-width:220px !important;
}

.process{
  padding-top:34px !important;
  padding-bottom:38px !important;
}
.process-line{
  top:153px !important;
  left:100px !important;
  right:100px !important;
}
.bubble{
  width:76px !important;
  height:76px !important;
}
.bubble img{
  width:43px !important;
  height:43px !important;
}
.step p{
  max-width:145px !important;
}

.assurance{
  padding:30px 42px !important;
  grid-template-columns:88px 1fr 150px !important;
}
.assure-copy h2{
  font-size:23px !important;
}
.assure-copy p{
  font-size:13.6px !important;
  max-width:820px !important;
}
.footer{
  padding:28px 34px 0 !important;
}
.footer-grid{
  grid-template-columns:1.25fr 1.15fr .95fr .5fr !important;
}
.footer p{
  font-size:13.3px !important;
}
.footer-bottom{
  font-size:12.5px !important;
}

@media (max-width: 1080px){
  .hero{
    grid-template-columns:1fr !important;
  }
  .hero h1{
    font-size:34px !important;
  }
}
@media (max-width: 700px){
  .topbar{
    min-height:72px !important;
    padding:14px 18px !important;
  }
  .brand img{
    height:36px !important;
  }
  .hero-copy{
    padding:30px 20px !important;
  }
  .hero h1{
    font-size:30px !important;
  }
}

/* v11 icon pass: swap in AI-generated icon assets closer to mockup 2 */
.hero-benefits img{
  width:26px !important;
  height:26px !important;
  object-fit:contain;
}
.hero-benefits > div{
  gap:11px !important;
}
.bubble img{
  width:38px !important;
  height:38px !important;
  object-fit:contain;
}
.step:nth-child(4) .bubble img{
  width:42px !important;
  height:42px !important;
}
.step:nth-child(1) .bubble img{
  width:34px !important;
  height:34px !important;
}

/* v11 logo/year update */
.brand img{height:48px !important; width:auto; display:block;}
.card .service-icon{object-fit:contain;}
