/* =========================================================================
   КОНТУР - архитектурное бюро. Единая дизайн-система (направление A).
   Один источник правды для всех 5 страниц: токены, каркас, компоненты.
   ========================================================================= */

/* ---- Токены ---------------------------------------------------------- */
:root{
  --bg:        #F1F1EE;
  --surface:   #FBFBF9;
  --surface-2: #E7E7E2;
  --ink:       #17181A;
  --muted:     #5B5E63;
  --accent:    #27408B;
  --accent-hi: #33539E;
  --hairline:  rgba(23,24,26,.12);
  --hairline-2:rgba(23,24,26,.22);
  --accent-tint: rgba(39,64,139,.08);

  --font-display: 'Manrope', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-body:    'Manrope', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, 'Cascadia Code', Consolas, 'Courier New', monospace;

  --container: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --section-y: clamp(72px, 11vw, 148px);
  --header-h: 70px;

  --radius: 10px;
  --radius-sm: 8px;
  --shadow-1: 0 1px 2px rgba(23,24,26,.05);
  --shadow-2: 0 22px 48px -26px rgba(23,24,26,.32);
  --shadow-accent: 0 10px 34px -10px rgba(39,64,139,.42);

  --ease: cubic-bezier(.2,.6,.2,1);
  --dur: 240ms;
}

/* ---- Reset / base ---------------------------------------------------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; scroll-padding-top:calc(var(--header-h) + 24px); }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  font-weight:400;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* деликатный grain поверх фона */
body::before{
  content:"";
  position:fixed; inset:0;
  z-index:1;
  pointer-events:none;
  opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; }
:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; border-radius:2px; }

/* ---- Типографика ----------------------------------------------------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:800; line-height:1.04; letter-spacing:-.02em; margin:0; }
.display{
  font-size:clamp(2.6rem, 7vw, 5.6rem);
  font-weight:800;
  line-height:.98;
  letter-spacing:-.03em;
}
.h2{ font-size:clamp(1.9rem, 3.6vw, 3rem); }
.h3{ font-size:clamp(1.25rem, 2vw, 1.6rem); font-weight:700; letter-spacing:-.01em; }
p{ margin:0 0 1em; }
.lead{ font-size:clamp(1.05rem,1.5vw,1.32rem); line-height:1.55; color:var(--ink); font-weight:500; }
.muted{ color:var(--muted); }
strong{ font-weight:700; }

/* mono-метки и индексы */
.mono{
  font-family:var(--font-mono);
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:500;
}
.mono .idx{ color:var(--accent); }

/* ---- Layout ---------------------------------------------------------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.section{ position:relative; padding-block:var(--section-y); }
.section--tight{ padding-block:clamp(52px,7vw,92px); }
main{ position:relative; z-index:2; }

.sec-head{ display:flex; flex-direction:column; gap:18px; max-width:820px; margin-bottom:clamp(38px,5vw,64px); }
.sec-head .mono{ display:inline-flex; align-items:center; gap:10px; }
.sec-title{ font-size:clamp(1.8rem,3.4vw,2.9rem); font-weight:800; letter-spacing:-.025em; }
.sec-note{ color:var(--muted); font-size:1.05rem; max-width:60ch; }

.hairline{ height:1px; background:var(--hairline); border:0; margin:0; }

/* ghost-число (декоративная outline-цифра) */
.ghost-num{
  font-family:var(--font-display);
  font-weight:800;
  color:transparent;
  -webkit-text-stroke:1px var(--hairline-2);
  letter-spacing:-.04em;
  line-height:.8;
  pointer-events:none;
  user-select:none;
}

/* ---- Кнопки ---------------------------------------------------------- */
.btn{
  --pad-y:14px; --pad-x:24px;
  display:inline-flex; align-items:center; gap:10px;
  padding:var(--pad-y) var(--pad-x);
  font-family:var(--font-display);
  font-weight:700; font-size:.98rem; letter-spacing:.005em;
  border-radius:var(--radius-sm);
  border:1px solid transparent;
  transition:transform var(--dur) var(--ease), background var(--dur) var(--ease),
             box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease), color var(--dur) var(--ease);
  will-change:transform;
}
.btn svg{ width:18px; height:18px; transition:transform var(--dur) var(--ease); }
.btn--accent{ background:var(--accent); color:#fff; box-shadow:0 1px 2px rgba(23,24,26,.12); }
.btn--accent:hover{ background:var(--accent-hi); box-shadow:var(--shadow-accent); transform:translateY(-2px); }
.btn--accent:hover svg{ transform:translateX(3px); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--hairline-2); }
.btn--ghost:hover{ border-color:var(--ink); background:rgba(23,24,26,.04); transform:translateY(-2px); }
.btn--ghost:hover svg{ transform:translateX(3px); }
.btn--lg{ --pad-y:17px; --pad-x:30px; font-size:1.02rem; }
.btn--block{ width:100%; justify-content:center; }

