@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%; }
button, input, select, textarea { font: inherit; }
.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); }

.hero { min-height: 680px; position: relative; display: grid; align-items: end; color: #fff; background: #111 url("hero-premium.png") center / cover no-repeat; }
.hero::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(8,11,9,.97), rgba(8,11,9,.73) 54%, rgba(8,11,9,.12)); }
.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; }
.hero h1, .about h2, .contact-head h2, .closing h2 { margin: 0; font-size: clamp(48px, 6.5vw, 90px); line-height: .96; letter-spacing: -.045em; }
.hero h1 em, .about h2 em, .closing h2 em { color: var(--acid); font-family: "Playfair Display", serif; font-weight: 600; }
.hero p { max-width: 610px; margin: 24px 0 0; color: rgba(255,255,255,.65); font-size: 17px; }

.about { padding: 125px 0; background: rgba(244,245,241,.87); backdrop-filter: blur(8px); }
.about-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; }
.about h2 { color: var(--ink); }
.about h2 em { color: var(--forest); }
.about-copy { display: grid; grid-template-columns: 1fr 1fr; gap: 38px; margin-top: 38px; color: var(--muted); }
.about-copy strong { color: var(--ink); }
.about-brand {
  position: relative;
  min-height: 360px;
  margin-top: 54px;
  display: grid;
  place-items: center;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(8,11,9,.94), rgba(8,11,9,.58)),
    url("hero-premium.png") center 45% / cover no-repeat;
}
.about-brand::after { content: ""; position: absolute; inset: 18px; border: 1px solid rgba(255,255,255,.17); pointer-events: none; }
.about-brand img { position: relative; z-index: 2; width: min(520px, 75%); filter: drop-shadow(0 14px 28px rgba(0,0,0,.42)); }
.about-brand-note { position: absolute; z-index: 2; left: 32px; bottom: 28px; color: rgba(255,255,255,.66); font-size: 10px; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }

