@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Playfair+Display:ital,wght@0,600;1,600&display=swap");

:root {
  --ink: #101311;
  --paper: #f4f5f1;
  --white: #fff;
  --acid: #a4d900;
  --forest: #163a2d;
  --muted: #687169;
  --line: rgba(16, 19, 17, 0.14);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { position: relative; margin: 0; color: var(--ink); background: #e9ede7; font-family: "Manrope", sans-serif; line-height: 1.55; }
body::before { content: ""; position: fixed; z-index: -2; inset: 0; background: linear-gradient(rgba(235,240,233,.78), rgba(235,240,233,.78)), url("approach-outdoor.png") center / cover no-repeat; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
.shell { width: min(1240px, calc(100% - 48px)); margin: 0 auto; }
.top { position: absolute; inset: 0 0 auto; z-index: 10; color: #fff; border-bottom: 1px solid rgba(255,255,255,.18); }
.nav { height: 92px; display: flex; align-items: center; justify-content: space-between; gap: 28px; }
.brand { display: flex; align-items: center; }
.brand-logo { width: 242px; height: auto; }
.nav-links { display: flex; align-items: center; gap: 30px; font-size: 13px; font-weight: 700; }
.nav-links a { color: rgba(255,255,255,.7); }
.nav-links a:hover, .nav-links a.active { color: #fff; }
.nav-call { display: flex; align-items: center; gap: 12px; font-size: 13px; font-weight: 700; }
.pulse { width: 9px; height: 9px; border-radius: 50%; background: var(--acid); box-shadow: 0 0 0 7px rgba(164,217,0,.14); }

.page-hero { min-height: 700px; position: relative; display: grid; align-items: end; color: #fff; background: #111 url("pest-cockroach.png") center / cover no-repeat; }
.page-hero::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(8,11,9,.97), rgba(8,11,9,.7) 52%, rgba(8,11,9,.16)); }
.hero-inner { position: relative; z-index: 2; padding: 190px 0 82px; }
.overline { display: flex; align-items: center; gap: 14px; margin-bottom: 22px; color: var(--acid); font-size: 11px; font-weight: 800; letter-spacing: .2em; text-transform: uppercase; }
.overline::before { content: ""; width: 44px; height: 1px; background: currentColor; }
.page-hero h1 { max-width: 900px; margin: 0 0 24px; font-size: clamp(55px, 7.6vw, 104px); line-height: .94; letter-spacing: -.045em; }
.page-hero h1 em { color: var(--acid); font-family: "Playfair Display", serif; font-weight: 600; }
.page-hero p { max-width: 620px; margin: 0; color: rgba(255,255,255,.68); font-size: 17px; }
.hero-index { margin-top: 54px; display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid rgba(255,255,255,.18); }
.hero-index a { padding: 22px 0; border-right: 1px solid rgba(255,255,255,.18); color: rgba(255,255,255,.58); font-size: 12px; font-weight: 700; }
.hero-index a + a { padding-left: 24px; }
.hero-index b { display: block; margin-bottom: 3px; color: var(--acid); }

.intro { padding: 120px 0; background: rgba(244,245,241,.86); backdrop-filter: blur(8px); }
.intro-grid { display: grid; grid-template-columns: .65fr 1.35fr; gap: 90px; }
.index-label { color: var(--forest); font-size: 11px; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; }
.intro h2, .section-head h2, .closing h2 { margin: 0; font-size: clamp(42px, 5.8vw, 76px); line-height: 1.02; letter-spacing: -.045em; }
.intro h2 em, .closing h2 em { color: var(--forest); font-family: "Playfair Display", serif; }
.intro-copy { display: grid; grid-template-columns: 1fr 1fr; gap: 38px; margin-top: 38px; color: var(--muted); }
.intro-visual {
  position: relative;
  min-height: 580px;
  margin-top: 70px;
  overflow: hidden;
}
.intro-visual img { width: 100%; height: 580px; object-fit: cover; }
.intro-visual::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(9,14,11,.82), rgba(9,14,11,.08) 72%); }
.intro-caption {
  position: absolute;
  z-index: 2;
  left: 34px;
  bottom: 34px;
  width: min(430px, calc(100% - 68px));
  padding: 25px;
  border-left: 3px solid var(--acid);
  background: rgba(16,19,17,.76);
  color: #fff;
  backdrop-filter: blur(10px);
}
.intro-caption b { display: block; margin-bottom: 7px; color: var(--acid); font-size: 11px; letter-spacing: .13em; text-transform: uppercase; }
.intro-caption strong { display: block; font-size: 25px; line-height: 1.15; }
.intro-caption span { display: block; margin-top: 7px; color: rgba(255,255,255,.57); font-size: 12px; }

.core { padding: 120px 0; color: #fff; background: var(--ink); }
.section-head { display: grid; grid-template-columns: 1fr .55fr; align-items: end; gap: 44px; margin-bottom: 62px; }
.section-head p { margin: 0; color: rgba(255,255,255,.5); }
.core-list { border-top: 1px solid rgba(255,255,255,.16); }
.core-service { display: grid; grid-template-columns: 70px .82fr 1fr 38px; gap: 28px; align-items: center; padding: 38px 0; border-bottom: 1px solid rgba(255,255,255,.16); }
.core-service span:first-child { color: var(--acid); font-size: 12px; font-weight: 800; }
.core-service h3 { margin: 0; font-size: 31px; letter-spacing: -.03em; }
.core-service p { margin: 0; color: rgba(255,255,255,.48); font-size: 14px; }
.core-service .arrow { color: var(--acid); font-size: 25px; }

.detail { padding: 130px 0; background: rgba(255,255,255,.91); backdrop-filter: blur(8px); }
.detail.alt { background: rgba(244,245,241,.88); }
.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 76px; align-items: center; }
.detail.alt .media { order: 2; }
.media { position: relative; }
.media img { width: 100%; height: 610px; object-fit: cover; }
.media-tag { position: absolute; left: -18px; bottom: 24px; padding: 17px 20px; background: var(--acid); color: var(--ink); font-size: 11px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.detail-copy h2 { margin: 15px 0 20px; font-size: clamp(40px, 5vw, 68px); line-height: 1.02; letter-spacing: -.045em; }
.detail-copy > p { color: var(--muted); }
.features { margin-top: 34px; border-top: 1px solid var(--line); }
.feature { display: grid; grid-template-columns: 34px 1fr; gap: 18px; padding: 19px 0; border-bottom: 1px solid var(--line); }
.feature b { color: var(--forest); }
.feature strong { display: block; margin-bottom: 3px; }
.feature span { color: var(--muted); font-size: 13px; }

.pests { padding: 125px 0; color: #fff; background: var(--forest); }
.pest-head { display: grid; grid-template-columns: 1fr .55fr; gap: 42px; align-items: end; margin-bottom: 55px; }
.pest-head h2 { margin: 0; font-size: clamp(42px, 5.8vw, 76px); line-height: 1.02; letter-spacing: -.045em; }
.pest-head p { margin: 0; color: rgba(255,255,255,.55); }
.pest-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.pest-card { position: relative; min-height: 530px; overflow: hidden; }
.pest-card img { width: 100%; height: 100%; min-height: 530px; object-fit: cover; transition: transform .5s ease; }
.pest-card:hover img { transform: scale(1.025); }
.pest-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(transparent 35%, rgba(8,11,9,.92)); }
.pest-copy { position: absolute; z-index: 2; inset: auto 0 0; padding: 30px; }
.pest-copy span { color: var(--acid); font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .14em; }
.pest-copy h3 { margin: 8px 0; font-size: 31px; }
.pest-copy p { margin: 0; color: rgba(255,255,255,.62); font-size: 13px; }

.process { padding: 125px 0; background: rgba(255,255,255,.9); backdrop-filter: blur(8px); }
.process-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; margin-top: 55px; }
.step { position: relative; min-height: 410px; overflow: hidden; background: var(--ink); color: #fff; }
.step img { width: 100%; height: 410px; object-fit: cover; transition: transform .5s ease; }
.step:hover img { transform: scale(1.025); }
.step::after { content: ""; position: absolute; inset: 0; background: linear-gradient(transparent 22%, rgba(7,10,8,.94)); }
.step-copy { position: absolute; z-index: 2; inset: auto 0 0; padding: 28px; }
.step b { color: var(--acid); font-size: 12px; }
.step h3 { margin: 10px 0 7px; font-size: 25px; }
.step p { max-width: 470px; margin: 0; color: rgba(255,255,255,.61); font-size: 13px; }

.sectors { padding: 120px 0; background: rgba(244,245,241,.88); backdrop-filter: blur(8px); }
.sector-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 52px; }
.sector { position: relative; min-height: 340px; overflow: hidden; background: var(--ink); color: #fff; }
.sector img { width: 100%; height: 340px; object-fit: cover; transition: transform .5s ease; }
.sector:hover img { transform: scale(1.03); }
.sector::after { content: ""; position: absolute; inset: 0; background: linear-gradient(transparent 28%, rgba(7,10,8,.94)); }
.sector-copy { position: absolute; z-index: 2; inset: auto 0 0; padding: 24px; }
.sector span { color: var(--acid); font-size: 11px; font-weight: 800; }
.sector h3 { margin: 8px 0 6px; font-size: 21px; }
.sector p { margin: 0; color: rgba(255,255,255,.6); font-size: 12px; }

.closing {
  position: relative;
  padding: 145px 0;
  color: #fff;
  background:
    linear-gradient(90deg, rgba(12, 27, 21, .88) 0%, rgba(12, 27, 21, .55) 52%, rgba(12, 27, 21, .12) 100%),
    url("service-inspection.png") center 48% / cover no-repeat;
}
.closing::before { content: ""; position: absolute; inset: 0; border-top: 1px solid rgba(164,217,0,.35); border-bottom: 1px solid rgba(164,217,0,.18); pointer-events: none; }
.closing-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr auto; gap: 50px; align-items: end; }
.closing h2 { max-width: 840px; }
.closing h2 { text-shadow: 0 3px 24px rgba(0,0,0,.65); }
.closing h2 em { color: var(--acid); }
.button { min-height: 54px; display: inline-flex; align-items: center; justify-content: center; padding: 0 24px; border: 1px solid var(--acid); background: var(--acid); color: var(--ink); font-size: 12px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.footer {
  position: relative;
  padding: 58px 0 24px;
  background:
    linear-gradient(90deg, rgba(7,10,8,.9), rgba(7,10,8,.62)),
    url("pest-mouse.png") center 48% / cover no-repeat;
  color: rgba(255,255,255,.72);
}
.footer::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(164,217,0,.025), transparent 42%, rgba(164,217,0,.015)); pointer-events: none; }
.footer .shell { position: relative; z-index: 1; }
.footer-main { display: grid; grid-template-columns: 1.2fr .8fr .8fr; gap: 50px; padding-bottom: 38px; border-bottom: 1px solid rgba(255,255,255,.12); }
.footer-brand { color: #fff; font-weight: 800; font-size: 22px; }
.footer h4 { margin: 0 0 12px; color: #fff; font-size: 12px; text-transform: uppercase; letter-spacing: .12em; }
.footer p { margin: 0; font-size: 13px; }
.footer-bottom { display: flex; justify-content: space-between; gap: 20px; padding-top: 20px; font-size: 11px; }

@media (max-width: 900px) {
  .nav-links { display: none; }
  .intro-grid, .section-head, .detail-grid, .pest-head, .closing-grid { grid-template-columns: 1fr; }
  .detail.alt .media { order: initial; }
  .core-service { grid-template-columns: 50px 1fr 28px; }
  .core-service p { display: none; }
  .process-grid, .sector-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 620px) {
  .shell { width: min(100% - 28px, 1240px); }
  .nav-call { display: none; }
  .brand-logo { width: 196px; }
  .page-hero h1 { font-size: 54px; }
  .hero-index, .intro-copy, .pest-grid, .process-grid, .sector-grid, .footer-main { grid-template-columns: 1fr; }
  .hero-index a, .hero-index a + a { padding: 12px 0; border-right: 0; }
  .intro, .core, .detail, .pests, .process, .sectors, .closing { padding: 82px 0; }
  .media img { height: 400px; }
  .intro-visual, .intro-visual img { min-height: 390px; height: 390px; }
  .step, .step img { min-height: 340px; height: 340px; }
}