/* текстовая ссылка со стрелкой */
.arrow-link{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font-display); font-weight:700; font-size:1rem;
  color:var(--ink);
  padding-bottom:3px;
  border-bottom:1px solid var(--hairline-2);
  transition:color var(--dur) var(--ease), border-color var(--dur) var(--ease), gap var(--dur) var(--ease);
}
.arrow-link svg{ width:17px; height:17px; transition:transform var(--dur) var(--ease); }
.arrow-link:hover{ color:var(--accent); border-color:var(--accent); gap:13px; }

/* ======================================================================
   ШАПКА (идентична на всех страницах)
   ====================================================================== */
.site-header{
  position:sticky; top:0; z-index:100;
  background:color-mix(in srgb, var(--bg) 86%, transparent);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--hairline);
}
.header__inner{
  display:flex; align-items:center; gap:28px;
  height:var(--header-h);
}
.brand{ display:inline-flex; align-items:center; gap:12px; margin-right:auto; }
.brand__mark{ width:26px; height:26px; color:var(--ink); flex:none; }
.brand__mark svg{ width:100%; height:100%; }
.brand__name{ font-family:var(--font-display); font-weight:800; font-size:1.15rem; letter-spacing:.04em; }
.brand__tag{ font-family:var(--font-mono); font-size:.62rem; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); border-left:1px solid var(--hairline-2); padding-left:10px; margin-left:2px; }

.nav{ display:flex; align-items:center; gap:4px; }
.nav a{
  position:relative;
  font-family:var(--font-display); font-weight:600; font-size:.95rem;
  padding:9px 14px; border-radius:6px;
  color:var(--muted);
  transition:color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.nav a::after{
  content:""; position:absolute; left:14px; right:14px; bottom:4px; height:1.5px;
  background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform var(--dur) var(--ease);
}
.nav a:hover{ color:var(--ink); }
.nav a:hover::after{ transform:scaleX(1); }
.nav a.is-active{ color:var(--ink); }
.nav a.is-active::after{ transform:scaleX(1); }

.header__cta{ flex:none; }

.burger{
  display:none; position:relative;
  width:44px; height:44px; border:1px solid var(--hairline-2); border-radius:8px;
  background:transparent; flex:none;
}
.burger span{
  position:absolute; left:12px; right:12px; height:1.6px; background:var(--ink);
  transition:transform var(--dur) var(--ease), opacity var(--dur) var(--ease); top:50%;
}
.burger span:nth-child(1){ transform:translateY(-5px); }
.burger span:nth-child(2){ transform:translateY(4px); }
.burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(0) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2){ transform:translateY(0) rotate(-45deg); }

/* мобильное меню-оверлей */
.mobile-nav{
  position:fixed; inset:var(--header-h) 0 0 0; z-index:99;
  background:var(--bg);
  border-top:1px solid var(--hairline);
  padding:26px var(--gutter) 40px;
  display:flex; flex-direction:column; gap:6px;
  transform:translateY(-8px); opacity:0; pointer-events:none;
  transition:opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.mobile-nav.is-open{ transform:none; opacity:1; pointer-events:auto; }
.mobile-nav a.m-link{
  display:flex; align-items:baseline; gap:14px;
  font-family:var(--font-display); font-weight:700; font-size:1.5rem; letter-spacing:-.01em;
  padding:16px 0; border-bottom:1px solid var(--hairline); color:var(--ink);
}
.mobile-nav a.m-link .m-idx{ font-family:var(--font-mono); font-size:.7rem; color:var(--muted); font-weight:500; }
.mobile-nav a.m-link.is-active{ color:var(--accent); }
.mobile-nav a.m-link.is-active .m-idx{ color:var(--accent); }
.mobile-nav .btn{ margin-top:22px; }
.mobile-nav__foot{ margin-top:auto; padding-top:26px; }
.mobile-nav__foot a{ color:var(--ink); font-weight:600; }

/* ======================================================================
   HERO (главная) - асимметричный
   ====================================================================== */
.hero{ position:relative; padding-top:clamp(40px,6vw,72px); padding-bottom:0; overflow:hidden; }
.hero__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(24px,4vw,56px); align-items:end; }
.hero__col{ padding-bottom:clamp(48px,7vw,96px); }
.hero__meta{ display:flex; align-items:center; gap:16px; margin-bottom:26px; }
.hero__meta .line{ height:1px; width:64px; background:var(--hairline-2); }
.hero h1{ margin-bottom:26px; }
.hero h1 .accent{ color:var(--accent); }
.hero__lead{ max-width:46ch; margin-bottom:34px; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.hero__figure{ position:relative; align-self:stretch; }
.hero__img-wrap{
  position:relative; height:100%; min-height:clamp(320px,52vw,600px);
  border-radius:var(--radius) var(--radius) 0 0; overflow:hidden;
  background:var(--surface-2);
}
.hero__img-wrap img{ width:100%; height:100%; object-fit:cover; }
.hero__fig-cap{
  position:absolute; left:16px; bottom:16px; z-index:2;
  background:color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter:blur(6px);
  border:1px solid var(--hairline);
  border-radius:8px; padding:9px 13px;
}
.hero__strip{
  display:flex; flex-wrap:wrap; gap:28px 48px; align-items:center;
  border-top:1px solid var(--hairline); border-bottom:1px solid var(--hairline);
  padding:22px 0; margin-top:8px;
}
.hero__strip .item{ display:flex; flex-direction:column; gap:3px; }
.hero__strip .item b{ font-family:var(--font-display); font-weight:800; font-size:1.05rem; }

/* ======================================================================
   БЛОК ДОВЕРИЯ / СТАТИСТИКА (counter-up)
   ====================================================================== */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--hairline); border:1px solid var(--hairline); border-radius:var(--radius); overflow:hidden; }
