/* =====================================================================
   Производственно-складской комплекс · Колобово
   Aesthetic: industrial editorial — графит/слоновая кость + янтарь
   Type pairing: Fraunces (display, italic) + Geist (body)
   ===================================================================== */

/* ---------- ТОКЕНЫ ---------- */
:root{
  --ink:        #0E1620;
  --ink-2:      #152033;
  --ink-3:      #1B2A3F;
  --paper:      #F6F4EF;
  --paper-2:    #EDEAE2;
  --paper-3:    #E5E0D5;
  --line:       #D9D4C8;
  --line-d:     #2A3A52;
  --text:       #1F2937;
  --text-2:     #4B5563;
  --muted:      #6B7280;
  --muted-d:    #8FA0B5;
  --white:      #FFFFFF;

  --acc:        #E08A2B;
  --acc-d:      #C57420;
  --acc-soft:   #FBF1E2;
  --acc-soft-2: #F5E8D2;

  --green:      #15803D;
  --red:        #B91C1C;

  --r-sm: 4px;
  --r:    8px;
  --r-lg: 16px;

  --shadow-sm: 0 1px 2px rgba(14, 22, 32, .06);
  --shadow:    0 12px 32px -16px rgba(14, 22, 32, .25);
  --shadow-lg: 0 30px 60px -24px rgba(14, 22, 32, .35);

  --display:    'Fraunces', Georgia, 'Times New Roman', serif;
  --sans:       'Geist', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --mono:       'Geist Mono', 'JetBrains Mono', ui-monospace, monospace;

  --max:    1280px;
  --max-narrow: 980px;
  --gap:    clamp(20px, 4vw, 56px);
  --pad-y:  clamp(64px, 9vw, 120px);
}

/* ---------- БАЗА ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--sans);
  font-size:17px;
  line-height:1.55;
  color:var(--text);
  background:var(--paper);
  font-feature-settings:'ss01','cv11';
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:0; background:none; color:inherit; }
em{ font-style:italic; }

::selection{ background:var(--acc); color:var(--white); }

.wrap{ max-width:var(--max); margin:0 auto; padding:0 24px; }
.wrap--narrow{ max-width:var(--max-narrow); }

/* ---------- ТИПОГРАФИКА ---------- */
h1, h2, h3, h4{
  font-family:var(--display);
  font-weight:600;
  letter-spacing:-0.02em;
  line-height:1.04;
  margin:0;
  color:var(--ink);
  font-variation-settings: "SOFT" 30, "WONK" 0;
}
h2 em, h1 em{ font-style:italic; font-variation-settings:"SOFT" 50, "WONK" 1; color:var(--acc-d); font-weight:500; }
.section--dark h2{ color:var(--white); }
.section--dark h2 em{ color:var(--acc); }

.kicker{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--mono);
  font-size:11px; font-weight:600; letter-spacing:.18em; text-transform:uppercase;
  color:var(--acc-d);
}
.kicker::before{
  content:''; width:24px; height:1px; background:var(--acc); display:inline-block;
}
.kicker--accent{ color:var(--acc); }
.kicker--accent::before{ background:var(--acc); }
.section--dark .kicker{ color:var(--acc); }

.lead{
  font-size:clamp(17px, 1.5vw, 20px);
  color:var(--text-2);
  line-height:1.55;
  max-width:64ch;
  margin:0;
}
.section--dark .lead{ color:var(--muted-d); }
.lead__muted{ display:inline-block; margin-left:12px; color:var(--muted); font-family:var(--mono); font-size:14px; }

/* ---------- НАВИГАЦИЯ ---------- */
.nav{
  position:sticky; top:0; z-index:100;
  background:rgba(14,22,32,.92);
  backdrop-filter:blur(12px) saturate(140%);
  -webkit-backdrop-filter:blur(12px) saturate(140%);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:background .25s;
}
.nav__wrap{
  max-width:var(--max); margin:0 auto; padding:14px 24px;
  display:flex; align-items:center; gap:24px;
}
.nav__brand{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
.nav__brand-mark{
  width:36px; height:36px; display:grid; place-items:center;
  font-family:var(--display); font-style:italic; font-weight:700; font-size:22px;
  color:var(--acc); border:1.5px solid var(--acc); border-radius:6px;
  flex-shrink:0;
}
.nav__brand-text{ display:flex; flex-direction:column; line-height:1.1; }
.nav__brand-text strong{ font-family:var(--sans); font-weight:600; font-size:14px; color:var(--white); }
.nav__brand-text em{ font-family:var(--mono); font-style:normal; font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted-d); }

.nav__links{ display:flex; gap:4px; margin-left:auto; flex-wrap:wrap; }
.nav__links a{
  padding:8px 12px; font-size:14px; font-weight:500;
  color:rgba(255,255,255,.78); border-radius:4px;
  transition:color .15s, background .15s;
}
.nav__links a:hover{ color:var(--white); background:rgba(255,255,255,.06); }