.profile { padding: 125px 0; color: #fff; background: var(--ink); }
.profile-grid { display: grid; grid-template-columns: .88fr 1.12fr; gap: 80px; align-items: center; }
.portrait { position: relative; }
.portrait img { width: 100%; height: 690px; object-fit: cover; object-position: center top; filter: saturate(.82); }
.portrait-label {
  position: absolute;
  left: 26px;
  right: 26px;
  bottom: 25px;
  padding: 22px 0 0;
  border-top: 1px solid rgba(255,255,255,.58);
  color: #fff;
  text-shadow: 0 2px 18px rgba(0,0,0,.55);
}
.portrait-label strong { display: block; font-family: "Playfair Display", serif; font-size: 34px; font-weight: 600; line-height: 1; }
.portrait-label span { display: inline-block; margin-top: 10px; padding: 6px 9px; border: 1px solid rgba(255,255,255,.46); background: rgba(7,10,8,.74); color: #f2c66d; font-size: 10px; font-weight: 800; letter-spacing: .17em; text-transform: uppercase; text-shadow: 0 2px 10px rgba(0,0,0,.9); backdrop-filter: blur(8px); }
.profile-copy h2 { margin: 14px 0 20px; font-size: clamp(45px, 5.7vw, 78px); line-height: .98; letter-spacing: -.045em; }
.profile-copy p { color: rgba(255,255,255,.53); }
.credentials { margin-top: 36px; border-top: 1px solid rgba(255,255,255,.16); }
.credential { display: grid; grid-template-columns: 38px 1fr; gap: 18px; padding: 20px 0; border-bottom: 1px solid rgba(255,255,255,.16); }
.credential b { color: var(--acid); }
.credential strong { display: block; margin-bottom: 3px; }
.credential span { color: rgba(255,255,255,.48); font-size: 13px; }

.contact { padding: 125px 0; background: rgba(255,255,255,.9); backdrop-filter: blur(8px); }
.contact-head { display: grid; grid-template-columns: 1fr .55fr; gap: 44px; align-items: end; margin-bottom: 58px; }
.contact-head h2 { color: var(--ink); font-size: clamp(45px, 5.7vw, 78px); }
.contact-head p { margin: 0; color: var(--muted); }
.contact-grid { display: grid; grid-template-columns: .78fr 1.22fr; gap: 24px; align-items: start; }
.direct { display: grid; gap: 14px; }
.direct-card { min-height: 190px; display: grid; align-content: space-between; padding: 26px; border: 1px solid var(--line); background: var(--paper); transition: transform .2s ease, background .2s ease; }
.direct-card:hover { transform: translateY(-3px); background: #fff; }
.direct-card.whatsapp { background: var(--forest); color: #fff; border-color: var(--forest); }
.contact-icon {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  margin-bottom: 18px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--forest);
}
.contact-icon svg { width: 27px; height: 27px; }
.whatsapp .contact-icon { border-color: rgba(255,255,255,.18); background: rgba(255,255,255,.09); color: var(--acid); }
.direct-card span { color: var(--forest); font-size: 11px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.direct-card.whatsapp span { color: var(--acid); }
.direct-card strong { display: block; margin-top: 30px; font-size: 22px; }
.direct-card small { color: var(--muted); }
.direct-card.whatsapp small { color: rgba(255,255,255,.52); }

.availability {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-top: 14px;
}
.availability-item {
  position: relative;
  min-height: 135px;
  padding: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--ink);
  color: #fff;
}
.availability-item img { width: 100%; height: 220px; object-fit: cover; }
.availability-item::after { content: ""; position: absolute; inset: 0; background: linear-gradient(transparent 18%, rgba(7,10,8,.94)); }
.availability-copy { position: absolute; z-index: 2; inset: auto 0 0; padding: 20px; }
.availability-item b {
  display: block;
  margin-bottom: 7px;
  color: var(--acid);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.availability-item strong { display: block; font-size: 19px; }
.availability-item span { color: rgba(255,255,255,.62); font-size: 12px; }

.form-wrap { overflow: hidden; background: var(--ink); color: #fff; }
.form-visual { position: relative; height: 260px; }
.form-visual img { width: 100%; height: 260px; object-fit: cover; object-position: center 38%; }
.form-visual::after { content: ""; position: absolute; inset: 0; background: linear-gradient(transparent 30%, var(--ink)); }
.form-visual span { position: absolute; z-index: 2; left: 30px; bottom: 22px; color: var(--acid); font-size: 10px; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.form-content { padding: 30px 36px 36px; }
.form-wrap h3 { margin: 0 0 8px; font-size: 28px; }
.form-wrap > p { margin: 0 0 28px; color: rgba(255,255,255,.48); font-size: 13px; }
form { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; }
label { display: grid; gap: 7px; color: rgba(255,255,255,.72); font-size: 12px; font-weight: 700; }
input, select, textarea { width: 100%; min-height: 50px; padding: 12px 13px; border: 1px solid rgba(255,255,255,.18); border-radius: 0; outline: none; background: rgba(255,255,255,.06); color: #fff; }
select option { color: #111; }
textarea { min-height: 145px; resize: vertical; }
input:focus, select:focus, textarea:focus { border-color: var(--acid); }
.full { grid-column: 1 / -1; }
.form-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.button { min-height: 54px; border: 1px solid var(--acid); background: var(--acid); color: var(--ink); font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; cursor: pointer; }
.button.email { background: transparent; color: #fff; border-color: rgba(255,255,255,.3); }
.note { color: rgba(255,255,255,.4); font-size: 11px; }

.closing {
  position: relative;
  padding: 145px 0;
  color: #fff;
  background:
    linear-gradient(90deg, rgba(12, 27, 21, .88) 0%, rgba(12, 27, 21, .54) 52%, rgba(12, 27, 21, .12) 100%),
    url("service-disinfection.png") center 55% / 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: 850px; }
.closing h2 { text-shadow: 0 3px 24px rgba(0,0,0,.65); }
.closing .button { display: inline-flex; align-items: center; justify-content: center; padding: 0 24px; white-space: nowrap; }
.footer {
  position: relative;
  padding: 58px 0 24px;
  background:
    linear-gradient(90deg, rgba(7,10,8,.9), rgba(7,10,8,.62)),
    url("hero-premium.png") center 55% / 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; }
  .about-grid, .profile-grid, .contact-head, .contact-grid, .closing-grid { grid-template-columns: 1fr; }
  .portrait img { height: 560px; }
}
@media (max-width: 620px) {
  .shell { width: min(100% - 28px, 1240px); }
  .nav-call { display: none; }
  .brand-logo { width: 196px; }
  .hero h1 { font-size: 54px; }
  .hero, .hero-inner { min-height: 650px; }
  .about, .profile, .contact, .closing { padding: 82px 0; }
  .about-copy, form, .form-actions, .footer-main, .availability { grid-template-columns: 1fr; }
  .about-brand { min-height: 290px; }
  .portrait img { height: 450px; }
  .form-content { padding: 25px; }
  .form-visual, .form-visual img { height: 215px; }
}