.stat{ background:var(--bg); padding:clamp(26px,3vw,42px); display:flex; flex-direction:column; gap:8px; }
.stat__num{ font-family:var(--font-display); font-weight:800; font-size:clamp(2.4rem,5vw,3.6rem); line-height:1; letter-spacing:-.03em; }
.stat__num .u{ color:var(--accent); }
.stat__label{ color:var(--muted); font-size:.98rem; max-width:26ch; }

/* ======================================================================
   КАРТОЧКИ УСЛУГ
   ====================================================================== */
.cards{ display:grid; gap:20px; }
.cards--4{ grid-template-columns:repeat(4,1fr); }
.cards--3{ grid-template-columns:repeat(3,1fr); }
.cards--2{ grid-template-columns:repeat(2,1fr); }

.card-svc{
  position:relative; background:var(--surface); border:1px solid var(--hairline);
  border-radius:var(--radius); padding:26px 24px 24px; min-height:230px;
  display:flex; flex-direction:column;
  transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
  overflow:hidden;
}
.card-svc::after{ /* уголковый маркер */
  content:""; position:absolute; top:14px; right:14px; width:14px; height:14px;
  border-top:1.5px solid var(--hairline-2); border-right:1.5px solid var(--hairline-2);
  transition:border-color var(--dur) var(--ease), width var(--dur) var(--ease), height var(--dur) var(--ease);
}
.card-svc:hover{ transform:translateY(-4px); box-shadow:var(--shadow-2); border-color:var(--hairline-2); }
.card-svc:hover::after{ border-color:var(--accent); width:20px; height:20px; }
.card-svc__ico{ width:34px; height:34px; color:var(--accent); margin-bottom:auto; }
.card-svc__ico svg{ width:100%; height:100%; stroke-width:1.4; }
.card-svc__idx{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.14em; color:var(--muted); margin-bottom:18px; }
.card-svc h3{ margin:22px 0 8px; font-size:1.22rem; }
.card-svc p{ color:var(--muted); font-size:.96rem; margin:0; }

/* ======================================================================
   ГАЛЕРЕЯ ПРОЕКТОВ
   ====================================================================== */
.proj-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(16px,2vw,26px); }
.proj-grid--home{ grid-template-columns:repeat(2,1fr); }
.proj{
  position:relative; display:block; text-align:left; width:100%;
  background:var(--surface-2); border:1px solid var(--hairline);
  border-radius:var(--radius); overflow:hidden;
}
.proj__media{ position:relative; aspect-ratio:4/3; overflow:hidden; background:var(--surface-2); }
.proj__media img{ width:100%; height:100%; object-fit:cover; transition:transform 620ms var(--ease); }
.proj:hover .proj__media img{ transform:scale(1.045); }
.proj__badge{
  position:absolute; top:14px; left:14px; z-index:2;
  font-family:var(--font-mono); font-size:.64rem; letter-spacing:.14em; text-transform:uppercase;
  background:color-mix(in srgb, var(--bg) 90%, transparent); backdrop-filter:blur(6px);
  border:1px solid var(--hairline); border-radius:6px; padding:6px 9px; color:var(--ink);
}
.proj__body{
  display:flex; justify-content:space-between; align-items:flex-start; gap:16px;
  padding:18px 20px 20px; background:var(--surface);
  border-top:1px solid var(--hairline);
}
.proj__title{ font-family:var(--font-display); font-weight:700; font-size:1.16rem; letter-spacing:-.01em; margin-bottom:5px; }
.proj__meta{ font-size:.86rem; color:var(--muted); font-family:var(--font-mono); letter-spacing:.02em; }
.proj__go{ flex:none; width:38px; height:38px; border-radius:50%; border:1px solid var(--hairline-2); display:grid; place-items:center; color:var(--ink);
  transition:background var(--dur) var(--ease), color var(--dur) var(--ease), transform var(--dur) var(--ease); }