.nav__cta{
  padding:10px 18px; font-size:13px; font-weight:600; letter-spacing:.04em;
  background:var(--acc); color:var(--ink); border-radius:4px;
  transition:transform .15s, background .15s; flex-shrink:0;
}
.nav__cta:hover{ background:#F09833; transform:translateY(-1px); }

.nav__burger{
  display:none; width:40px; height:40px; flex-direction:column; justify-content:center; align-items:center; gap:5px;
  border-radius:4px;
}
.nav__burger span{ display:block; width:22px; height:2px; background:var(--white); transition:transform .25s, opacity .15s; }
.nav__burger.is-open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2){ opacity:0; }
.nav__burger.is-open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

@media (max-width:1100px){
  .nav__links a{ padding:8px 10px; font-size:13px; }
}
@media (max-width:880px){
  .nav__cta{ display:none; }
  .nav__burger{ display:flex; }
  .nav__links{
    position:fixed; inset:64px 0 auto 0;
    flex-direction:column; gap:0;
    background:var(--ink); padding:20px;
    transform:translateY(-150%); transition:transform .3s ease;
    border-bottom:1px solid rgba(255,255,255,.08);
    box-shadow:0 30px 60px -20px rgba(0,0,0,.5);
  }
  .nav__links.is-open{ transform:translateY(0); }
  .nav__links a{ padding:14px 8px; font-size:16px; border-bottom:1px solid rgba(255,255,255,.05); }
}

/* ---------- HERO ---------- */
.hero{
  position:relative; min-height:100svh;
  display:flex; flex-direction:column; justify-content:center;
  padding:120px 0 64px;
  color:var(--white); overflow:hidden;
  isolation:isolate;
}
.hero__bg{ position:absolute; inset:0; z-index:-2; }
.hero__bg img{ width:100%; height:100%; object-fit:cover; }
.hero__overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 70% 20%, rgba(14,22,32,.15), rgba(14,22,32,.55) 60%),
    linear-gradient(to bottom, rgba(14,22,32,.5) 0%, rgba(14,22,32,.55) 25%, rgba(14,22,32,.92) 75%, rgba(14,22,32,1) 100%);
}

.hero__content{ position:relative; max-width:var(--max); margin:0 auto; padding:0 24px; width:100%; }

.hero__kicker{
  display:flex; align-items:center; gap:14px; flex-wrap:wrap;
  font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  color:rgba(255,255,255,.7); margin-bottom:24px;
}
.hero__kicker .dash{ width:32px; height:1px; background:var(--acc); }
.hero__kicker > span:nth-child(2){ color:var(--white); font-weight:600; }
.hero__kicker-region{
  margin-left:auto; padding:6px 12px; border:1px solid rgba(255,255,255,.2);
  border-radius:4px; color:rgba(255,255,255,.85);
}
@media(max-width:760px){ .hero__kicker-region{ margin-left:0; } }

.hero__title{
  font-family:var(--display); font-weight:550;
  font-size:clamp(36px, 5.6vw, 78px);
  line-height:.98; letter-spacing:-0.035em;
  margin:0 0 22px; max-width:13ch;
  font-variation-settings:"SOFT" 40, "WONK" 0;
}
.hero__title-1{ display:block; }
.hero__title-2{ display:block; }
.hero__title-2 em{ font-style:italic; font-variation-settings:"SOFT" 70, "WONK" 1; color:var(--acc); font-weight:500; }
.hero__title-3{ display:block; }

.hero__sub{
  font-size:clamp(15px, 1.4vw, 18px);
  line-height:1.5; color:rgba(255,255,255,.78);
  max-width:54ch; margin:0 0 32px;
}

/* статистика — лента в hero */
.hero__stats{
  display:grid; grid-template-columns:repeat(5, 1fr);
  gap:0; border-top:1px solid rgba(255,255,255,.15); border-bottom:1px solid rgba(255,255,255,.15);
  margin-bottom:28px; padding:18px 0;
}
.stat{ position:relative; padding:0 14px; }
.stat:not(:last-child){ border-right:1px solid rgba(255,255,255,.08); }
.stat__num{
  font-family:var(--display); font-weight:600; font-size:clamp(26px, 3.4vw, 42px);
  line-height:1; letter-spacing:-0.04em; color:var(--white);
  display:flex; align-items:baseline; gap:6px; margin-bottom:6px;
  font-variation-settings:"SOFT" 30;
}
.stat__num span{ font-family:var(--sans); font-size:.36em; font-weight:500; letter-spacing:0; color:var(--acc); }
.stat__lbl{ font-size:12px; color:rgba(255,255,255,.6); line-height:1.35; }

@media(max-width:880px){
  .hero__stats{ grid-template-columns:repeat(2, 1fr); gap:1px; padding:0; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.08); }
  .stat{ background:var(--ink); padding:16px; border:0 !important; }
  .stat:nth-child(5){ grid-column:1/-1; }
}

