/* ===== Site chrome: единая шапка и подвал =====
   Эти селекторы дублируются в /css/main.css (используется только index.html
   и cities/*/index.html). При правке chrome-классов синхронизируй ОБА файла. */

/* Шрифты дублируем тоже: .name в шапке рендерится с font-weight:600.
   Если страница декларировала только Playfair-500 (типичный случай listings/legal),
   браузер ставил бы её на 500 или fake-bold — визуально иначе, чем на index/blog/uslugi,
   где есть и 500, и 700. */
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/playfair-500-cyrillic.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/playfair-700-cyrillic.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}

/* Переменные дублируем, чтобы chrome работал даже если страница не объявила свои */
:root{
  --navy-900:#061633;
  --navy-800:#0A2342;
  --gold-500:#C9A96E;
  --gold-400:#D8BD87;
  --gold-600:#A8884F;
  --ivory:#F7F3EC;
  --paper:#FBFAF7;
  --ink:#0E1117;
  --muted:#5B6274;
  --line:rgba(10,35,66,0.12);
}

html.scroll-locked,body.scroll-locked{overflow:hidden!important}

/* Skip-link для клавиатурной навигации */
.skip-link{
  position:absolute;top:-100px;left:0;z-index:999;
  background:var(--navy-800);color:var(--gold-400);
  padding:14px 20px;text-decoration:none;font-weight:600;
  font-size:14px;border:2px solid var(--gold-500);
  transition:top .2s ease;
}
.skip-link:focus{top:0;outline:none}

/* ===== Top bar =====
   Все ключевые свойства заданы явно — наследование от body не должно
   менять рендеринг бренд-блока (разные страницы имеют body{font-size:16px}
   или 17px, color:#fff на тёмных и т.п.). */
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(251,250,247,0.92);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
  font-family:'Inter',system-ui,sans-serif;
  font-size:16px;line-height:1.5;font-weight:400;
  color:var(--navy-800);letter-spacing:normal;
}
.topbar .wrap{max-width:1240px;margin:0 auto;padding:0 32px}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:76px}
.topbar .brand{display:flex;align-items:center;gap:14px;text-decoration:none;font-size:16px;line-height:1.1;color:var(--navy-800)}
.topbar .brand-mark{
  width:44px;height:44px;border:1px solid var(--gold-500);
  display:grid;place-items:center;color:var(--navy-800);
  position:relative;flex-shrink:0;
  --logo-primary:var(--navy-800);--logo-accent:var(--gold-500);
}
.topbar .brand-mark svg{width:36px;height:36px;display:block}
.topbar .brand-text{display:flex;flex-direction:column;line-height:1.1;font-size:16px;letter-spacing:normal;gap:0;padding:0;margin:0}
.topbar .brand-text .name{font-family:'Playfair Display',serif;font-size:17px;line-height:18.7px;color:var(--navy-800);font-weight:500;letter-spacing:normal;font-style:normal;margin:0;padding:0;text-transform:none}
.topbar .brand-text .role{font-family:'Inter',system-ui,sans-serif;font-size:11px;line-height:12.1px;color:var(--muted);letter-spacing:0.08em;text-transform:uppercase;font-weight:400;font-style:normal;margin:3px 0 0 0;padding:0}
.topbar .nav{display:flex;gap:30px;align-items:center}
.topbar .nav a{font-size:14px;color:var(--navy-800);font-weight:500;position:relative;padding:4px 0;white-space:nowrap;text-decoration:none}
.topbar .nav a:hover{color:var(--gold-600)}
.topbar .nav a::after{
  content:'';position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--gold-500);
  transform:scaleX(0);transform-origin:left;transition:transform .25s ease;
}
.topbar .nav a:hover::after{transform:scaleX(1)}
.topbar .top-contact{display:flex;align-items:center;gap:16px}
.topbar .top-contact .phone-block{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--navy-800);text-decoration:none;
  padding:6px 2px;transition:color .2s ease;
}
.topbar .top-contact .phone-block:hover{color:var(--gold-600)}
.topbar .top-contact .phone{font-weight:600;font-size:15px;letter-spacing:0.01em}
.topbar .top-contact .phone-dot{
  width:8px;height:8px;border-radius:50%;background:#2E9B5A;
  box-shadow:0 0 0 0 rgba(46,155,90,0.5);
  animation:chrome-phone-pulse 2.4s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes chrome-phone-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(46,155,90,0.5)}
  50%{box-shadow:0 0 0 4px rgba(46,155,90,0)}
}
@media (prefers-reduced-motion:reduce){
  .topbar .top-contact .phone-dot{animation:none}
}
.topbar .btn-gold{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;font-family:'Inter',sans-serif;font-weight:500;font-size:14px;
  letter-spacing:0.02em;cursor:pointer;border:none;border-radius:8px;transition:all .2s ease;
  white-space:nowrap;background:var(--gold-500);color:var(--navy-900);
  text-decoration:none;
}
.topbar .btn-gold:hover{background:var(--gold-400)}