.proj__go svg{ width:16px; height:16px; }
.proj:hover .proj__go{ background:var(--accent); color:#fff; border-color:var(--accent); transform:rotate(45deg); }

/* фильтры галереи */
.filters{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:clamp(28px,4vw,44px); }
.filter-btn{ font-family:var(--font-display); font-weight:600; font-size:.92rem; padding:9px 18px; border-radius:40px; border:1px solid var(--hairline-2); background:transparent; color:var(--muted); transition:color var(--dur) var(--ease), background var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.filter-btn:hover{ color:var(--ink); border-color:var(--ink); }
.filter-btn.is-active{ background:var(--ink); color:#fff; border-color:var(--ink); }
.proj.is-hidden{ display:none; }

/* ======================================================================
   МОДАЛКА ПРОЕКТА
   ====================================================================== */
.modal{ position:fixed; inset:0; z-index:200; display:none; }
.modal.is-open{ display:block; }
.modal__backdrop{ position:absolute; inset:0; background:rgba(15,16,18,.55); backdrop-filter:blur(3px); }
.modal__dialog{
  position:relative; z-index:1; max-width:960px; margin:6vh auto; width:calc(100% - 40px);
  background:var(--bg); border:1px solid var(--hairline); border-radius:var(--radius);
  overflow:hidden; box-shadow:var(--shadow-2); max-height:88vh; display:flex; flex-direction:column;
}
.modal__media{ aspect-ratio:16/9; background:var(--surface-2); overflow:hidden; }
.modal__media img{ width:100%; height:100%; object-fit:cover; }
.modal__body{ padding:clamp(22px,3vw,36px); overflow:auto; }
.modal__body h3{ font-size:clamp(1.5rem,3vw,2.1rem); margin-bottom:6px; }
.modal__meta{ font-family:var(--font-mono); font-size:.8rem; color:var(--muted); letter-spacing:.06em; margin-bottom:22px; }
.modal__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:8px; }
.modal__cols .mono{ display:block; margin-bottom:7px; }
.modal__close{
  position:absolute; top:14px; right:14px; z-index:3; width:42px; height:42px; border-radius:50%;
  background:var(--bg); border:1px solid var(--hairline-2); display:grid; place-items:center;
  transition:background var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.modal__close:hover{ background:var(--surface-2); transform:rotate(90deg); }
.modal__close svg{ width:18px; height:18px; }

/* ======================================================================
   КОМАНДА (честные плейсхолдеры, без стоковых лиц)
   ====================================================================== */
.team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.member{ background:var(--surface); border:1px solid var(--hairline); border-radius:var(--radius); overflow:hidden; transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.member:hover{ transform:translateY(-4px); box-shadow:var(--shadow-2); }
.member__ph{
  aspect-ratio:4/5; background:
    repeating-linear-gradient(135deg, transparent 0 11px, rgba(23,24,26,.03) 11px 12px), var(--surface-2);
  display:grid; place-items:center; position:relative; color:var(--muted);
  border-bottom:1px solid var(--hairline);
}
.member__ph svg{ width:46px; height:46px; opacity:.4; }
.member__ph .tag{ position:absolute; bottom:12px; left:12px; }
.member__body{ padding:18px 20px 22px; }
.member__body h3{ font-size:1.16rem; margin-bottom:3px; }
.member__role{ color:var(--accent); font-weight:600; font-size:.92rem; margin-bottom:8px; }
.member__note{ color:var(--muted); font-size:.9rem; margin:0; }

/* ======================================================================
   УСЛУГИ - развёрнутые секции
   ====================================================================== */
.svc-row{ display:grid; grid-template-columns:88px 1fr; gap:clamp(20px,4vw,56px); padding-block:clamp(40px,5vw,64px); border-top:1px solid var(--hairline); align-items:start; }
.svc-row:first-of-type{ border-top:0; }
.svc-row__num{ font-family:var(--font-mono); font-size:.8rem; color:var(--accent); letter-spacing:.1em; padding-top:8px; }
.svc-row__head{ display:flex; align-items:flex-start; gap:18px; margin-bottom:22px; }
.svc-row__ico{ width:40px; height:40px; color:var(--accent); flex:none; }
.svc-row__ico svg{ width:100%; height:100%; stroke-width:1.4; }
.svc-row h2{ font-size:clamp(1.6rem,3vw,2.3rem); }
.svc-row__cols{ display:grid; grid-template-columns:repeat(2,1fr); gap:26px 40px; margin-top:8px; }
.svc-block .mono{ display:block; margin-bottom:10px; }
.svc-block ul{ margin:0; padding:0; list-style:none; }
.svc-block li{ position:relative; padding-left:22px; margin-bottom:9px; color:var(--muted); }
.svc-block li::before{ content:""; position:absolute; left:0; top:11px; width:9px; height:1.5px; background:var(--accent); }
.svc-block p{ color:var(--muted); }

/* ======================================================================
   ЦИТАТА / ОТЗЫВ
   ====================================================================== */
.quote{ position:relative; max-width:960px; }
.quote blockquote{ margin:0; font-family:var(--font-display); font-weight:700; font-size:clamp(1.4rem,3vw,2.15rem); line-height:1.3; letter-spacing:-.02em; }
.quote__mark{ font-family:var(--font-display); font-size:5rem; line-height:.5; color:var(--accent); opacity:.3; height:38px; display:block; }
.quote__by{ display:flex; align-items:center; gap:14px; margin-top:26px; }
.quote__by .ph{ width:48px; height:48px; border-radius:50%; background:var(--surface-2); border:1px solid var(--hairline); display:grid; place-items:center; color:var(--muted); flex:none; }
.quote__by .ph svg{ width:22px; height:22px; opacity:.5; }
.quote__by b{ font-family:var(--font-display); }
.quote__by span{ display:block; color:var(--muted); font-size:.9rem; }

/* ======================================================================
   БАННЕР CTA (конец страниц)
   ====================================================================== */
.cta-band{ position:relative; background:var(--ink); color:#fff; border-radius:var(--radius); overflow:hidden; padding:clamp(40px,6vw,76px) clamp(28px,5vw,72px); }
.cta-band .ghost-num{ position:absolute; right:2%; bottom:-14%; font-size:clamp(9rem,22vw,20rem); -webkit-text-stroke-color:rgba(255,255,255,.1); }
.cta-band__in{ position:relative; z-index:1; max-width:640px; }
.cta-band .mono{ color:rgba(255,255,255,.6); }
.cta-band .mono .idx{ color:#8aa0e0; }
.cta-band h2{ color:#fff; font-size:clamp(1.9rem,4vw,3rem); margin:16px 0 14px; }
.cta-band p{ color:rgba(255,255,255,.72); max-width:48ch; margin-bottom:28px; }
.cta-band .btn--accent{ background:#fff; color:var(--ink); }
.cta-band .btn--accent:hover{ background:#e9edf7; box-shadow:0 10px 34px -10px rgba(255,255,255,.3); }
.cta-band .btn--ghost{ color:#fff; border-color:rgba(255,255,255,.3); }
.cta-band .btn--ghost:hover{ border-color:#fff; background:rgba(255,255,255,.08); }

/* ======================================================================
   КОНТАКТЫ + ФОРМА
   ====================================================================== */
.contact-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(28px,4vw,60px); align-items:start; }
.contact-list{ display:flex; flex-direction:column; }
.contact-item{ display:flex; gap:16px; padding:20px 0; border-top:1px solid var(--hairline); align-items:flex-start; }
.contact-item:first-child{ border-top:0; padding-top:0; }
.contact-item__ico{ width:22px; height:22px; color:var(--accent); flex:none; margin-top:3px; }
.contact-item__ico svg{ width:100%; height:100%; stroke-width:1.5; }
.contact-item .mono{ display:block; margin-bottom:5px; }
.contact-item a{ font-weight:600; font-size:1.08rem; transition:color var(--dur) var(--ease); }
.contact-item a:hover{ color:var(--accent); }
.contact-item .sub{ color:var(--muted); font-size:.92rem; }

.form{ background:var(--surface); border:1px solid var(--hairline); border-radius:var(--radius); padding:clamp(24px,3vw,40px); }
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field{ margin-bottom:18px; display:flex; flex-direction:column; gap:8px; }
.field label{ font-family:var(--font-mono); font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.field label .req{ color:var(--accent); }
.field input,.field select,.field textarea{
  font:inherit; font-size:1rem; color:var(--ink);
  background:var(--bg); border:1px solid var(--hairline-2); border-radius:var(--radius-sm);
  padding:13px 15px; transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  width:100%;
}
.field textarea{ resize:vertical; min-height:110px; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-tint); }
.field.is-invalid input,.field.is-invalid select,.field.is-invalid textarea{ border-color:#b23b3b; box-shadow:0 0 0 3px rgba(178,59,59,.12); }
.field__err{ color:#b23b3b; font-size:.82rem; display:none; }
.field.is-invalid .field__err{ display:block; }

.consent{ display:flex; gap:12px; align-items:flex-start; margin:6px 0 22px; }
.consent input{ margin-top:4px; width:18px; height:18px; flex:none; accent-color:var(--accent); }
.consent label{ font-size:.86rem; color:var(--muted); line-height:1.5; }
.consent a{ color:var(--accent); border-bottom:1px solid var(--hairline-2); }

.form__success{ display:none; text-align:center; padding:22px; }
.form__success.is-shown{ display:block; }
.form__success .ico{ width:52px; height:52px; margin:0 auto 16px; border-radius:50%; background:var(--accent-tint); color:var(--accent); display:grid; place-items:center; }
.form__success .ico svg{ width:26px; height:26px; }

.map-wrap{ position:relative; border:1px solid var(--hairline); border-radius:var(--radius); overflow:hidden; margin-top:clamp(40px,5vw,64px); background:var(--surface-2); }
.map-wrap iframe{ width:100%; height:clamp(300px,42vw,460px); border:0; display:block; filter:grayscale(.35) contrast(.95); }
.map-note{ position:absolute; top:14px; left:14px; z-index:2; background:color-mix(in srgb, var(--bg) 92%, transparent); backdrop-filter:blur(6px); border:1px solid var(--hairline); border-radius:8px; padding:8px 12px; }

/* ======================================================================
   О БЮРО - блоки
   ====================================================================== */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,64px); align-items:center; }
.figure{ position:relative; border-radius:var(--radius); overflow:hidden; background:var(--surface-2); border:1px solid var(--hairline); }
.figure img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/3; }
.figure__cap{ position:absolute; left:14px; bottom:14px; background:color-mix(in srgb, var(--bg) 90%, transparent); backdrop-filter:blur(6px); border:1px solid var(--hairline); border-radius:8px; padding:8px 12px; }
.approach{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--hairline); border:1px solid var(--hairline); border-radius:var(--radius); overflow:hidden; margin-top:8px; }
.approach .cell{ background:var(--bg); padding:clamp(22px,3vw,34px); }
.approach .cell .num{ font-family:var(--font-mono); color:var(--accent); font-size:.8rem; letter-spacing:.1em; }
.approach .cell h3{ margin:14px 0 8px; font-size:1.2rem; }
.approach .cell p{ color:var(--muted); margin:0; font-size:.96rem; }

/* лента логотипов/регалий */
.badges{ display:flex; flex-wrap:wrap; gap:14px; }
.badge{ display:inline-flex; align-items:center; gap:10px; border:1px solid var(--hairline); background:var(--surface); border-radius:8px; padding:12px 16px; }
.badge svg{ width:20px; height:20px; color:var(--accent); flex:none; }
.badge b{ font-family:var(--font-display); font-size:.95rem; }
.badge span{ font-family:var(--font-mono); font-size:.68rem; color:var(--muted); letter-spacing:.06em; }

/* маленькая шапка внутренней страницы */
.pagehead{ padding-top:clamp(40px,6vw,72px); padding-bottom:clamp(30px,4vw,52px); }
.pagehead__meta{ display:flex; align-items:center; gap:14px; margin-bottom:22px; }
.pagehead__meta .line{ height:1px; width:52px; background:var(--hairline-2); }
.pagehead h1{ font-size:clamp(2.3rem,6vw,4.4rem); letter-spacing:-.03em; max-width:16ch; }
.pagehead__lead{ max-width:56ch; margin-top:22px; }

/* ======================================================================
   ПОДВАЛ (идентичен на всех страницах)
   ====================================================================== */
.site-footer{ position:relative; z-index:2; background:var(--surface); border-top:1px solid var(--hairline); padding-top:clamp(52px,6vw,80px); margin-top:clamp(60px,8vw,120px); }
.footer__top{ display:grid; grid-template-columns:1.4fr 1fr 1.3fr; gap:clamp(28px,4vw,56px); padding-bottom:clamp(40px,5vw,60px); }
.footer__brand .brand{ margin-bottom:18px; }
.footer__brand p{ color:var(--muted); max-width:34ch; font-size:.96rem; }
.footer__col h4{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); font-weight:500; margin-bottom:18px; }
.footer__col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.footer__col a{ color:var(--ink); font-weight:500; transition:color var(--dur) var(--ease); }
.footer__col a:hover{ color:var(--accent); }
.footer__col .muted-line{ color:var(--muted); font-size:.94rem; }
.socials{ display:flex; gap:10px; margin-top:18px; }
.socials a{ width:40px; height:40px; border:1px solid var(--hairline-2); border-radius:8px; display:grid; place-items:center; color:var(--ink); transition:background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.socials a:hover{ background:var(--accent); color:#fff; border-color:var(--accent); }
.socials svg{ width:18px; height:18px; }
.footer__bottom{ display:flex; flex-wrap:wrap; gap:14px 28px; align-items:center; justify-content:space-between; padding:24px 0 30px; border-top:1px solid var(--hairline); }
.footer__bottom .mono{ font-size:.7rem; }
.footer__bottom .links{ display:flex; gap:22px; flex-wrap:wrap; }
.footer__bottom .links a{ color:var(--muted); font-size:.86rem; }
.footer__bottom .links a:hover{ color:var(--ink); }

/* ======================================================================
   КАЛЬКУЛЯТОР СТОИМОСТИ
   ====================================================================== */
.calc{ display:grid; grid-template-columns:1.25fr .85fr; gap:clamp(24px,3vw,44px); align-items:start; }
.calc__controls{ display:flex; flex-direction:column; gap:clamp(22px,3vw,34px); }
.opt-group{ border:0; margin:0; padding:0; min-width:0; }
.opt-group legend{ padding:0; margin-bottom:14px; display:inline-flex; align-items:center; gap:9px; }
.opts{ display:grid; gap:12px; }
.opts--3{ grid-template-columns:repeat(3,1fr); }
.opts--check{ grid-template-columns:1fr; gap:10px; }
.opt{ position:relative; display:block; cursor:pointer; }
.opt > input{ position:absolute; inset:0; opacity:0; cursor:pointer; margin:0; }
.opt__box{ height:100%; display:flex; flex-direction:column; gap:3px; padding:15px 16px; border:1px solid var(--hairline-2); border-radius:var(--radius-sm); background:var(--surface); transition:border-color var(--dur) var(--ease), background var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.opt__box b{ font-family:var(--font-display); font-weight:700; font-size:1rem; letter-spacing:-.01em; }
.opt__box small{ color:var(--muted); font-size:.82rem; }
.opt:hover .opt__box{ border-color:var(--ink); }
.opt > input:checked + .opt__box{ border-color:var(--accent); background:var(--accent-tint); box-shadow:inset 0 0 0 1px var(--accent); }
.opt > input:focus-visible + .opt__box{ outline:2px solid var(--accent); outline-offset:2px; }
.opt--check .opt__box{ flex-direction:row; align-items:center; justify-content:space-between; gap:14px; }
.opt--check .opt__box .l{ display:flex; align-items:center; gap:13px; }
.opt--check .tick{ width:22px; height:22px; border:1px solid var(--hairline-2); border-radius:6px; display:grid; place-items:center; color:#fff; flex:none; transition:background var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.opt--check .tick svg{ width:14px; height:14px; opacity:0; transition:opacity var(--dur) var(--ease); }
.opt--check > input:checked + .opt__box .tick{ background:var(--accent); border-color:var(--accent); }
.opt--check > input:checked + .opt__box .tick svg{ opacity:1; }
.opt--check .price-hint{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.06em; color:var(--muted); text-transform:uppercase; }

.area-head{ display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:16px; }
.area-num{ font:inherit; font-family:var(--font-mono); width:130px; text-align:right; color:var(--ink); background:var(--bg); border:1px solid var(--hairline-2); border-radius:8px; padding:9px 13px; }
.area-num:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-tint); }
.range{ -webkit-appearance:none; appearance:none; width:100%; height:3px; background:var(--hairline-2); border-radius:3px; outline:none; }
.range::-webkit-slider-thumb{ -webkit-appearance:none; appearance:none; width:22px; height:22px; border-radius:50%; background:var(--accent); border:3px solid var(--surface); box-shadow:0 1px 5px rgba(23,24,26,.3); cursor:pointer; transition:transform var(--dur) var(--ease); }
.range::-webkit-slider-thumb:hover{ transform:scale(1.12); }
.range::-moz-range-thumb{ width:19px; height:19px; border:3px solid var(--surface); border-radius:50%; background:var(--accent); box-shadow:0 1px 5px rgba(23,24,26,.3); cursor:pointer; }
.range:focus-visible::-webkit-slider-thumb{ outline:2px solid var(--accent); outline-offset:2px; }
.scale{ display:flex; justify-content:space-between; margin-top:11px; }

.calc__result{ position:sticky; top:calc(var(--header-h) + 20px); }
.calc__result-card{ position:relative; background:var(--ink); color:#fff; border-radius:var(--radius); padding:clamp(24px,3vw,34px); overflow:hidden; }
.calc__result-card .mono{ color:rgba(255,255,255,.55); }
.calc__price{ font-family:var(--font-display); font-weight:800; font-size:clamp(1.7rem,3.4vw,2.5rem); letter-spacing:-.025em; margin:10px 0 4px; }
.calc__perm2{ color:rgba(255,255,255,.7); font-family:var(--font-mono); font-size:.85rem; }
.calc__summary{ margin-top:16px; font-size:.72rem; line-height:1.5; letter-spacing:.04em; }
.calc__breakdown{ list-style:none; margin:18px 0 20px; padding:18px 0; border-top:1px solid rgba(255,255,255,.15); border-bottom:1px solid rgba(255,255,255,.15); display:flex; flex-direction:column; gap:11px; }
.calc__breakdown li{ display:flex; justify-content:space-between; gap:16px; font-size:.94rem; }
.calc__breakdown li span:first-child{ color:rgba(255,255,255,.82); }
.calc__breakdown li span:last-child{ font-family:var(--font-mono); white-space:nowrap; }
.calc__breakdown li.is-note span{ color:#8aa0e0; }
.calc__term-row{ display:flex; justify-content:space-between; align-items:center; gap:16px; margin-bottom:22px; }
.calc__term-row b{ font-family:var(--font-display); font-weight:700; }
.calc__result-card .btn--accent{ background:#fff; color:var(--ink); }
.calc__result-card .btn--accent:hover{ background:#e9edf7; box-shadow:0 10px 34px -10px rgba(255,255,255,.28); }
.calc__note{ margin:16px 0 0; font-size:.72rem; line-height:1.55; color:rgba(255,255,255,.5); }

@media (max-width:900px){
  .calc{ grid-template-columns:1fr; }
  .calc__result{ position:static; }
}
@media (max-width:560px){
  .opts--3{ grid-template-columns:1fr; }
  .area-num{ width:110px; }
}

/* ======================================================================
   REVEAL (fail-safe: видно без JS)
   ====================================================================== */
.js .reveal{ opacity:0; transform:translateY(18px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.js .reveal.is-in{ opacity:1; transform:none; }
.js .reveal[data-delay="1"]{ transition-delay:.08s; }
.js .reveal[data-delay="2"]{ transition-delay:.16s; }
.js .reveal[data-delay="3"]{ transition-delay:.24s; }
.js .reveal[data-delay="4"]{ transition-delay:.32s; }

/* ======================================================================
   АДАПТИВ
   ====================================================================== */
@media (max-width:1040px){
  .cards--4{ grid-template-columns:repeat(2,1fr); }
  .footer__top{ grid-template-columns:1fr 1fr; }
  .footer__brand{ grid-column:1 / -1; }
}
@media (max-width:900px){
  :root{ --header-h:60px; }
  .nav, .header__cta{ display:none; }
  .burger{ display:inline-block; }
  .hero__grid{ grid-template-columns:1fr; }
  .hero__figure{ order:-1; }
  .hero__img-wrap{ min-height:clamp(240px,60vw,360px); border-radius:var(--radius); }
  .hero__col{ padding-bottom:clamp(36px,8vw,56px); }
  .split{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .modal__cols{ grid-template-columns:1fr; gap:14px; }
}
@media (max-width:720px){
  body{ font-size:16px; }
  .stats{ grid-template-columns:1fr; }
  .cards--4,.cards--3,.cards--2{ grid-template-columns:1fr; }
  .proj-grid,.proj-grid--home{ grid-template-columns:1fr; }
  .team-grid{ grid-template-columns:1fr 1fr; }
  .approach{ grid-template-columns:1fr; }
  .form__row{ grid-template-columns:1fr; }
  .svc-row{ grid-template-columns:1fr; gap:14px; }
  .svc-row__num{ padding-top:0; }
  .svc-row__cols{ grid-template-columns:1fr; }
  .footer__top{ grid-template-columns:1fr; }
  .hero__strip{ gap:18px 32px; }
}
@media (max-width:480px){
  .team-grid{ grid-template-columns:1fr; }
  .brand__tag{ display:none; }
  .footer__bottom{ flex-direction:column; align-items:flex-start; }
}

/* уважение к prefers-reduced-motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  .js .reveal{ opacity:1 !important; transform:none !important; }
  .proj:hover .proj__media img{ transform:none; }
}
