:root {
  --bg: #f7f7f5;
  --white: #ffffff;
  --text: #1e1e1e;
  --muted: #666666;
  --line: #dddddd;
  --dark: #111111;
  --soft: #f0eee8;
  --accent: #2f5f3b;
  --accent-dark: #244a2f;
  --max: 1140px;
  --radius: 6px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: Arial, Helvetica, sans-serif;
  font-size: 15px;
  line-height: 1.55;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.wrap { width: min(var(--max), calc(100% - 34px)); margin: 0 auto; }
.top { background: var(--dark); color: #ffffff; font-size: 13px; }
.top .wrap { display: flex; justify-content: space-between; gap: 16px; padding: 8px 0; flex-wrap: wrap; }
header { background: #ffffff; border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 10; }
.header-inner { min-height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 22px; }
.brand strong { display: block; font-size: 24px; letter-spacing: .03em; }
.brand span { display: block; font-size: 12px; color: var(--muted); margin-top: 1px; }
nav { display: flex; gap: 20px; align-items: center; font-size: 14px; }
nav a:hover { color: var(--accent); }
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 42px; padding: 0 17px; border-radius: var(--radius);
  border: 1px solid var(--dark); font-size: 14px; font-weight: 700; line-height: 1;
}
.btn.dark { background: var(--dark); color: #ffffff; }
.btn.green { background: var(--accent); border-color: var(--accent); color: #ffffff; }
.btn.light { background: #ffffff; color: var(--dark); }
.hero {
  background:
    linear-gradient(rgba(12, 12, 12, .68), rgba(12, 12, 12, .68)),
    radial-gradient(circle at top left, #5d6b55, #1d211d 68%);
  color: #ffffff; padding: 76px 0 68px;
}
.hero-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 36px; align-items: center; }
.hero h1 { margin: 0 0 14px; font-size: clamp(34px, 5vw, 54px); line-height: 1.05; letter-spacing: -.03em; max-width: 760px; }
.hero p { margin: 0 0 24px; max-width: 650px; color: #eeeeee; font-size: 17px; }
.hero-actions, .card-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-box {
  background: rgba(255,255,255,.94); color: var(--text);
  border-radius: var(--radius); padding: 24px; box-shadow: 0 12px 34px rgba(0,0,0,.24);
}
.hero-box h2 { margin: 0 0 12px; font-size: 22px; }
.quick-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; }
.quick-list li { border-bottom: 1px solid #e7e7e7; padding-bottom: 10px; font-size: 14px; }
.quick-list li:last-child { border-bottom: 0; padding-bottom: 0; }
section { padding: 54px 0; }
.section-title {
  margin-bottom: 24px; display: flex; align-items: end; justify-content: space-between;
  gap: 20px; border-bottom: 1px solid var(--line); padding-bottom: 15px;
}
.section-title h2 { margin: 0; font-size: 31px; line-height: 1.12; letter-spacing: -.02em; }
.section-title p { margin: 0; color: var(--muted); max-width: 520px; font-size: 14px; }
.services, .cards-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.service-card, .info-card, .review, .contact-card, .crew-card {
  background: #ffffff; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: 0 5px 16px rgba(0,0,0,.04);
}
.service-card { overflow: hidden; }
.service-top { height: 8px; background: var(--accent); }
.service-card .body, .info-card, .review, .contact-card { padding: 22px; }
h2, h3 { color: var(--text); }
h3 { margin: 0 0 9px; font-size: 21px; line-height: 1.18; }
.service-card p, .info-card p, .review p, .contact-card p { margin: 0; color: var(--muted); font-size: 14px; }
.service-card ul, .info-card ul, .content-list {
  list-style: none; margin: 15px 0 0; padding: 0; display: grid; gap: 8px; font-size: 14px;
}
.service-card li, .info-card li, .content-list li { position: relative; padding-left: 16px; }
.service-card li::before, .info-card li::before, .content-list li::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); position: absolute; left: 0; top: .62em;
}
.split { display: grid; grid-template-columns: .9fr 1.1fr; gap: 22px; align-items: start; }
.area-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-top: 16px; }
.area-list span {
  background: var(--soft); border: 1px solid #e1ddd3; border-radius: var(--radius);
  padding: 10px 12px; font-weight: 700; font-size: 14px;
}
.reviews { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.stars { color: #d08a00; letter-spacing: 1px; font-size: 14px; margin-bottom: 10px; }
.review strong { display: block; margin-top: 14px; font-size: 14px; }
.contact-row { display: grid; grid-template-columns: .95fr 1.05fr; gap: 22px; align-items: start; }
.contact-lines { display: grid; gap: 12px; margin-top: 18px; }
.contact-line { padding: 13px 14px; background: var(--soft); border-radius: var(--radius); border: 1px solid #e1ddd3; font-size: 14px; }
.contact-line span { display: block; color: var(--muted); font-size: 12px; margin-bottom: 2px; }
form { display: grid; gap: 12px; }
input, textarea, select {
  width: 100%; border: 1px solid #cfcfcf; background: #ffffff; border-radius: var(--radius);
  padding: 12px 13px; font: inherit; font-size: 14px;
}
textarea { min-height: 120px; resize: vertical; }
.mini { color: var(--muted); font-size: 12px; margin-top: 10px; }
.content {
  background: #ffffff; border: 1px solid var(--line); border-radius: var(--radius);
  padding: 28px; box-shadow: 0 5px 16px rgba(0,0,0,.04);
}
.content h2 { margin-top: 0; font-size: 28px; line-height: 1.12; }
.content p { color: var(--muted); }
.breadcrumb { font-size: 13px; margin-bottom: 12px; color: #dddddd; }
.breadcrumb a { color: #ffffff; text-decoration: underline; text-underline-offset: 3px; }
.crew-grid { display: grid; grid-template-columns: 1fr; gap: 18px; }
.crew-card { display: grid; grid-template-columns: 260px 1fr; gap: 22px; padding: 22px; align-items: center; }
.crew-photo { background: var(--soft); border: 1px solid #e1ddd3; border-radius: var(--radius); overflow: hidden; min-height: 260px; }
.crew-photo img { width: 100%; height: 100%; object-fit: cover; }
.crew-role { font-weight: 700; color: var(--accent); margin-bottom: 10px !important; }
footer { background: #151515; color: #ffffff; padding: 28px 0; font-size: 13px; }
.footer-grid { display: grid; grid-template-columns: 1fr auto auto; gap: 28px; align-items: start; }
footer strong { display: block; margin-bottom: 6px; font-size: 15px; }
footer a, footer span { color: #dddddd; display: block; margin-top: 3px; }
@media (max-width: 900px) {
  nav { display: none; }
  .hero-grid, .services, .cards-3, .split, .reviews, .contact-row, .footer-grid { grid-template-columns: 1fr; }
  .section-title { display: block; }
  .section-title p { margin-top: 8px; }
}
@media (max-width: 700px) {
  .crew-card { grid-template-columns: 1fr; }
  .crew-photo { min-height: 320px; }
}
@media (max-width: 560px) {
  body { font-size: 14px; }
  .top .wrap, .header-inner { display: block; }
  .brand { padding: 15px 0 10px; }
  .header-inner .btn { margin-bottom: 14px; }
  .hero { padding: 50px 0; }
  section { padding: 42px 0; }
  .area-list { grid-template-columns: 1fr; }
}