/* ============== TOKENS ============== */
.bd-about{
  --navy-deep:#0a1c2e;
  --navy:#10283f;
  --navy-soft:#143350;
  --navy-card:#162e47;
  --graphite:#1d2a36;
  --gold:#c9a86a;
  --gold-light:#dcc28a;
  --gold-dim:rgba(201,168,106,.55);
  --cream:#ecdfc4;
  --cream-strong:#e9d6ad;
  --milk: #f1f1f1;

  --text:#f1f1f1;
  --text-mute:#a9b5c2;
  --text-dim:#7c8a98;
  --line:rgba(255,255,255,.09);
  --line-strong:rgba(255,255,255,.16);
  --serif:'Cormorant Garamond', 'PT Serif', Georgia, serif;
  --sans:'Manrope', system-ui, -apple-system, 'Segoe UI', Helvetica, Arial, sans-serif;
  --maxw:1440px;
  --pad:64px;
  --radius-card:18px;
  --radius-pill:999px;
  --tr:cubic-bezier(.2,.7,.2,1);
  /* Единый вертикальный ритм как в макете (tmp/Barkli about/styles.css) */
  --bd-space-after-eyebrow:22px;
  --bd-space-after-heading:22px;
  --bd-space-after-deck:48px;
}

.bd-about,.bd-about *,.bd-about *::before,.bd-about *::after{box-sizing:border-box}
.bd-about{margin:0;padding:0;scroll-behavior:smooth;
  font-family:var(--sans);
  font-size:16px;
  line-height:1.55;
  color:var(--text);
  background:var(--navy);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

.bd-about img{display:block;max-width:100%;height:auto}
.bd-about a{color:inherit;text-decoration:none}
.bd-about button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
.bd-about ul,.bd-about ol{margin:0;padding:0;list-style:none}
.bd-about h1,.bd-about h2,.bd-about h3,.bd-about h4,.bd-about h5,.bd-about p,.bd-about dl,.bd-about dd{margin:0}
.bd-about input,.bd-about textarea{font-family:inherit;font-size:inherit;color:inherit}

.bd-about .container{
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--pad);
}

/* ============== TYPE ============== */
.eyebrow{
  display:inline-block;
  font-family:var(--sans);
  font-weight:500;
  letter-spacing:.22em;
  font-size:11.5px;
  text-transform:uppercase;
  color:var(--gold);
}
.section-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(40px,4.8vw,76px);
  line-height:1.04;
  letter-spacing:-.005em;
  color:var(--milk);
}
.section-deck{
  max-width:64ch;
  margin-top:0;
  color:var(--text-mute);
  font-size:17px;
  line-height:1.65;
}
.section-head{
  margin-bottom:64px;
  display:flex;
  flex-direction:column;
  gap:0;
  max-width:880px;
}
.section-head > .eyebrow{
  display:block;
  margin-bottom:var(--bd-space-after-eyebrow);
}
.section-head > .section-title{
  margin-bottom:var(--bd-space-after-heading);
}
.section-head > .section-deck{
  margin-top:0;
}
.muted{color:var(--text-dim)}

/* ============== HEADER ============== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(10,28,46,.84);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.header-inner{
  max-width:1760px;
  margin:0 auto;
  padding:18px 40px;
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  align-items:center;
  gap:38px;
}
.logo{display:flex;align-items:center;gap:10px;color:var(--milk)}
.logo-mark{width:34px;height:26px;color:var(--cream);display:flex;align-items:center;justify-content:center}
.logo-mark svg{width:100%;height:100%}
.logo-text{display:flex;flex-direction:column;line-height:1.05}
.logo-title{font-family:var(--serif);font-size:21px;letter-spacing:.04em;color:var(--milk)}
.logo-sub{font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--text-mute);margin-top:3px}

.primary-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:38px;
}
.nav-item{
  display:flex;align-items:center;gap:10px;
  font-size:14px;color:var(--text);
  padding:6px 0;
  transition:color .25s var(--tr);
}
.nav-ico{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;
  border:1px solid var(--line-strong);
  color:var(--cream);
  transition:border-color .25s var(--tr),background .25s var(--tr);
}
.nav-ico svg{width:18px;height:18px}
.nav-item:hover{color:var(--milk)}
.nav-item:hover .nav-ico{border-color:var(--gold-dim);background:rgba(201,168,106,.08)}
.nav-item.is-active{color:var(--gold-light)}
.nav-item.is-active .nav-ico{border-color:var(--gold);background:rgba(201,168,106,.12)}

.header-contact{display:flex;align-items:center;gap:34px}
.contact-address{display:flex;flex-direction:column;line-height:1.35;font-size:13px}
.contact-address .muted{font-size:12px}
.contact-phone{font-size:15px;color:var(--milk);letter-spacing:.01em;white-space:nowrap}
.contact-phone:hover{color:var(--gold-light)}

.burger{
  width:46px;height:46px;border-radius:50%;
  background:rgba(255,255,255,.06);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  border:1px solid var(--line-strong);
  transition:background .2s var(--tr);
}
.burger:hover{background:rgba(255,255,255,.12)}
.burger span{width:16px;height:1px;background:var(--milk)}

/* ============== HERO ============== */
/* Полноэкранный герой: фиксированный Bitrix-хедер .main-header снаружи блока —
   высоту считаем от 100vh, верх контента не «обрезаем» вторым вычитанием 80px. */
