:root {
  --cp-primary: #1e9035;
  --cp-primary-dark: #143a52;
  --cp-primary-hover: #1a7d2a;
  --cp-primary-soft: #dceee1;
  --cp-bg: #fff;
  --cp-surface-muted: #f6f9f7;
  --cp-text: #132420;
  --cp-text-secondary: #3b4a50;
  --cp-muted: #5c6b72;
  --cp-border: #e0e8e4;
  --cp-radius: 12px;
  --cp-radius-lg: 16px;
  --cp-shadow-sm: 0 1px 3px rgba(20, 58, 82, 0.06), 0 1px 2px rgba(20, 58, 82, 0.04);
  --cp-shadow: 0 8px 24px rgba(20, 58, 82, 0.1);
}

*,
*::before,
*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--cp-text); background: var(--cp-bg); font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; line-height: 1.6; }
a { color: var(--cp-primary-dark); }

.cp-container, .ds-container { width: min(1200px, calc(100% - 32px)); margin: 0 auto; }
.section, .ds-section { padding: 72px 0; }
.section--muted { background: var(--cp-surface-muted); }

.cp-skip-nav { position: absolute; top: -100%; left: 16px; z-index: 100000; padding: 12px 24px; background: var(--cp-primary); color: #fff; border-radius: 8px; font-weight: 600; text-decoration: none; }
.cp-skip-nav:focus { top: 16px; }

.site-header { position: sticky; top: 0; z-index: 1000; background: rgba(255,255,255,.92); border-bottom: 1px solid rgba(20,58,82,.08); backdrop-filter: blur(12px); }
.site-header__inner { min-height: 72px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.brand { text-decoration: none; font-weight: 700; color: var(--cp-text); }
.main-nav { display: flex; gap: 16px; }
.main-nav a { text-decoration: none; color: var(--cp-text); }
.phone-link { color: var(--cp-primary-dark); font-weight: 600; text-decoration: none; }

.hero { padding: 96px 0 72px; }
.hero__grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 24px; }
.eyebrow, .section-kicker, .ds-label { text-transform: uppercase; letter-spacing: .12em; color: var(--cp-muted); font-weight: 600; margin: 0 0 8px; }
h1, .ds-h1 { font-family: Georgia, serif; font-size: clamp(30px,4vw,48px); line-height: 1.2; margin: 0 0 14px; color: #505d61; }
h2, .ds-h2 { font-family: Georgia, serif; font-size: clamp(26px,3vw,36px); line-height: 1.25; margin: 0 0 12px; color: #505d61; }
h3, .ds-h3 { margin: 0 0 10px; font-size: 22px; }
.lead, .ds-desc { margin: 0 0 20px; color: var(--cp-text-secondary); }

.button-row { display: flex; flex-wrap: wrap; gap: 12px; }
.cp-btn { border: none; border-radius: 9999px; background: var(--cp-primary); color: #fff; padding: 13px 28px; font-size: 15px; font-weight: 600; cursor: pointer; text-decoration: none; display: inline-flex; align-items: center; justify-content: center; }
.cp-btn:hover { background: var(--cp-primary-hover); }
.cp-btn--ghost { background: transparent; color: var(--cp-primary-dark); border: 2px solid var(--cp-primary-dark); }
.cp-btn--ghost:hover { background: var(--cp-primary-dark); color: #fff; }

.stats-card, .card, .cp-review-card { background: #fff; border: 1px solid var(--cp-border); border-radius: var(--cp-radius-lg); box-shadow: var(--cp-shadow-sm); }
.stats-card { padding: 20px; }
.stats-card ul { margin: 0; padding-left: 18px; }
.cards { display: grid; gap: 16px; }
.cards--3 { grid-template-columns: repeat(3,minmax(0,1fr)); }
.cards--2 { grid-template-columns: repeat(2,minmax(0,1fr)); }
.card { padding: 20px; }

.cp-reviews-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.cp-review-card { padding: 28px 24px 24px; }
.cp-review-stars { color: #f5a623; font-size: 18px; letter-spacing: 2px; margin-bottom: 14px; }
.cp-review-text { font-size: 15px; line-height: 1.65; margin: 0 0 20px; }
.cp-review-author { display: flex; align-items: center; gap: 12px; }
.cp-review-avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--cp-primary-soft); color: var(--cp-primary); display: flex; align-items: center; justify-content: center; font-weight: 700; }
.cp-review-name { font-weight: 600; font-size: 14px; }
.cp-review-date { font-size: 12px; color: var(--cp-muted); margin-top: 2px; }

.contacts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.contacts-grid iframe { width: 100%; min-height: 340px; border: 1px solid var(--cp-border); border-radius: var(--cp-radius-lg); }

.site-footer { padding: 40px 0; background: linear-gradient(180deg,#1f3f50 0%,#143a52 100%); color: #d7e2e8; }
.site-footer a { color: #d7e2e8; }
.site-footer__grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 20px; }
.footer-brand, .footer-title { font-weight: 700; color: #f3f7f9; }

.scroll-top { position: fixed; right: 20px; bottom: 20px; width: 46px; height: 46px; border-radius: 9999px; border: 1px solid rgba(20,58,82,.1); background: #fff; color: var(--cp-primary-dark); cursor: pointer; box-shadow: var(--cp-shadow-sm); }

.cp-modal { position: fixed; inset: 0; z-index: 2000; display: none; }
.cp-modal.is-open { display: block; }
.cp-modal__overlay { position: absolute; inset: 0; background: rgba(19,36,32,.45); }
.cp-modal__dialog { position: relative; width: min(560px, calc(100% - 32px)); margin: 10vh auto 0; background: #fff; border: 1px solid var(--cp-border); border-radius: var(--cp-radius-lg); box-shadow: var(--cp-shadow); padding: 22px; }
.cp-modal__close { position: absolute; top: 10px; right: 12px; border: none; background: transparent; font-size: 24px; cursor: pointer; }

.cp-form { display: grid; gap: 12px; }
.cp-form label { display: grid; gap: 6px; font-weight: 500; }
.cp-form input { min-height: 46px; border: 1.5px solid #c9d9d2; border-radius: 10px; padding: 0 12px; font-size: 16px; }
.cp-form-status { margin: 0; font-size: 14px; color: var(--cp-muted); }
.cp-form-status.is-success { color: var(--cp-primary); }
.cp-form-status.is-error { color: #dc2626; }
.cp-form-note { margin: 0; font-size: 13px; color: var(--cp-muted); }

.legal-content h2 { margin-top: 30px; }
.legal-content ul, .legal-content ol { padding-left: 20px; }

#cp-cookie-bar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 3000; background: var(--cp-primary-dark); color: #e4eef2; padding: 14px 16px; }
.cp-cookie-inner { width: min(1100px, calc(100% - 16px)); margin: 0 auto; display: flex; flex-wrap: wrap; gap: 12px; align-items: center; justify-content: space-between; }
#cp-cookie-ok { border: none; border-radius: 9999px; background: var(--cp-primary); color: #fff; padding: 8px 20px; cursor: pointer; }

*:focus-visible { outline: 2px solid var(--cp-primary); outline-offset: 2px; border-radius: 4px; }

@media (max-width: 960px) {
  .hero__grid, .contacts-grid, .site-footer__grid, .cards--3, .cards--2, .cp-reviews-grid { grid-template-columns: 1fr; }
  .section, .ds-section { padding: 52px 0; }
  .site-header__inner { flex-wrap: wrap; justify-content: center; padding: 10px 0; }
  .main-nav { width: 100%; justify-content: center; flex-wrap: wrap; }
}