.hero__cta{ display:flex; gap:12px; flex-wrap:wrap; }

.hero__scroll{
  position:absolute; bottom:24px; left:50%; transform:translateX(-50%);
  width:24px; height:36px;
  border:1.5px solid rgba(255,255,255,.4); border-radius:14px;
  display:none; align-items:flex-start; justify-content:center; padding-top:8px;
}
.hero__scroll span{ width:2px; height:8px; background:var(--white); border-radius:2px; animation:scroll 1.5s ease-in-out infinite; }
@keyframes scroll{ 0%,100%{transform:translateY(0); opacity:1;} 50%{transform:translateY(8px); opacity:.3;} }
@media (min-width:880px) and (min-height:700px){ .hero__scroll{ display:flex; } }

/* ---------- КНОПКИ ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 24px;
  font-family:var(--sans); font-weight:600; font-size:14px; letter-spacing:.02em;
  border-radius:4px; border:1.5px solid transparent;
  transition:transform .15s ease, background .15s, border-color .15s, color .15s;
  white-space:nowrap; user-select:none;
}
.btn:hover{ transform:translateY(-1px); }
.btn:active{ transform:translateY(0); }

.btn--primary{ background:var(--acc); color:var(--ink); border-color:var(--acc); }
.btn--primary:hover{ background:#F09833; border-color:#F09833; }

.btn--ghost{ background:transparent; color:var(--white); border-color:rgba(255,255,255,.3); }
.btn--ghost:hover{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.5); }

.btn--ghost-dark{ background:transparent; color:var(--ink); border-color:var(--ink); }
.btn--ghost-dark:hover{ background:var(--ink); color:var(--white); }

.btn--whats{ background:#25D366; color:var(--white); border-color:#25D366; }
.btn--whats:hover{ background:#1FBA58; border-color:#1FBA58; }

.btn--tg{ background:#229ED9; color:var(--white); border-color:#229ED9; }
.btn--tg:hover{ background:#1B8AC2; border-color:#1B8AC2; }

.btn--block{ width:100%; justify-content:center; padding:16px; }

.btn[hidden]{ display:none; }

/* ---------- БЫСТРЫЙ СТАРТ ---------- */
.quick{ background:var(--ink); padding:48px 0 64px; }
.quick__grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:1px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
}
.quick__card{
  background:var(--ink); padding:32px;
  display:flex; flex-direction:column; gap:8px;
  position:relative; transition:background .2s;
}
.quick__card:hover{ background:var(--ink-2); }
.quick__num{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; color:var(--acc); }
.quick__card h3{
  font-family:var(--display); font-weight:550; font-size:24px; color:var(--white);
  letter-spacing:-0.02em; margin:0;
  font-variation-settings:"SOFT" 40;
}
.quick__card p{ color:var(--muted-d); font-size:14px; margin:0; }
.quick__card .arr{
  position:absolute; right:24px; bottom:24px; color:var(--acc); font-size:20px;
  transition:transform .2s;
}
.quick__card:hover .arr{ transform:translateX(6px); }
.quick__card--accent{ background:var(--acc); }
.quick__card--accent:hover{ background:#F09833; }
.quick__card--accent .quick__num,
.quick__card--accent h3,
.quick__card--accent p,
.quick__card--accent .arr{ color:var(--ink); }

@media(max-width:880px){ .quick__grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .quick__grid{ grid-template-columns:1fr; } .quick__card{ padding:24px; } }

/* ---------- СЕКЦИИ ---------- */
.section{ padding:var(--pad-y) 0; }
.section--paper{ background:var(--paper); color:var(--text); }
.section--paper-tinted{ background:linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%); }
.section--dark{ background:var(--ink); color:var(--white); }
.section--gallery{ background:var(--ink-2); color:var(--white); padding-top:var(--pad-y); padding-bottom:var(--pad-y); }
.section--gallery .section__head{ color:var(--white); }
.section--gallery h2{ color:var(--white); }
.section--gallery h2 em{ color:var(--acc); }

.section__head{ max-width:760px; margin-bottom:64px; }
.section__head--dark{ color:var(--white); }

.section__head h2{
  font-size:clamp(36px, 5.5vw, 64px);
  line-height:1.02; margin:14px 0 18px;
}

/* ---------- BIGSTATS (об объекте) ---------- */
.bigstats{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  margin-bottom:32px;
}
.bigstat{
  background:var(--white); padding:36px 28px;
  border-left:3px solid var(--acc);
  position:relative;
}
.bigstat__num{
  font-family:var(--display); font-weight:600;
  font-size:clamp(34px, 4vw, 48px); line-height:1; letter-spacing:-0.04em; color:var(--ink);
  display:flex; align-items:baseline; gap:6px;
  font-variation-settings:"SOFT" 40;
}
.bigstat__num span{ font-family:var(--sans); font-size:.34em; font-weight:500; color:var(--acc-d); letter-spacing:0; }
.bigstat__lbl{ font-weight:600; font-size:13px; color:var(--ink); margin:14px 0 8px; }
.bigstat__desc{ color:var(--muted); font-size:13px; line-height:1.5; }