.bd-about .hero{
  position:relative;
  height:100vh;
  min-height:760px;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  isolation:isolate;
}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{width:100%;height:100%;object-fit:cover;filter:saturate(.9) brightness(.9)}
.hero-bg-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(90deg, rgba(10,28,46,.95) 0%, rgba(10,28,46,.65) 40%, rgba(10,28,46,.35) 70%, rgba(10,28,46,.1) 100%),
    linear-gradient(180deg, rgba(10,28,46,.55) 0%, rgba(10,28,46,.1) 30%, rgba(10,28,46,.2) 70%, rgba(10,28,46,.85) 100%);
}
.bd-about .hero-inner{
  position:relative;z-index:1;
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  padding:clamp(76px,10vh,118px) var(--pad) 96px;
  display:grid;
  grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);
  gap:64px;
  align-items:end;
}
.hero-copy{max-width:820px;display:flex;flex-direction:column;align-items:flex-start;}
.hero-copy > .eyebrow{display:block;margin-bottom:var(--bd-space-after-eyebrow);}
.hero-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(34px,4.6vw,88px);
  line-height:.96;
  letter-spacing:-.01em;
  color:var(--milk);
  margin:0 0 var(--bd-space-after-heading) 0!important;
  margin-bottom: 25px!important;
}
.hero-lead{
  margin-top:0;
  max-width:58ch;
  font-size:18px;
  line-height:1.65;
  color:#eeeeee;
}
.hero-actions{
  margin-top:42px;
  display:flex;flex-wrap:wrap;gap:14px;
}

/* Buttons */
.bd-ab-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:18px 36px;
  border-radius:var(--radius-pill);
  font-size:15px;letter-spacing:.01em;font-weight:500;
  transition:transform .25s var(--tr),background .25s var(--tr),color .25s var(--tr),border-color .25s var(--tr);
  white-space:nowrap;
}
.bd-ab-btn-cream{background:var(--cream);color:var(--navy-deep)}
.bd-ab-btn-cream:hover{background:var(--milk);transform:translateY(-1px)}
.bd-ab-btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.32);color:var(--milk)}
.bd-ab-btn-ghost:hover{border-color:var(--gold);color:var(--gold-light)}
.bd-ab-btn-block{width:100%}
/* Герой: кнопки — <a>; глобально `.bd-about a { color: inherit }` ломает контраст кремовой кнопки */
.bd-about a.bd-ab-btn{text-decoration:none;}
.bd-about a.bd-ab-btn-cream,
.bd-about a.bd-ab-btn-cream:hover{color:var(--navy-deep);}
.bd-about a.bd-ab-btn-ghost{color:var(--milk);}
.bd-about a.bd-ab-btn-ghost:hover{color:var(--gold-light);}

/* Hero card */
.hero-card{
  background:rgba(13,33,53,.78);
  border:1px solid var(--line-strong);
  border-radius:var(--radius-card);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  padding:30px 32px;
  display:flex;flex-direction:column;gap:0;
  align-self:end;
  max-width:420px;
  justify-self:end;
}
.hero-card-row{
  display:flex;align-items:baseline;justify-content:space-between;gap:14px;
  padding:14px 0;
  border-bottom:1px solid var(--line);
}
.hero-card-row:last-child{border-bottom:0}
.hero-card-label{font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-mute)}
.hero-card-value{font-family:var(--serif);font-size:21px;color:var(--milk);letter-spacing:.005em}

.hero-scroll{
  position:absolute;left:var(--pad);bottom:32px;z-index:1;
  display:flex;align-items:center;gap:14px;
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--text-mute);
}
.hero-scroll-line{width:42px;height:1px;background:var(--gold-dim);position:relative;overflow:hidden}
.hero-scroll-line::after{
  content:"";position:absolute;left:-100%;top:0;width:60%;height:100%;background:var(--gold);
  animation:scrollLine 2.6s var(--tr) infinite;
}
@keyframes scrollLine{
  0%{left:-60%} 60%{left:100%} 100%{left:100%}
}

