﻿:root {
  --ink: #1e2930;
  --trust: #1f3346;
  --trust-deep: #162533;
  --paper: #f6f2ea;
  --soft: #edf1ef;
  --line: #d8ded8;
  --accent: #c8843e;
  --accent-dark: #9c6128;
  --green: #4d7562;
  --white: #ffffff;
  --shadow: 0 18px 50px rgba(22, 37, 51, .12);
  font-family: Arial, Helvetica, sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); line-height: 1.6; }
a { color: inherit; }
.site-header { position: sticky; top: 0; z-index: 20; display: flex; justify-content: space-between; align-items: center; gap: 24px; padding: 14px clamp(18px, 4vw, 56px); background: rgba(246, 242, 234, .94); border-bottom: 1px solid rgba(31, 51, 70, .12); backdrop-filter: blur(14px); }
.brand { display: flex; align-items: center; gap: 12px; text-decoration: none; min-width: 250px; }
.brand-mark { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 8px; background: var(--trust); color: var(--paper); font-weight: 700; }
.brand strong, .brand small { display: block; line-height: 1.2; }
.brand small { color: #62706d; font-size: 12px; margin-top: 3px; }
.main-nav, .site-footer nav { display: flex; gap: 18px; flex-wrap: wrap; align-items: center; }
.main-nav a, .site-footer a { text-decoration: none; color: #34444b; font-size: 15px; }
.main-nav a:hover, .site-footer a:hover { color: var(--accent-dark); }
.section, .section-band { padding: clamp(56px, 8vw, 104px) clamp(18px, 5vw, 72px); }
.section { max-width: 1180px; margin: 0 auto; }
.section-band { width: 100%; }
.hero { min-height: 86vh; display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr); align-items: center; gap: clamp(28px, 6vw, 80px); background: linear-gradient(135deg, #f6f2ea 0%, #edf1ef 55%, #e7dccd 100%); }
.hero-copy { max-width: 720px; }
.eyebrow { margin: 0 0 12px; color: var(--accent-dark); text-transform: uppercase; letter-spacing: 0; font-size: 13px; font-weight: 700; }
h1, h2, h3, p { overflow-wrap: anywhere; }
h1 { margin: 0; color: var(--trust-deep); font-size: clamp(38px, 6vw, 72px); line-height: 1.02; letter-spacing: 0; }
h2 { margin: 0 0 18px; color: var(--trust); font-size: clamp(28px, 4vw, 46px); line-height: 1.12; letter-spacing: 0; }
h3 { margin: 0 0 8px; color: var(--trust); font-size: 20px; line-height: 1.25; }
.lead { font-size: clamp(21px, 3vw, 30px); color: var(--green); margin: 22px 0 10px; }
.hero p:not(.eyebrow):not(.lead) { font-size: 18px; max-width: 650px; }
blockquote { margin: 28px 0; padding: 18px 22px; border-left: 5px solid var(--accent); background: rgba(255,255,255,.55); color: var(--trust-deep); font-size: 19px; }
.cta-row { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 28px; }
.button { display: inline-flex; min-height: 46px; align-items: center; justify-content: center; padding: 11px 18px; border-radius: 8px; text-decoration: none; border: 1px solid transparent; font-weight: 700; cursor: pointer; font-size: 16px; }
.button.primary { background: var(--accent); color: #fffaf2; }
.button.primary:hover { background: var(--accent-dark); }
.button.secondary { color: var(--trust); border-color: rgba(31,51,70,.24); background: rgba(255,255,255,.42); }
.hero-visual { min-height: 450px; display: grid; place-items: center; }
.desk-scene { position: relative; width: min(100%, 520px); aspect-ratio: 1.05; border-radius: 8px; background: linear-gradient(145deg, #314c61, #203746); box-shadow: var(--shadow); overflow: hidden; }
.desk-scene::before { content: ""; position: absolute; inset: 24px; border: 1px solid rgba(246,242,234,.25); border-radius: 8px; }
.paper { position: absolute; width: 170px; min-height: 116px; padding: 18px; border-radius: 8px; background: #fbfaf5; box-shadow: 0 12px 28px rgba(0,0,0,.18); transform: rotate(-5deg); }
.paper span, .paper b { display: block; }
.paper span { color: var(--accent-dark); font-size: 14px; }
.paper b { color: var(--trust); margin-top: 8px; line-height: 1.2; }
.paper-one { left: 56px; top: 70px; }
.paper-two { right: 52px; bottom: 62px; transform: rotate(4deg); }
.compass { position: absolute; right: 78px; top: 62px; width: 112px; height: 112px; border-radius: 50%; border: 7px solid #ead9bd; background: #f7efe1; display: grid; place-items: center; }
.compass span { width: 20px; height: 72px; background: linear-gradient(var(--accent) 0 50%, var(--green) 50% 100%); clip-path: polygon(50% 0, 80% 50%, 50% 100%, 20% 50%); transform: rotate(38deg); }
.path-line { position: absolute; height: 3px; background: rgba(246,242,234,.7); border-radius: 99px; }
.path-line.one { width: 210px; left: 86px; bottom: 142px; transform: rotate(-18deg); }
.path-line.two { width: 160px; left: 182px; top: 240px; transform: rotate(24deg); }
.path-line.three { width: 120px; right: 74px; top: 206px; transform: rotate(-8deg); }
.section-heading { max-width: 760px; margin-bottom: 34px; }
.section-heading.wide { max-width: 930px; }
.text-columns { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 36px; font-size: 20px; }
.muted { background: var(--soft); max-width: none; }
.muted > * { max-width: 1180px; margin-left: auto; margin-right: auto; }
.audience-grid, .offer-grid, .example-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.audience-grid article, .offer-grid article, .example-grid article { background: var(--white); border: 1px solid var(--line); border-radius: 8px; padding: 20px; box-shadow: 0 8px 24px rgba(22,37,51,.05); }
.audience-grid article { font-weight: 700; color: var(--trust); }
.image-strip { display: grid; grid-template-columns: minmax(260px, 420px) minmax(0, 1fr); gap: 22px; align-items: center; margin: 0 auto 28px; max-width: 1180px; }
.image-strip img, .inline-image img { display: block; width: 100%; height: auto; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 8px; border: 1px solid rgba(31,51,70,.12); box-shadow: 0 14px 34px rgba(22,37,51,.12); }
.image-strip figcaption { color: #52625f; font-size: 18px; max-width: 520px; }
.compact-image { margin-bottom: 34px; }
.inline-image { margin: 28px 0 0; max-width: 420px; }
.split { display: grid; grid-template-columns: minmax(0,.85fr) minmax(0,1.15fr); gap: clamp(28px, 6vw, 72px); align-items: start; }
.check-list { margin: 0; padding: 0; display: grid; gap: 12px; list-style: none; }
.check-list li { padding: 14px 16px 14px 46px; background: var(--white); border: 1px solid var(--line); border-radius: 8px; position: relative; }
.check-list li::before { content: ""; position: absolute; left: 17px; top: 19px; width: 12px; height: 7px; border-left: 3px solid var(--green); border-bottom: 3px solid var(--green); transform: rotate(-45deg); }
.boundary { background: var(--trust); color: #edf1ef; }
.boundary-panel { max-width: 1080px; margin: 0 auto; }
.boundary h2 { color: #fff; }
.boundary .eyebrow { color: #f0b36d; }
.boundary-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 10px; margin: 28px 0; }
.boundary-grid strong { display: grid; place-items: center; min-height: 88px; padding: 14px; text-align: center; border: 1px solid rgba(255,255,255,.18); border-radius: 8px; background: rgba(255,255,255,.08); }
.steps { list-style: none; counter-reset: step; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.steps li { display: flex; align-items: center; gap: 14px; min-height: 92px; padding: 20px; border: 1px solid var(--line); border-radius: 8px; background: #fffaf3; }
.steps span { flex: 0 0 42px; width: 42px; height: 42px; display: grid; place-items: center; border-radius: 50%; background: var(--trust); color: var(--paper); font-weight: 700; }
.form { display: grid; gap: 14px; padding: 26px; border-radius: 8px; background: var(--white); color: var(--ink); box-shadow: var(--shadow); }
.form.compact { box-shadow: none; border: 1px solid var(--line); }
.bee-field { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; }
.form-status { margin: 0; color: var(--green); font-weight: 700; }
.form-status.error { color: #8b2f26; }
label { display: grid; gap: 7px; font-weight: 700; color: var(--trust); }
input, textarea, select { width: 100%; border: 1px solid #cbd3d0; border-radius: 8px; padding: 12px 13px; font: inherit; background: #fff; color: var(--ink); }
textarea { resize: vertical; }
.checkbox { display: flex; align-items: flex-start; gap: 10px; font-weight: 400; color: var(--ink); }
.checkbox input { width: auto; margin-top: 5px; }
.about-text p:first-child { margin-top: 0; }
.contact { display: grid; grid-template-columns: minmax(0,.85fr) minmax(0,1.15fr); gap: clamp(28px, 6vw, 72px); background: #e7dccd; }
.notice { padding: 16px; background: rgba(255,255,255,.55); border-left: 5px solid var(--accent); }
.site-footer { display: flex; justify-content: space-between; gap: 24px; padding: 34px clamp(18px, 5vw, 72px); background: var(--trust-deep); color: #edf1ef; }
.site-footer p { margin: 8px 0 0; color: #c6d0cd; }
.visitor-counter { font-size: 14px; }
.site-footer a { color: #edf1ef; }
.legal h1 { color: var(--trust-deep); font-size: clamp(34px, 5vw, 56px); line-height: 1.08; }
.legal h2 { margin-top: 30px; font-size: clamp(24px, 3vw, 34px); }
.legal p, .legal li { max-width: 920px; }
@media (max-width: 900px) {
  .site-header { align-items: flex-start; flex-direction: column; }
  .main-nav { gap: 12px; }
  .hero, .split, .contact, .text-columns { grid-template-columns: 1fr; }
  .image-strip { grid-template-columns: 1fr; }
  .hero { min-height: auto; }
  .hero-visual { min-height: 340px; }
  .audience-grid, .offer-grid, .example-grid, .steps { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .boundary-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 620px) {
  .brand { min-width: 0; }
  .brand small { display: none; }
  .section, .section-band { padding-left: 16px; padding-right: 16px; }
  h1 { font-size: 38px; }
  h2 { font-size: 28px; }
  .audience-grid, .offer-grid, .example-grid, .steps, .boundary-grid { grid-template-columns: 1fr; }
  .desk-scene { aspect-ratio: .9; }
  .paper { width: 145px; }
  .paper-one { left: 30px; top: 54px; }
  .paper-two { right: 28px; bottom: 54px; }
  .compass { right: 32px; top: 48px; width: 92px; height: 92px; }
  .site-footer { flex-direction: column; }
}