@media(max-width:880px){ .bigstats{ grid-template-columns:1fr 1fr; } }
@media(max-width:520px){ .bigstats{ grid-template-columns:1fr; } }

.freeplate{
  display:flex; align-items:center; gap:24px;
  background:var(--ink); color:var(--white);
  padding:24px 28px; border-radius:var(--r);
  border-left:3px solid var(--acc);
  margin-bottom:32px;
}
.freeplate__l{ display:flex; flex-direction:column; gap:8px; flex-shrink:0; }
.freeplate__num{
  font-family:var(--display); font-weight:600; font-size:42px; line-height:1; color:var(--white);
  display:flex; align-items:baseline; gap:6px;
}
.freeplate__num span{ font-family:var(--sans); font-size:.4em; color:var(--acc); }
.freeplate__r{ color:var(--muted-d); font-size:15px; line-height:1.5; }
@media(max-width:680px){ .freeplate{ flex-direction:column; align-items:flex-start; gap:12px; } }

.checklist{
  display:grid; grid-template-columns:1fr 1fr; gap:32px;
  border-top:1px solid var(--line); padding-top:32px;
}
.checklist__col h4{
  font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.18em; text-transform:uppercase;
  color:var(--acc-d); margin:0 0 16px;
}
.checklist__col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px; }
.checklist__col li{ position:relative; padding-left:18px; font-size:15px; }
.checklist__col li::before{
  content:''; position:absolute; left:0; top:9px;
  width:6px; height:6px; background:var(--acc); border-radius:50%;
}
@media(max-width:680px){ .checklist{ grid-template-columns:1fr; gap:24px; } }