/* ============== MANIFESTO ============== */
.manifesto{
  padding:140px 0 110px;
  background:var(--navy);
  border-top:1px solid var(--line);
}
.manifesto-grid{
  display:grid;
  grid-template-columns:240px 1fr;
  gap:80px;
  align-items:start;
}
.section-eyebrow .eyebrow{position:sticky;top:120px}
.manifesto-lead{
  font-family:var(--serif);
  font-size:clamp(28px,2.6vw,44px);
  line-height:1.22;
  color:var(--milk);
  font-weight:400;
  letter-spacing:-.003em;
  max-width:30ch;
  margin-bottom:var(--bd-space-after-deck)!important;
}
.manifesto-body{
  margin-top:0;
  display:grid;gap:22px;
  max-width:62ch;
  color:var(--text);
  font-size:17px;line-height:1.7;
}

/* ============== FACTS ============== */
.facts{
  padding:90px 0;
  background:linear-gradient(180deg, var(--navy) 0%, var(--navy-deep) 100%);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.facts-grid{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:0;
}
.fact{
  padding:18px 28px;
  border-left:1px solid var(--line);
  display:flex;flex-direction:column;gap:12px;
}
.fact:first-child{border-left:0;padding-left:0}
.fact:last-child{padding-right:0}
.fact-num{
  font-family:var(--serif);
  font-size:clamp(44px,4vw,68px);
  line-height:1;
  color:var(--gold-light);
  letter-spacing:-.01em;
}
.fact-unit{font-size:.45em;color:var(--gold);margin-left:4px;letter-spacing:.04em}
.fact-label{
  font-size:13px;line-height:1.45;color:var(--text-mute);
}

/* ============== ANATOMY ============== */
.anatomy{padding:130px 0 50px}
.anatomy-chips{
  display:flex;flex-wrap:wrap;gap:12px;
  margin-top:var(--bd-space-after-deck);
}
.chip{
  display:inline-flex;align-items:center;gap:14px;
  padding:16px 26px 16px 22px;
  border-radius:var(--radius-pill);
  border:1px solid var(--line-strong);
  color:var(--text);font-size:15px;letter-spacing:.005em;
  background:rgba(255,255,255,.02);
  transition:all .25s var(--tr);
}
.chip-num{font-family:var(--serif);font-size:14px;color:var(--gold);letter-spacing:.04em}
.chip:hover{border-color:var(--gold);color:var(--milk);background:rgba(201,168,106,.07);transform:translateY(-1px)}

/* ============== FEATURE BASE ============== */
.feature{padding:110px 0}
.feature--alt{background:var(--navy-deep)}
.feature-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:96px;
  align-items:center;
}
.feature-grid--rev .feature-media{order:2}
.feature-text{max-width:560px}
.feature-mark{
  display:flex;align-items:center;gap:14px;
  color:var(--gold);font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  margin-bottom:var(--bd-space-after-eyebrow);
}
.feature-mark span{
  font-family:var(--serif);font-size:13px;letter-spacing:.05em;
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;border:1px solid var(--gold-dim);
  color:var(--gold-light);
}
.feature-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(44px,5vw,84px);
  line-height:.98;
  color:var(--milk);
  letter-spacing:-.005em;
  margin:0 0 var(--bd-space-after-heading) 0!important;
}
.feature-lead{
  margin-top:0;
  font-size:17px;line-height:1.7;color:var(--text);
  max-width:54ch;
  margin-bottom: 25px!important;
}
.feature-head{margin-bottom:64px;max-width:880px}
.feature-head > .feature-mark{margin-bottom:var(--bd-space-after-eyebrow);}
.feature-head > .feature-title{margin-bottom:var(--bd-space-after-heading);}
.feature-head > .feature-lead{margin-top:0;}
.feature-head--split{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:64px;
  align-items:start;
  max-width:none;
}
.feature-head--split > div:first-child{display:flex;flex-direction:column;}
.feature-head--split > div:first-child .feature-mark{margin-bottom:var(--bd-space-after-eyebrow);}
.feature-head--split > div:first-child .feature-title{margin-bottom:0;}
/* Лид выравниваем по строке заголовка: высота марки ≈34px + отступ как до заголовка */
.feature-head--split > .feature-lead{
  margin-top:0;
  padding-top:56px;
}