/* ===== Burger + Mobile drawer ===== */
.burger{
  display:none;
  width:44px;height:44px;border:none;background:transparent;cursor:pointer;
  flex-direction:column;align-items:center;justify-content:center;gap:5px;
  padding:0;margin-left:4px;
  -webkit-tap-highlight-color:transparent;
}
.burger-bar{
  display:block;width:24px;height:2px;background:var(--navy-800);
  transition:transform .3s ease, opacity .2s ease;
  transform-origin:center;
}
.burger[aria-expanded="true"] .burger-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] .burger-bar:nth-child(2){opacity:0}
.burger[aria-expanded="true"] .burger-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.burger:hover .burger-bar{background:var(--gold-600)}

.mobile-menu{
  position:fixed;top:0;right:0;bottom:0;
  width:min(86vw, 360px);
  background:#fff;
  box-shadow:-8px 0 40px rgba(6,22,51,0.14);
  z-index:95;
  transform:translateX(100%);
  transition:transform .32s cubic-bezier(0.2, 0.8, 0.2, 1);
  display:flex;flex-direction:column;
  visibility:hidden;
}
.mobile-menu.open{transform:translateX(0);visibility:visible}
.mobile-menu-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:1px solid var(--line);
  min-height:76px;
}
.mobile-menu-title{
  font-family:'Playfair Display',serif;font-size:17px;color:var(--navy-800);font-weight:600;
}
.mobile-menu-close{
  width:36px;height:36px;border:1px solid var(--line);background:#fff;
  display:grid;place-items:center;cursor:pointer;color:var(--navy-800);
  transition:all .2s ease;
}
.mobile-menu-close:hover{border-color:var(--gold-500);color:var(--gold-600)}
.mobile-menu-nav{
  display:flex;flex-direction:column;padding:0;flex:1;overflow-y:auto;
  -ms-overflow-style:none;scrollbar-width:none;
}
.mobile-menu-nav::-webkit-scrollbar{display:none}
.mobile-menu-nav a{
  padding:13px 24px;color:var(--navy-800);font-size:15px;font-weight:500;
  border-bottom:1px solid var(--line);text-decoration:none;
  transition:background .15s ease, color .15s ease;
  /* flex:1 0 auto — пункты делят свободную высоту панели поровну (нет «провала» перед футером);
     при нехватке высоты не сжимаются — работает overflow-y:auto. */
  flex:1 0 auto;display:flex;align-items:center;
}
.mobile-menu-nav a:hover,.mobile-menu-nav a:focus-visible{
  background:var(--ivory);color:var(--gold-600);outline:none;
}
.mobile-menu-foot{
  padding:12px 24px 14px;
  display:flex;flex-direction:column;gap:10px;
}
.mobile-menu-phone{
  display:flex;align-items:center;gap:8px;
  color:var(--navy-800);font-weight:600;font-size:13px;
  padding:0;white-space:nowrap;
}
.mobile-menu-phone .phone-dot{
  width:8px;height:8px;border-radius:50%;background:#2E9B5A;flex-shrink:0;
}
.mobile-menu-cta{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 20px;background:var(--gold-500);color:var(--navy-900);
  font-weight:500;font-size:14px;letter-spacing:0.02em;
  border:none;border-radius:8px;cursor:pointer;transition:background .2s ease;
}
.mobile-menu-cta:hover{background:var(--gold-400)}

.mobile-menu-backdrop{
  position:fixed;inset:0;background:rgba(6,22,51,0.5);
  z-index:90;opacity:0;visibility:hidden;
  transition:opacity .3s ease, visibility .3s ease;
  backdrop-filter:blur(2px);
}
.mobile-menu-backdrop.open{opacity:1;visibility:visible}

@media (prefers-reduced-motion:reduce){
  .mobile-menu{transition:none}
  .mobile-menu-backdrop{transition:none}
  .burger-bar{transition:none}
}