/* ---------- ПРЕИМУЩЕСТВА (тёмные) ---------- */
.adv{
  display:grid; grid-template-columns:repeat(5, 1fr); gap:1px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
}
.adv__card{
  background:var(--ink); padding:28px 24px;
  display:flex; flex-direction:column; gap:10px;
  transition:background .2s;
}
.adv__card:hover{ background:var(--ink-2); }
.adv__icon{
  width:42px; height:42px; display:grid; place-items:center;
  border:1px solid var(--acc); border-radius:6px;
  color:var(--acc); font-size:18px; line-height:1;
  margin-bottom:8px;
}
.adv__card h3{
  font-family:var(--display); font-weight:600; font-size:18px;
  color:var(--white); letter-spacing:-0.01em;
  font-variation-settings:"SOFT" 40;
}
.adv__card p{ color:var(--muted-d); font-size:13px; line-height:1.5; margin:0; }
.adv__card--accent{ background:linear-gradient(155deg, var(--acc-d) 0%, var(--acc) 100%); }
.adv__card--accent:hover{ background:linear-gradient(155deg, var(--acc) 0%, #F09833 100%); }
.adv__card--accent .adv__icon{ border-color:var(--ink); color:var(--ink); }
.adv__card--accent h3{ color:var(--ink); }
.adv__card--accent p{ color:rgba(14,22,32,.75); }

@media(max-width:1100px){ .adv{ grid-template-columns:repeat(3, 1fr); } }
@media(max-width:680px){ .adv{ grid-template-columns:1fr 1fr; } }

/* ---------- VS-ТАБЛИЦА ---------- */
.vs{
  border:1px solid var(--line); background:var(--white);
  border-radius:var(--r); overflow:hidden; margin-bottom:32px;
}
.vs__head, .vs__row{
  display:grid; grid-template-columns:1.4fr 1.2fr 1.2fr;
}
.vs__head{ background:var(--ink); }
.vs__head .vs__cell{ color:var(--white); padding:18px 20px; font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; }
.vs__head .vs__cell--old{ color:var(--muted-d); }
.vs__head .vs__cell--new{ color:var(--acc); }

.vs__row{ border-top:1px solid var(--line); }
.vs__row:nth-child(odd) .vs__cell--param{ background:var(--paper); }
.vs__row:nth-child(odd) .vs__cell--old{ background:var(--paper); }
.vs__row:nth-child(odd) .vs__cell--new{ background:var(--acc-soft); }
.vs__row:nth-child(even) .vs__cell--new{ background:var(--acc-soft-2); }

.vs__cell{ padding:18px 20px; font-size:14px; line-height:1.5; }
.vs__cell--param{ font-weight:600; color:var(--ink); }
.vs__cell--old{ color:var(--muted); font-size:13px; }
.vs__cell--new strong{ color:var(--ink); font-weight:600; }

@media(max-width:760px){
  .vs__head{ display:none; }
  .vs__row{ grid-template-columns:1fr; padding:0; }
  .vs__cell{ padding:14px 18px; }
  .vs__cell--param{ background:var(--ink) !important; color:var(--white); padding:12px 18px; font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; font-weight:600; }
  .vs__cell--old::before{ content:'Стройка с нуля: '; color:var(--muted); font-weight:600; }
  .vs__cell--new::before{ content:'Эта площадка: '; color:var(--acc-d); font-weight:600; font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; display:block; margin-bottom:4px; }
}

.conclusion{
  background:var(--ink); color:var(--white);
  padding:28px 32px; border-radius:var(--r);
  border-left:4px solid var(--acc);
}
.conclusion p{
  font-family:var(--display); font-weight:500; font-size:clamp(18px, 2vw, 22px);
  margin:8px 0 0; line-height:1.4; letter-spacing:-0.01em;
}

/* ---------- СЦЕНАРИИ ---------- */
.scn{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  margin-bottom:24px;
}
.scn__card{
  background:var(--white); padding:28px 24px 32px;
  display:flex; flex-direction:column; gap:12px;
  position:relative; transition:transform .2s, background .2s;
}
.scn__card:hover{ background:var(--paper); }
.scn__num{
  font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.18em;
  color:var(--acc-d);
  display:inline-flex; align-items:center; gap:8px;
}
.scn__num::after{ content:''; flex:1; height:1px; background:var(--line); max-width:40px; }
.scn__card h3{
  font-family:var(--display); font-weight:600; font-size:20px; line-height:1.1;
  color:var(--ink); letter-spacing:-0.015em;
  font-variation-settings:"SOFT" 40;
}
.scn__card p{ color:var(--muted); font-size:13.5px; line-height:1.5; margin:0; }

@media(max-width:1100px){ .scn{ grid-template-columns:repeat(3, 1fr); } }
@media(max-width:760px){ .scn{ grid-template-columns:1fr 1fr; } }
@media(max-width:480px){ .scn{ grid-template-columns:1fr; } }

.scn__note{
  background:var(--white); border-left:3px solid var(--acc);
  padding:20px 24px; border-radius:0 var(--r) var(--r) 0;
  font-size:15px; color:var(--text-2); margin:0;
}
.scn__note strong{ color:var(--ink); }

/* ---------- ИНЖЕНЕРКА ---------- */
.eng{
  display:grid; grid-template-columns:repeat(2, 1fr); gap:24px;
  margin-bottom:24px;
}
.eng__card{
  background:var(--white); color:var(--ink);
  border-radius:var(--r); overflow:hidden;
  box-shadow:var(--shadow);
}
.eng__card header{
  background:var(--ink); color:var(--white);
  padding:18px 24px;
  display:flex; align-items:center; gap:14px;
}
.eng__ico{
  width:38px; height:38px; display:grid; place-items:center;
  background:var(--acc); color:var(--ink);
  border-radius:6px; font-size:18px; font-weight:700; flex-shrink:0;
}
.eng__card h3{
  color:var(--white); font-size:20px;
}
.eng__list{ list-style:none; margin:0; padding:8px 24px 24px; display:flex; flex-direction:column; }
.eng__list li{
  padding:18px 0; border-bottom:1px solid var(--line);
}
.eng__list li:last-child{ border-bottom:0; }
.eng__num{
  font-family:var(--display); font-weight:600;
  font-size:32px; line-height:1; color:var(--ink);
  letter-spacing:-0.03em;
  display:flex; align-items:baseline; gap:6px;
  font-variation-settings:"SOFT" 30;
}
.eng__num span{ font-family:var(--sans); font-size:14px; font-weight:500; color:var(--acc-d); letter-spacing:0; }
.eng__num--small{ font-family:var(--sans); font-size:22px; font-weight:600; }
.eng__desc{ color:var(--muted); font-size:13px; margin-top:6px; }

@media(max-width:880px){ .eng{ grid-template-columns:1fr; } }

.eng__note{
  background:var(--ink-2); border-left:3px solid var(--acc);
  padding:18px 24px; border-radius:var(--r);
  font-size:14px; color:var(--muted-d);
}

/* ---------- КАДРЫ ---------- */
.staff{
  display:grid; grid-template-columns:1.3fr 1fr; gap:64px;
  align-items:center;
}
.staff__l h2{ margin:14px 0 24px; }
.staff__l p{ font-size:16px; line-height:1.65; color:var(--text-2); margin:0 0 16px; max-width:55ch; }
.staff__l p strong{ color:var(--ink); }
.staff__r{
  background:var(--ink); color:var(--white);
  padding:48px 40px; border-radius:var(--r-lg);
  border-left:4px solid var(--acc);
}
.staff__bignum{
  font-family:var(--display); font-weight:600;
  font-size:clamp(80px, 12vw, 140px); line-height:1; color:var(--white);
  letter-spacing:-0.06em;
  font-variation-settings:"SOFT" 40;
}
.staff__biglbl{ font-size:15px; color:var(--muted-d); margin-top:8px; }
.staff__divider{ width:40px; height:2px; background:var(--acc); margin:24px 0; }
.staff__list div{ display:flex; gap:10px; padding:6px 0; font-size:14px; color:rgba(255,255,255,.85); line-height:1.45; }
.staff__list span{ color:var(--acc); font-weight:600; flex-shrink:0; }

@media(max-width:880px){ .staff{ grid-template-columns:1fr; gap:32px; } }

/* ---------- ГАЛЕРЕЯ ---------- */
.gallery{
  display:grid; grid-template-columns:repeat(4, 1fr);
  grid-auto-rows:200px; gap:12px;
}
.gallery__item{
  position:relative; overflow:hidden; border-radius:var(--r);
  background:var(--ink-2);
}
.gallery__item img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .5s ease;
}
.gallery__item:hover img{ transform:scale(1.05); }
.gallery__item--lg{ grid-column:span 2; grid-row:span 2; }
.gallery__cap{
  position:absolute; left:16px; bottom:16px; right:16px;
  font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--white);
  padding:8px 12px; background:rgba(14,22,32,.85); border-left:2px solid var(--acc);
  border-radius:0 4px 4px 0;
}