/* Frames */
.frame{position:relative;overflow:hidden;border-radius:6px}
.frame img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.4s var(--tr);
}
.frame:hover img{transform:scale(1.03)}
.frame figcaption{
  margin-top:14px;
  font-size:12px;color:var(--text-mute);letter-spacing:.08em;text-transform:uppercase;
}
.frame-tall{aspect-ratio:3/4}
.frame-wide{aspect-ratio:16/10;margin-top:24px}
.frame-hero{aspect-ratio:4/3}

.feature-media--left{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
}
.feature-media--right{display:block}

/* Spec list */
.spec-list{margin-top:40px;display:grid;gap:0}
.spec-list div{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:20px;
  padding:18px 0;
  border-top:1px solid var(--line);
}
.spec-list div:last-child{border-bottom:1px solid var(--line)}
.spec-list dt{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);padding-top:3px}
.spec-list dd{font-size:15.5px;line-height:1.55;color:var(--text)}

/* Bullets */
.bullets{margin-top:40px;display:grid;gap:14px}
.bullets li{
  display:grid;grid-template-columns:160px 1fr;gap:20px;
  padding:16px 0;
  border-top:1px solid var(--line);
  font-size:15.5px;line-height:1.55;color:var(--text);
}
.bullets li:last-child{border-bottom:1px solid var(--line)}
.bullets li span{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);padding-top:3px;
}

/* ============== LOBBY ============== */
.lobby-frame{margin-top:48px}
.lobby-toggle{
  display:inline-flex;
  padding:5px;
  border-radius:var(--radius-pill);
  border:1px solid var(--line-strong);
  background:rgba(255,255,255,.03);
  margin-bottom:24px;
}
.lobby-toggle-btn{
  padding:12px 24px;
  border-radius:var(--radius-pill);
  font-size:13.5px;color:var(--text-mute);
  letter-spacing:.02em;
  transition:all .25s var(--tr);
}
.lobby-toggle-btn:hover{color:var(--milk)}
.lobby-toggle-btn.is-active{background:var(--cream);color:var(--navy-deep)}
.lobby-images{
  position:relative;
  aspect-ratio:16/8;
  border-radius:10px;overflow:hidden;
}
.lobby-img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  opacity:0;
  transition:opacity .9s var(--tr);
}
.lobby-img.is-active{opacity:1}
.lobby-meta{
  margin-top:36px;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:0;
}
.lobby-meta li{
  padding:18px 24px;border-left:1px solid var(--line);
  display:flex;flex-direction:column;gap:8px;
}
.lobby-meta li:first-child{border-left:0;padding-left:0}
.lobby-meta strong{font-family:var(--serif);font-size:30px;color:var(--milk);font-weight:400;letter-spacing:-.005em}
.lobby-meta span{font-size:12.5px;color:var(--text-mute);letter-spacing:.02em}

/* ============== APARTMENTS / TABS ============== */
.tabs{margin-top:24px}
.tabs-nav{
  display:flex;flex-wrap:wrap;gap:4px;
  margin-bottom:40px;
  border-bottom:1px solid var(--line);
}
.tab{
  position:relative;
  padding:18px 28px 20px;
  font-size:15px;color:var(--text-mute);letter-spacing:.01em;
  transition:color .25s var(--tr);
}
.tab::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;background:var(--gold);
  transform:scaleX(0);transform-origin:left;transition:transform .35s var(--tr);
}
.tab:hover{color:var(--milk)}
.tab.is-active{color:var(--gold-light)}
.tab.is-active::after{transform:scaleX(1)}

.tab-panel{display:none}
.tab-panel.is-active{display:block;animation:fadeIn .5s var(--tr) both}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.apt-grid{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);
  gap:64px;align-items:center;
}
.apt-media{
  aspect-ratio:4/3;border-radius:8px;overflow:hidden;
}
.apt-media img{width:100%;height:100%;object-fit:cover}
.apt-info{max-width:520px}
.apt-meta{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  gap:0;
  padding-bottom:24px;
  border-bottom:1px solid var(--line);
  margin-bottom:24px;
}
.apt-meta>div{display:flex;flex-direction:column;gap:6px;padding-right:18px;border-left:1px solid var(--line);padding-left:18px}
.apt-meta>div:first-child{border-left:0;padding-left:0}
.apt-meta span{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-mute)}
.apt-meta strong{font-family:var(--serif);font-size:22px;color:var(--milk);font-weight:400;letter-spacing:-.003em}
.apt-text{font-size:16px;line-height:1.7;color:var(--text)}
.apt-features{
  margin-top:24px;
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 24px;
}
.apt-features li{
  position:relative;padding-left:20px;font-size:14.5px;color:var(--text);
}
.apt-features li::before{
  content:"";position:absolute;left:0;top:9px;width:8px;height:1px;background:var(--gold);
}