/* Скрываем nav и показываем бургер */
@media (max-width:1100px){
  .topbar .nav{display:none}
  .burger{display:flex}
}
@media (max-width:600px){
  .topbar .top-contact .phone-block{display:none}
  .topbar .top-contact .btn-gold{display:none}
}

/* ===== Site footer ===== */
.site-footer{background:var(--navy-900);color:rgba(255,255,255,0.6);padding:56px 0 32px;font-size:13px;margin-top:64px}
.site-footer .wrap{max-width:1240px;margin:0 auto;padding:0 32px}
.site-footer .foot-brand-bar{padding:0 0 32px;margin-bottom:32px;border-bottom:1px solid rgba(255,255,255,0.08)}
.site-footer .foot-brand-bar .brand{display:inline-flex;align-items:center;gap:14px;text-decoration:none}
.site-footer .foot-brand-bar .brand-mark{
  width:44px;height:44px;border:1px solid var(--gold-500);
  display:grid;place-items:center;flex-shrink:0;
  --logo-primary:#fff;--logo-accent:var(--gold-500);
}
.site-footer .foot-brand-bar .brand-mark svg{width:36px;height:36px;display:block}
.site-footer .foot-brand-bar .brand-text{display:flex;flex-direction:column;gap:2px;line-height:1.1}
.site-footer .foot-brand-bar .brand-text .name{color:#fff;font-family:'Playfair Display',serif;font-size:20px;font-weight:500;line-height:1.1}
.site-footer .foot-brand-bar .brand-text .role{color:rgba(255,255,255,0.55);font-size:11px;text-transform:uppercase;letter-spacing:0.08em;font-weight:500}
.site-footer .foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:48px;margin-bottom:36px}
.site-footer .foot-col h3,.site-footer .foot-col h5{color:#fff;font-size:12px;letter-spacing:0.12em;text-transform:uppercase;margin-bottom:18px;font-family:'Inter',sans-serif;font-weight:600;margin-top:0}
.site-footer .foot-col a{display:block;padding:6px 0;color:rgba(255,255,255,0.6);transition:color .2s;text-decoration:none}
.site-footer .foot-col a:hover{color:var(--gold-400)}
.site-footer .foot-col a[href^="mailto:"]{text-decoration:underline;text-decoration-color:rgba(201,169,110,0.4);text-underline-offset:3px}
.site-footer .foot-col a[href^="mailto:"]:hover{text-decoration-color:var(--gold-400)}
.site-footer .foot-col .foot-address{display:block;padding:6px 0;color:rgba(255,255,255,0.55);font-size:12.5px}
.site-footer .foot-col .foot-about{margin-top:18px;font-size:12.5px;line-height:1.55;color:rgba(255,255,255,0.55);border-top:1px solid rgba(255,255,255,0.08);padding-top:14px}
.site-footer .foot-webmail-links{display:inline-flex;gap:6px;padding:2px 0 6px;font-size:11px;color:rgba(255,255,255,0.4);align-items:baseline}
.site-footer .foot-webmail-links a{display:inline;padding:0;color:rgba(255,255,255,0.55);text-decoration:underline;text-decoration-color:rgba(201,169,110,0.3);text-underline-offset:2px}
.site-footer .foot-webmail-links a:hover{color:var(--gold-400);text-decoration-color:var(--gold-400)}
.site-footer .foot-disclaimer{font-size:11px;color:rgba(255,255,255,0.4);line-height:1.5;margin-bottom:10px;max-width:780px}
.site-footer .foot-disclaimer:last-of-type{margin-bottom:14px}
.site-footer .foot-credentials{font-size:11.5px;color:rgba(216,189,135,0.78);line-height:1.55;margin:0 0 16px;max-width:820px;padding:9px 14px;border-left:2px solid rgba(201,169,110,0.4);background:rgba(255,255,255,0.02);border-radius:0 4px 4px 0}
.site-footer .foot-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:12px;align-items:center}
.site-footer .foot-legal-links{display:flex;gap:20px;flex-wrap:wrap;align-items:center}
.site-footer .foot-legal-links a,.site-footer .foot-cookie-btn{color:rgba(255,255,255,0.72);text-decoration:none;font-size:12px;transition:color .2s;display:inline;padding:0}
.site-footer .foot-legal-links a:hover,.site-footer .foot-cookie-btn:hover{color:var(--gold-400)}
.site-footer .foot-cookie-btn{background:transparent;border:none;font-family:inherit;cursor:pointer;letter-spacing:inherit}
.site-footer .foot-cookie-btn:focus-visible{outline:2px solid var(--gold-500);outline-offset:2px}