@media(max-width:880px){
  .gallery{ grid-template-columns:1fr 1fr; grid-auto-rows:160px; }
  .gallery__item--lg{ grid-column:span 2; grid-row:span 2; }
}
@media(max-width:520px){
  .gallery{ grid-template-columns:1fr; grid-auto-rows:240px; }
  .gallery__item--lg{ grid-column:span 1; grid-row:span 1; }
}

/* ---------- LIGHTBOX ---------- */
.lightbox{
  position:fixed; inset:0; z-index:200;
  background:rgba(14,22,32,.95); backdrop-filter:blur(8px);
  display:none; align-items:center; justify-content:center;
  padding:48px 24px;
}
.lightbox.is-open{ display:flex; }
.lightbox img{ max-width:100%; max-height:80vh; object-fit:contain; box-shadow:0 30px 80px rgba(0,0,0,.5); }
.lightbox__cap{
  position:absolute; bottom:24px; left:0; right:0; text-align:center;
  font-family:var(--mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--white); padding:0 24px;
}
.lightbox__close{
  position:absolute; top:16px; right:16px;
  width:48px; height:48px; font-size:32px; color:var(--white);
  border-radius:50%; background:rgba(255,255,255,.1);
  display:grid; place-items:center; line-height:1;
}
.lightbox__close:hover{ background:rgba(255,255,255,.2); }