.link-gold{
  display:inline-block;margin-top:32px;
  font-size:14px;color:var(--gold-light);
  letter-spacing:.06em;
  border-bottom:1px solid var(--gold-dim);
  padding-bottom:4px;
  transition:color .25s var(--tr),border-color .25s var(--tr);
}
.link-gold:hover{color:var(--milk);border-color:var(--gold)}

/* Views slider */
.views{
  margin-top:90px;
  padding-top:60px;
  border-top:1px solid var(--line);
}
.views-head{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:32px;
  flex-wrap:wrap;gap:18px;
}
.views-head h4{
  font-family:var(--serif);
  font-size:clamp(30px,2.9vw,42px);
  font-weight:400;
  color:var(--milk);
  letter-spacing:-.008em;
  line-height:1.15;
  margin:0;
}
.views-ctrl{display:flex;align-items:center;gap:16px;font-size:13px;color:var(--text-mute);letter-spacing:.06em}
.views-btn{
  width:46px;height:46px;border-radius:50%;
  border:1px solid var(--line-strong);background:transparent;
  color:var(--milk);font-size:18px;
  display:inline-flex;align-items:center;justify-content:center;
  transition:all .25s var(--tr);
}
.views-btn:hover{border-color:var(--gold);background:rgba(201,168,106,.08);color:var(--gold-light)}
.views-counter{min-width:48px;text-align:center;font-variant-numeric:tabular-nums}

.views-track{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(440px, 50%);
  gap:24px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
  padding-bottom:8px;
}
.views-track::-webkit-scrollbar{display:none}
.view-slide{
  scroll-snap-align:start;
  display:flex;flex-direction:column;
}
.view-slide img{
  width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:6px;
}
.view-slide figcaption{
  margin-top:12px;font-size:12px;color:var(--text-mute);letter-spacing:.08em;text-transform:uppercase;
}

/* ============== PROMENADE ============== */
.promenade-grid{
  margin-top:40px;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.prom-card{
  padding:24px 22px;
  border:1px solid var(--line);
  border-radius:10px;
  background:rgba(255,255,255,.02);
  display:flex;flex-direction:column;gap:10px;
  transition:border-color .25s var(--tr),background .25s var(--tr);
}
.prom-card:hover{border-color:var(--gold-dim);background:rgba(201,168,106,.04)}
.prom-card span{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.prom-card strong{font-family:var(--serif);font-size:20px;color:var(--milk);font-weight:400;line-height:1.25}

/* ============== SERVICE / ACCORDION ============== */
.service{padding:140px 0;background:var(--navy-deep)}
.accordion{display:grid;gap:0;border-top:1px solid var(--line)}
.acc-item{border-bottom:1px solid var(--line);transition:background .3s var(--tr)}
.acc-item.is-open{background:rgba(255,255,255,.02)}
.acc-head{
  width:100%;
  display:grid;
  grid-template-columns:80px 1fr 44px;
  gap:24px;align-items:center;
  padding:32px 4px;
  text-align:left;
}
.acc-num{
  font-family:var(--serif);color:var(--gold);font-size:14px;letter-spacing:.06em;
}
.acc-title{
  font-family:var(--serif);font-size:clamp(28px,2.75vw,40px);color:var(--milk);
  font-weight:400;letter-spacing:-.004em;line-height:1.18;
}
.acc-icon{
  font-family:var(--sans);
  font-weight:500;
  font-size:30px;
  line-height:1;
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  flex-shrink:0;
  border:1px solid var(--gold-dim);
  border-radius:50%;
  transform-origin:50% 50%;
  transition:transform .35s var(--tr),background .25s var(--tr);
}
.acc-item.is-open .acc-icon{transform:rotate(45deg);background:rgba(201,168,106,.1)}
.acc-body{
  display:grid;grid-template-rows:0fr;
  transition:grid-template-rows .45s var(--tr);
}
.acc-item.is-open .acc-body{grid-template-rows:1fr}
.acc-body>*{overflow:hidden}
.acc-body p{
  padding:0 4px 36px 104px;
  max-width:74ch;font-size:16.5px;line-height:1.7;color:var(--text);
}

/* ============== SECURITY ============== */
.security{padding:140px 0}
.security-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  border-radius:14px;overflow:hidden;
}
.sec-card{
  background:var(--navy);
  padding:40px 36px 44px;
  display:flex;flex-direction:column;gap:14px;
  min-height:260px;
  transition:background .3s var(--tr);
}
.sec-card:hover{background:var(--navy-soft)}
.sec-num{
  font-family:var(--serif);font-size:14px;color:var(--gold);letter-spacing:.06em;
}
.sec-card h4{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(28px,2.4vw,34px);line-height:1.18;color:var(--milk);
  letter-spacing:-.004em;
}
.sec-card p{font-size:15px;line-height:1.65;color:var(--text-mute)}

/* ============== DEVELOPER ============== */
.developer{padding:140px 0;background:var(--navy-deep)}
.developer-grid{
  display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);
  gap:96px;align-items:center;
}
.developer-text > .eyebrow{display:block;margin-bottom:var(--bd-space-after-eyebrow);}
.developer-text > .section-title{margin:0 0 var(--bd-space-after-heading) 0!important;}
.developer-text>p{margin-top:24px;color:var(--text);font-size:16.5px;line-height:1.7;max-width:54ch}
.developer-text > .section-title + p{margin-top:0;}
.dev-stats{
  margin-top:48px;
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;
  border-top:1px solid var(--line);
}
.dev-stats li{
  padding:24px 20px;
  border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:8px;
}
.dev-stats li:nth-child(2n){border-right:0}
.dev-stats strong{font-family:var(--serif);font-size:42px;color:var(--gold-light);font-weight:400;letter-spacing:-.01em;line-height:1}
.dev-stats span{font-size:13px;color:var(--text-mute)}