@media (max-width:960px){
  .site-footer .foot-grid{grid-template-columns:1fr;gap:32px}
}
@media (max-width:600px){
  .site-footer .wrap{padding:0 20px}
  .site-footer .foot-bottom{flex-direction:column;align-items:flex-start;gap:12px}
  .site-footer .foot-legal-links{gap:14px}
}

/* ===== Кнопка «наверх» (#fabScrollTop) =====
   Общие стили для страниц без своего inline-блока (uslugi, tseny, cases, otzyvy).
   На blog/статьях/услугах-карточках есть inline-копия — она ниже в каскаде
   и значения совпадают, конфликтов нет. Логика показа — site-chrome.js. */
.floating-actions{position:fixed;bottom:24px;right:24px;z-index:202;display:flex;flex-direction:column;gap:14px;pointer-events:none}
.floating-actions .fab{pointer-events:auto;display:grid;place-items:center;border:none;cursor:pointer;border-radius:50%;text-decoration:none;transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease,opacity .25s ease}
.floating-actions .fab:focus-visible{outline:2px solid var(--gold-500);outline-offset:3px}
.fab-scroll-top{width:52px;height:52px;background:#fff;color:var(--navy-800);border:1px solid var(--gold-500);box-shadow:0 4px 16px rgba(6,22,51,0.14);opacity:0;visibility:hidden;transform:scale(.8)}
.fab-scroll-top.visible{opacity:1;visibility:visible;transform:scale(1)}
.fab-scroll-top:hover{background:var(--navy-800);color:var(--gold-400);transform:scale(1.08)}
/* Кнопка чата (как на главной, 68px). contact-fab.js перехватывает её
   и превращает в тоггл меню каналов связи. На мобиле скрыта (contact-fab.css). */
.fab-chat{
  position:relative;width:68px;height:68px;
  background:var(--gold-500);color:var(--navy-900);
  box-shadow:0 4px 20px rgba(193,138,37,0.45);
}
.fab-chat:hover{transform:scale(1.08);box-shadow:0 6px 24px rgba(193,138,37,0.6);background:var(--gold-400)}
.fab-chat::before{content:'';position:absolute;inset:0;border-radius:50%;background:var(--gold-500);z-index:-1;animation:fab-pulse 2s ease-in-out infinite}
@keyframes fab-pulse{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.35);opacity:0}}
@media (prefers-reduced-motion:reduce){.fab-chat::before{animation:none;opacity:0}}

/* ===== Sticky-bar «Перезвоните мне / Написать» (как на главной: main.css) ===== */
.mobile-cta-bar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:90;
  background:var(--navy-800);border-top:2px solid var(--gold-500);
  padding:10px 12px;gap:10px;
  box-shadow:0 -8px 24px rgba(6,22,51,0.18);
}
.mobile-cta-btn{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 16px;font-size:14px;font-weight:600;letter-spacing:0.02em;
  border:none;cursor:pointer;border-radius:8px;
  background:var(--gold-500);color:var(--navy-900);
  text-decoration:none;transition:transform .15s ease, background .2s ease;
}
.mobile-cta-btn:active{transform:scale(0.97)}
.mobile-cta-btn:hover{background:var(--gold-400)}

@media (max-width:600px){
  /* Дублируем скрытие из contact-fab.css: site-chrome грузится позже,
     и его базовый .floating-actions .fab{display:grid} иначе перебьёт display:none */
  .floating-actions .fab-chat{display:none}
  .floating-actions .fab-scroll-top{width:44px;height:44px}
  .floating-actions .fab-scroll-top svg{width:18px;height:18px}
  /* contact-fab.css пинит кнопку на 162px (над sticky-bar + lm-fab).
     На страницах БЕЗ sticky-bar lm-fab сидит у края (20px, 56px высотой) —
     кнопка «вверх» над ним: 20 + 56 + 10 = 86px. Как столбик на главной. */
  body:not(:has(.mobile-cta-bar)) .floating-actions .fab-scroll-top{
    bottom:calc(env(safe-area-inset-bottom, 0px) + 86px);
  }
  .mobile-cta-bar{display:flex}
  /* :has — чтобы не давать нижний паддинг страницам без бара (about, faq и т.д.) */
  body:has(.mobile-cta-bar){padding-bottom:80px}
}