/* ---------- ЛОКАЦИЯ ---------- */
.loc{
  display:grid; grid-template-columns:1.3fr 1fr; gap:32px;
  margin-bottom:32px;
}
.loc__map{
  position:relative; border-radius:var(--r); overflow:hidden;
  box-shadow:var(--shadow); aspect-ratio:4/3; display:block;
  background:var(--ink);
}
.loc__map img{ width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.loc__map:hover img{ transform:scale(1.02); }
.loc__cap{
  position:absolute; top:16px; left:16px;
  background:var(--ink); color:var(--white);
  padding:14px 18px; border-left:3px solid var(--acc); border-radius:0 4px 4px 0;
  display:flex; flex-direction:column; gap:4px;
}
.loc__cap strong{ font-family:var(--display); font-weight:600; font-size:16px; color:var(--white); }
.loc__open{
  position:absolute; bottom:16px; right:16px;
  background:rgba(14,22,32,.9); color:var(--acc);
  padding:8px 14px; border-radius:4px;
  font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
}
.loc__panel{
  background:var(--white); border:1px solid var(--line); padding:32px;
  border-radius:var(--r);
}
.loc__panel h3{ font-size:22px; margin-bottom:24px; }

.dist{ display:flex; flex-direction:column; }
.dist__row{
  display:flex; align-items:center; gap:16px;
  padding:16px 0; border-bottom:1px solid var(--line);
}
.dist__row:last-child{ border-bottom:0; }
.dist__num{
  font-family:var(--display); font-weight:600; font-size:32px; line-height:1;
  color:var(--ink); letter-spacing:-0.03em; min-width:90px;
  display:flex; align-items:baseline; gap:4px;
  font-variation-settings:"SOFT" 30;
}
.dist__num span{ font-family:var(--sans); font-size:13px; font-weight:500; color:var(--acc-d); }
.dist__city{ display:flex; flex-direction:column; gap:2px; }
.dist__city strong{ font-weight:600; color:var(--ink); }
.dist__city em{ font-style:normal; color:var(--muted); font-size:13px; }

@media(max-width:880px){ .loc{ grid-template-columns:1fr; } }

/* ---------- ФОРМАТЫ СДЕЛКИ ---------- */
.deal{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:20px;
}
.deal__card{
  background:var(--white); color:var(--text); border-radius:var(--r);
  overflow:hidden; box-shadow:var(--shadow); position:relative;
}
.deal__head{
  background:var(--ink); color:var(--white);
  padding:24px 28px;
}
.deal__head h3{
  font-size:32px; color:var(--white); margin:8px 0 4px; letter-spacing:-0.025em;
}
.deal__num{
  font-family:var(--mono); font-size:12px; font-weight:600; letter-spacing:.18em;
  color:var(--acc);
}
.deal__head em{ color:var(--muted-d); font-size:13px; font-style:normal; }
.deal__card ul{
  list-style:none; margin:0; padding:24px 28px;
  display:flex; flex-direction:column; gap:12px;
}
.deal__card li{
  position:relative; padding-left:20px; font-size:15px; line-height:1.5;
}
.deal__card li::before{
  content:''; position:absolute; left:0; top:9px;
  width:6px; height:6px; background:var(--acc); border-radius:50%;
}
.deal__card footer{
  background:var(--acc); color:var(--ink);
  padding:14px 28px;
  font-family:var(--mono); font-size:12px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
}

@media(max-width:880px){ .deal{ grid-template-columns:1fr; } }

/* ---------- ДОКУМЕНТЫ ---------- */
.docs{
  display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center;
}
.docs__l h2{ margin:14px 0 18px; }
.docs__l p{ color:var(--text-2); margin:0 0 28px; line-height:1.6; max-width:55ch; }
.docs__btns{ display:flex; gap:12px; flex-wrap:wrap; }

.docs__cover{
  aspect-ratio:3/4; max-width:380px; margin:0 auto;
  background:linear-gradient(155deg, var(--ink) 0%, var(--ink-2) 100%);
  color:var(--white);
  padding:36px 32px;
  border-radius:var(--r);
  box-shadow:0 40px 80px -30px rgba(14,22,32,.4);
  display:flex; flex-direction:column; justify-content:flex-end; gap:8px;
  position:relative; overflow:hidden;
  border-top:6px solid var(--acc);
}
.docs__cover::before{
  content:''; position:absolute; top:32px; right:32px; bottom:120px; left:32px;
  background:url('assets/img/facade-hero.jpg') center/cover;
  opacity:.25; border-radius:4px;
}
.docs__cover-tag{
  position:absolute; top:24px; left:32px;
  font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--acc); z-index:1;
}
.docs__cover-num{
  font-family:var(--display); font-weight:600; font-size:54px; line-height:1; letter-spacing:-0.04em;
  color:var(--white); z-index:1; position:relative;
  display:flex; align-items:baseline; gap:6px;
}
.docs__cover-num span{ font-family:var(--sans); font-size:18px; color:var(--acc); font-weight:500; }
.docs__cover-lbl{ font-family:var(--display); font-weight:500; font-size:18px; color:var(--white); z-index:1; position:relative; }
.docs__cover-foot{ font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted-d); z-index:1; position:relative; padding-top:14px; border-top:1px solid rgba(255,255,255,.15); }

@media(max-width:880px){ .docs{ grid-template-columns:1fr; gap:32px; } .docs__cover{ max-width:280px; } }

/* ---------- FAQ ---------- */
.faq{ display:flex; flex-direction:column; gap:8px; }
.faq__item{
  background:var(--white); border:1px solid var(--line); border-radius:var(--r);
  overflow:hidden; transition:border-color .2s;
}
.faq__item[open]{ border-color:var(--acc); }
.faq__item summary{
  cursor:pointer; padding:20px 28px;
  font-family:var(--display); font-weight:600; font-size:18px;
  color:var(--ink); letter-spacing:-0.01em;
  display:flex; justify-content:space-between; align-items:center; gap:16px;
  list-style:none;
  font-variation-settings:"SOFT" 30;
}
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary::after{
  content:'+'; font-family:var(--sans); font-size:24px; font-weight:300;
  color:var(--acc-d); transition:transform .2s; flex-shrink:0;
}
.faq__item[open] summary::after{ transform:rotate(45deg); }
.faq__body{ padding:0 28px 24px; color:var(--text-2); line-height:1.6; }
.faq__body p{ margin:0; }
.faq__body a{ color:var(--acc-d); text-decoration:underline; text-underline-offset:3px; }