/* ============== LOCATION SHORT ============== */
.loc-short{padding:130px 0}
.loc-short-inner{
  display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:80px;align-items:center;
}
.loc-short-inner > div:first-child > .eyebrow{display:block;margin-bottom:var(--bd-space-after-eyebrow);}
.loc-short-inner > div:first-child > .section-title{margin:0 0 var(--bd-space-after-heading) 0!important;}
.loc-short-inner > div:first-child > .section-deck{margin-top:0;}
.loc-short p{margin-top:18px;color:var(--text-mute);font-size:17px;line-height:1.65;max-width:54ch}
.loc-short .link-gold{margin-top:28px}
.loc-list{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
  border-radius:10px;overflow:hidden;
}
.loc-list li{
  padding:32px 28px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  display:flex;flex-direction:column;gap:10px;
  background:var(--navy);
}
.loc-list strong{font-family:var(--serif);font-size:46px;color:var(--gold-light);font-weight:400;line-height:1;letter-spacing:-.01em}
.loc-list span{color:var(--text-mute);font-size:14px}

/* ============== CTA ============== */
.cta{
  padding:140px 0;
  background:
    radial-gradient(1100px 600px at 80% 20%, rgba(201,168,106,.14), transparent 70%),
    linear-gradient(180deg, var(--navy-deep), var(--navy));
  border-top:1px solid var(--line);
}
.cta-grid{
  display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:96px;align-items:start;
}
.cta-copy > .eyebrow{display:block;margin-bottom:var(--bd-space-after-eyebrow);}
.cta-copy > .section-title{margin:0 0 var(--bd-space-after-heading) 0!important;}
.cta-copy>p{margin-top:0;color:var(--text-mute);font-size:17px;line-height:1.65;max-width:50ch}
.cta-contact{
  margin-top:42px;
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;
  padding-top:32px;border-top:1px solid var(--line);
}
.cta-contact span{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase}
.cta-contact strong{display:block;font-family:var(--serif);font-size:24px;color:var(--milk);font-weight:400;margin-top:10px;letter-spacing:-.003em}
.phone-lg{display:block;margin-top:10px;font-family:var(--serif);font-size:28px;color:var(--gold-light);letter-spacing:.005em}
.phone-lg:hover{color:var(--milk)}

/* Form */
.cta-form{
  background:rgba(255,255,255,.03);
  border:1px solid var(--line-strong);
  border-radius:18px;
  padding:40px;
  display:grid;gap:22px;
}
.field{display:flex;flex-direction:column;gap:10px}
.field label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.field input,.field textarea{
  background:transparent;
  border:0;border-bottom:1px solid var(--line-strong);
  padding:14px 0;
  font-size:17px;color:var(--milk);
  outline:none;
  transition:border-color .25s var(--tr);
  font-family:var(--sans);
}
.field input:focus,.field textarea:focus{border-color:var(--gold)}
.field textarea{resize:vertical;min-height:80px}
.field input::placeholder,.field textarea::placeholder{color:var(--text-dim)}
.form-policy{font-size:12px;color:var(--text-dim);line-height:1.55;margin:0}
.form-success{
  padding:16px 18px;border-radius:10px;
  background:rgba(201,168,106,.12);
  border:1px solid var(--gold-dim);
  color:var(--milk);font-size:14.5px;
}
.form-submit-status{
  font-size:13px;line-height:1.45;margin-top:-4px;
}

/* Согласие — как во всплывающей форме FAB */
.cta-privacy{
  display:flex;
  align-items:flex-start;
  gap:12px;
  font-size:12.5px;
  color:var(--text-dim);
  line-height:1.45;
}
.cta-privacy input[type="checkbox"]{
  margin-top:4px;
  flex-shrink:0;
  width:16px;height:16px;accent-color:var(--gold);
}
.cta-privacy a{
  color:var(--gold-light);
  text-decoration:underline;
  text-underline-offset:3px;
}
.cta-form .cta-privacy{margin-top:4px;margin-bottom:4px;}
.cta-form .form-submit-pending{opacity:.65;pointer-events:none;}

/* ============== FOOTER ============== */
.site-footer{
  padding:80px 0 60px;
  background:var(--navy-deep);
  border-top:1px solid var(--line);
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr .8fr 1.1fr;
  gap:64px;
  align-items:start;
}
.footer-brand{display:flex;flex-direction:column;align-items:flex-start;gap:12px}
.footer-brand .logo-mark{width:34px;height:26px;color:var(--cream)}
.footer-brand .logo-text{flex-direction:row;align-items:baseline;gap:10px;line-height:1.05}
.footer-tag{margin-top:14px;color:var(--text-mute);font-size:14px;max-width:34ch}
.footer-nav{display:flex;flex-direction:column;gap:14px;font-size:15px}
.footer-nav a{color:var(--text-mute);transition:color .25s var(--tr)}
.footer-nav a:hover{color:var(--milk)}
.footer-contact{display:flex;flex-direction:column;gap:6px;font-size:14px}
.footer-contact strong{font-family:var(--serif);font-size:20px;color:var(--milk);font-weight:400;margin-bottom:6px}
.footer-phone{font-family:var(--serif);font-size:24px;color:var(--gold-light);margin:6px 0}
.footer-phone:hover{color:var(--milk)}
.footer-legal{
  grid-column:1/-1;
  margin-top:48px;padding-top:28px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;
  color:var(--text-dim);font-size:12.5px;
}
.footer-legal p{max-width:60ch}

/* ============== RESPONSIVE ============== */
@media (max-width:1280px){
  .bd-about{--pad:48px}
  .primary-nav{gap:24px}
  .nav-item{font-size:13px}
  .header-inner{gap:24px;padding:16px 28px}
  .contact-address{display:none}
  .feature-grid{gap:60px}
  .developer-grid,.loc-short-inner,.cta-grid{gap:64px}
}

@media (max-width:1100px){
  .header-inner{grid-template-columns:auto 1fr auto auto}
  .primary-nav{gap:18px}
  .nav-ico{width:34px;height:34px}
  .nav-ico svg{width:16px;height:16px}
  .facts-grid{grid-template-columns:repeat(3,1fr)}
  .fact{padding:18px 20px;border-bottom:1px solid var(--line)}
  .fact:nth-child(3n+1){border-left:0;padding-left:0}
  .fact:nth-child(4){border-left:0;padding-left:0}
  .fact:nth-child(n+4){border-bottom:0}
}

@media (max-width:960px){
  .bd-about{--pad:36px}
  .primary-nav{display:none}
  .header-inner{grid-template-columns:auto 1fr auto}
  .contact-phone{font-size:14px}
  .bd-about .hero{min-height:680px;height:auto;padding-top:0;padding-bottom:40px}
  .bd-about .hero-bg img{object-position:center center;}
  .bd-about .hero-inner{grid-template-columns:1fr;gap:48px;padding:max(92px, calc(env(safe-area-inset-top, 0px) + 64px)) var(--pad) 80px}
  .hero-card{justify-self:start;max-width:none;width:100%}
  .manifesto-grid{grid-template-columns:1fr;gap:32px}
  .section-eyebrow .eyebrow{position:static}
  .feature{padding:80px 0}
  .feature-grid{grid-template-columns:1fr;gap:48px}
  .feature-grid--rev .feature-media{order:0}
  .feature-head--split{grid-template-columns:1fr;gap:24px}
  .feature-head--split > .feature-lead{padding-top:0}
  .apt-grid{grid-template-columns:1fr;gap:36px}
  .apt-features{grid-template-columns:1fr}
  .lobby-meta{grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line)}
  .lobby-meta li{padding:18px;border-left:0;background:var(--navy)}
  .security-grid{grid-template-columns:repeat(2,1fr)}
  .developer-grid,.loc-short-inner,.cta-grid{grid-template-columns:1fr;gap:48px}
  /* Один слайд на ширину трека внутри контейнера (без breakout — иначе с overflow-x:hidden съедается край) */
  .bd-about .views-track{
    display:flex;
    flex-flow:row nowrap;
    gap:0;
    align-items:stretch;
  }
  .bd-about .views-track .view-slide{
    flex:0 0 100%;
    width:100%;
    min-width:0;
    max-width:100%;
    box-sizing:border-box;
  }
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .promenade-grid{grid-template-columns:1fr}
  .views-track{grid-auto-columns:minmax(300px,80%)}
  .acc-head{grid-template-columns:48px 1fr 36px;gap:16px;padding:24px 0}
  .acc-icon{width:36px;height:36px;font-size:24px}
  .acc-body p{padding:0 0 28px 64px;font-size:15.5px}
  .facts{padding:60px 0}
  .facts-grid{grid-template-columns:repeat(2,1fr)}
  .fact{padding:24px 16px;border-left:0;border-top:1px solid var(--line)}
  .fact:nth-child(2n){border-left:1px solid var(--line)}
  .service,.security,.developer,.cta,.loc-short{padding:80px 0}
  .anatomy{padding:80px 0 20px}
  .manifesto{padding:90px 0 70px}
  .hero-title{font-size:48px}
  .hero-lead{font-size:16px}
}