/* ---------- КОНТАКТЫ ---------- */
.contacts{
  display:grid; grid-template-columns:1fr 1fr; gap:32px;
}
.contacts__card{
  background:var(--ink-2); padding:40px;
  border-radius:var(--r-lg); border-left:4px solid var(--acc);
}
.contacts__name{
  font-family:var(--display); font-weight:600; font-size:42px;
  color:var(--white); margin:8px 0 28px; letter-spacing:-0.03em;
  font-variation-settings:"SOFT" 40;
}
.contacts__rows{ display:flex; flex-direction:column; gap:0; margin-bottom:28px; }
.contacts__row{
  display:flex; flex-direction:column; gap:4px;
  padding:16px 0; border-bottom:1px solid rgba(255,255,255,.08);
  transition:background .15s;
}
.contacts__row:hover:not(.contacts__row--static){ background:rgba(255,255,255,.03); padding-left:8px; padding-right:8px; }
.contacts__row:last-child{ border-bottom:0; }
.contacts__label{
  font-family:var(--mono); font-size:10px; font-weight:600; letter-spacing:.18em; text-transform:uppercase;
  color:var(--acc);
}
.contacts__val{ color:var(--white); font-size:18px; font-weight:500; }
a.contacts__row .contacts__val{ font-weight:600; }

.contacts__btns{ display:flex; flex-wrap:wrap; gap:8px; }

.form{
  background:var(--white); color:var(--ink);
  padding:36px; border-radius:var(--r-lg); border:1px solid var(--line);
  display:flex; flex-direction:column; gap:18px;
}
.form h3{ font-size:28px; margin:0; }
.form__lead{ color:var(--muted); font-size:14px; margin:0; }
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form label{ display:flex; flex-direction:column; gap:6px; }
.form label > span{ font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--ink); }
.form input, .form textarea{
  font-family:var(--sans); font-size:15px;
  padding:12px 14px; border:1px solid var(--line); border-radius:var(--r-sm);
  background:var(--paper); color:var(--ink); width:100%;
  transition:border-color .15s, background .15s;
}
.form input:focus, .form textarea:focus{
  outline:0; border-color:var(--acc); background:var(--white);
  box-shadow:0 0 0 3px rgba(224,138,43,.15);
}
.form textarea{ resize:vertical; min-height:80px; font-family:var(--sans); }
.form__radios{
  display:flex; gap:16px; flex-wrap:wrap; align-items:center;
  padding:8px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.form__radios-label{
  font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink); width:100%;
}
.form__radios label{ flex-direction:row; align-items:center; gap:6px; cursor:pointer; font-size:14px; }
.form__radios input{ width:auto; accent-color:var(--acc); }
.form__note{ color:var(--muted); font-size:12px; line-height:1.5; margin:0; }
.form__note a{ color:var(--acc-d); text-decoration:underline; text-underline-offset:2px; }
.form__note a:hover{ color:var(--acc); }

@media(max-width:880px){
  .contacts{ grid-template-columns:1fr; }
  .contacts__card, .form{ padding:28px; }
  .form__row{ grid-template-columns:1fr; }
}

/* ---------- ФУТЕР ---------- */
.footer{
  background:var(--ink); color:var(--muted-d);
  padding:40px 0 32px; border-top:1px solid rgba(255,255,255,.06);
}
.footer__grid{
  display:grid; grid-template-columns:auto 1fr auto; gap:32px;
  align-items:center;
}
.footer__brand{ display:flex; align-items:center; gap:14px; }
.footer__brand strong{ display:block; color:var(--white); font-size:14px; font-weight:600; }
.footer__brand em{ display:block; font-style:normal; font-family:var(--mono); font-size:11px; letter-spacing:.1em; color:var(--muted-d); margin-top:2px; }

.footer__contacts{ display:flex; gap:24px; justify-content:center; flex-wrap:wrap; }
.footer__contacts a{ color:var(--white); font-weight:500; font-size:14px; transition:color .15s; }
.footer__contacts a:hover{ color:var(--acc); }

.footer__copy{ font-size:12px; text-align:right; line-height:1.5; max-width:280px; }

@media(max-width:760px){
  .footer__grid{ grid-template-columns:1fr; text-align:center; }
  .footer__brand{ justify-content:center; }
  .footer__copy{ text-align:center; max-width:none; }
}

/* ---------- TOAST ---------- */
.toast{
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(100px);
  background:var(--ink); color:var(--white);
  padding:14px 24px; border-radius:var(--r);
  border-left:3px solid var(--acc);
  box-shadow:0 20px 60px -20px rgba(0,0,0,.5);
  font-size:14px; font-weight:500;
  z-index:300;
  transition:transform .35s cubic-bezier(.2,.9,.3,1), opacity .35s;
  opacity:0; pointer-events:none;
  max-width:90vw;
}
.toast.is-show{ transform:translateX(-50%) translateY(0); opacity:1; }

/* ---------- АНИМАЦИИ ВХОДА ---------- */
/* Никаких opacity:0 как стартового состояния — всё всегда видимо.
   Лёгкие микро-интеракции на hover уже добавлены в карточках. */
.reveal{ /* зарезервировано на будущее */ }

@media (prefers-reduced-motion:reduce){
  *, *::before, *::after{ animation-duration:.01ms !important; transition-duration:.01ms !important; }
  html{ scroll-behavior:auto; }
}