@media (max-width:600px){
  .bd-about{--pad:20px}
  .header-inner{padding:14px 20px;gap:16px}
  .logo-sub{display:none}
  .logo-mark{width:30px;height:22px}
  .logo-title{font-size:19px}
  .contact-phone{display:none}
  .burger{width:42px;height:42px}
  .bd-about .hero{min-height:600px;padding-top:0}
  .bd-about .hero-inner{padding:max(84px, calc(env(safe-area-inset-top, 0px) + 56px)) var(--pad) 60px;gap:32px}
  .bd-about .hero-bg img{object-position:-350px center;}
  .hero-actions{
    flex-direction:row;
    flex-wrap:nowrap;
    align-items:stretch;
    gap:10px;
  }
  .bd-ab-btn{padding:16px 28px;font-size:14px}
  .bd-about .hero-actions .bd-ab-btn-cream{

    padding:12px;
    min-width:0;
    white-space:normal;
    text-align:center;
  }
  .hero-card{padding:24px}
  .hero-card-value{font-size:17px}
  .hero-scroll{display:none}
  .facts-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .facts .fact{padding:18px 12px;border-left:0;border-top:1px solid var(--line)}
  .facts .fact:nth-child(2n){border-left:1px solid var(--line)}
  .fact-num{font-size:42px}
  .section-title{font-size:36px}
  .hero-title{font-size:30px}
  .feature-title{font-size:36px}
  .manifesto-lead{font-size:24px}
  .anatomy-chips{gap:8px}
  .chip{padding:12px 18px 12px 16px;font-size:13.5px;gap:10px}
  .lobby-meta{grid-template-columns:1fr}
  .lobby-meta strong{font-size:24px}
  .security-grid{grid-template-columns:1fr}
  .sec-card{padding:28px 22px;min-height:auto}
  .loc-list{grid-template-columns:1fr}
  .loc-list strong{font-size:34px}
  .dev-stats{grid-template-columns:1fr}
  .dev-stats li{border-right:0}
  .footer-grid{grid-template-columns:1fr}
  .footer-legal{flex-direction:column;gap:12px}
  .tab{padding:14px 16px;font-size:14px}
  /* Табы квартирного блока — одна строка, при узком экране горизонтальный скролл */
  .bd-about .tabs-nav{
    flex-wrap:nowrap;
    overflow-x:auto;
    gap:4px;
    scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
  }
  .bd-about .tabs-nav::-webkit-scrollbar{display:none}
  .bd-about .tabs-nav .tab{
    flex:0 0 auto;
    white-space:nowrap;
  }
  .views-head h4{font-size:26px}
  /* Офис и телефон — друг под другом, не в два столбца */
  .bd-about .cta-contact{
    grid-template-columns:1fr;
    gap:22px;
  }
  .cta-form{padding:28px 22px}
  .phone-lg{font-size:22px}
  /* Колонка под кнопку = размеру .acc-icon (36px), иначе круг обрезается и «двоится» */
  .acc-head{grid-template-columns:36px 1fr 36px;gap:12px;padding:22px 0}
  .acc-num{font-size:12px}
  .acc-title{font-size:20px}
  .acc-body p{padding:0 0 24px 48px}
  .spec-list div,.bullets li{grid-template-columns:1fr;gap:6px;padding:14px 0}
  .apt-meta{grid-template-columns:repeat(3,1fr)}
  .apt-meta>div{padding:0 8px;border-left:1px solid var(--line)}
}
