:root {
  --bg: #f5f7fa;
  --surface: #ffffff;
  --panel: #f0f2f5;
  --grid: #d4d9e1;
  --ink: #1f2937;
  --muted: #475569;
  --primary: #203b62;
  --primary-tint: #e9eff6;
  --accent: #e6c13d;
  --accent-600: #c7a61e;
  --success: #2f855a;
  --warning: #8a5a12;
  --danger: #b91c1c;
  --info: #1e40af;
  --ui-border: #8c94a0;
  --focus: #1e40af;
  --radius: 14px;
  --shadow: 0 10px 24px rgba(0, 0, 0, .06);
  --steel-50: #f6f7f8;
  --steel-200: #e9edf1;
  --steel-300: #d4dae1;
  --steel-600: #8c97a3
}

* {
  box-sizing: border-box
}

html,
body {
  height: 100%
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font: 16px/1.6 system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Arial
}

h1,
h2,
h3,
h4 {
  margin: 0 0 .6rem;
  font-weight: 800;
  letter-spacing: .2px
}

h1 {
  font-size: clamp(28px, 3.4vw, 46px)
}

h2 {
  font-size: clamp(22px, 2.3vw, 32px)
}

h3 {
  font-size: clamp(18px, 1.9vw, 24px)
}

p {
  margin: 0 0 1rem;
  color: var(--ink)
}

.lead {
  color: var(--muted)
}

.wrap {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 20px
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0
}

.skip {
  position: absolute;
  left: -9999px;
  top: auto
}

.skip:focus {
  left: 10px;
  top: 10px;
  background: #fff;
  color: var(--ink);
  padding: .5rem 1rem;
  border: 1px solid var(--focus);
  border-radius: 8px
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: #fff;
  border-bottom: 2px solid var(--grid)
}

.header-grid {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 72px
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--ink)
}

.nav-toggle {
  display: none;
  background: #fff;
  border: 1px solid var(--ui-border);
  color: var(--ink);
  padding: .6rem .9rem;
  border-radius: 10px
}

#navmenu {
  display: flex;
  gap: 18px;
  list-style: none;
  margin: 0;
  padding: 0;
  background: #fff
}

#navmenu a {
  color: var(--ink);
  text-decoration: none;
  padding: .6rem .8rem;
  border: 1px solid transparent;
  border-radius: 8px
}

#navmenu a:hover {
  background: #fefce8;
  border-color: var(--accent)
}

#navmenu a:focus {
  outline: 2px solid var(--focus);
  outline-offset: 2px
}

.section {
  padding: 42px 0
}

.section.alt {
  background: var(--primary-tint)
}

.section-title {
  display: flex;
  align-items: center;
  gap: 10px
}

.hero-inner {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 28px;
  align-items: center
}

.hero-cta {
  display: flex;
  gap: 12px;
  margin: 18px 0 4px
}

.badges {
  list-style: none;
  padding: 0;
  margin: 14px 0 0;
  display: grid;
  gap: 8px
}

.accent {
  color: var(--primary)
}

.cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px
}

.card {
  display: block;
  background: var(--surface);
  border: 1px solid var(--grid);
  border-radius: var(--radius);
  padding: 14px;
  text-decoration: none;
  box-shadow: var(--shadow)
}

.card:hover {
  border-color: var(--accent)
}

.card-head {
  font-weight: 700;
  margin-bottom: .4rem
}

.aside {
  background: var(--panel);
  border: 1px solid var(--grid);
  border-radius: var(--radius);
  padding: 14px
}

.service-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 20px
}

.note-info {
  background: #eef2ff;
  border: 1px solid #c7d2fe;
  color: var(--info);
  border-radius: var(--radius);
  padding: 12px
}

.grid-two {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px
}

.k12 {
  padding-left: 16px;
  margin: 0
}

.steel-card {
  background: linear-gradient(180deg, var(--steel-50) 0%, var(--steel-200) 100%), repeating-linear-gradient(90deg, rgba(255, 255, 255, .65) 0 1px, rgba(0, 0, 0, .04) 1px 2px);
  border: 1px solid var(--steel-300);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  position: relative;
  overflow: hidden
}

.steel-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, rgba(255, 255, 255, .55) 0%, rgba(255, 255, 255, 0) 28%, rgba(0, 0, 0, 0) 72%, rgba(255, 255, 255, .25) 100%);
  pointer-events: none;
  mix-blend-mode: overlay
}

.plate-head,
.plate-foot {
  border-color: var(--steel-300)
}

.plate-head {
  padding: 10px 14px;
  border-bottom: 1px dashed var(--grid);
  color: var(--muted);
  letter-spacing: .06em;
  background: linear-gradient(180deg, rgba(255, 255, 255, .7), rgba(255, 255, 255, .3))
}

.plate-body {
  padding: 12px 14px;
  display: grid;
  gap: 10px
}

.plate-foot {
  padding: 10px 14px;
  border-top: 1px dashed var(--grid);
  display: flex;
  gap: 8px;
  background: linear-gradient(0deg, rgba(255, 255, 255, .5), rgba(255, 255, 255, 0))
}

.plate-row {
  display: flex;
  align-items: center;
  justify-content: space-between
}

.plate-row span:first-child {
  color: var(--muted)
}

.tag {
  background: #fff8d6;
  border: 1px solid var(--accent);
  border-radius: 999px;
  padding: 4px 10px;
  color: var(--ink);
  font-size: 12px
}

.dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 2px solid #0001
}

.dot-ok {
  background: #2f855a
}

.dot-warn {
  background: #8a5a12
}

.dot-bad {
  background: #b91c1c
}

.cta {
  background: var(--primary-tint);
  border-top: 2px solid var(--grid);
  border-bottom: 2px solid var(--grid)
}

.cta-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px
}

.site-footer {
  border-top: 2px solid var(--grid);
  padding-top: 18px;
  background: #fff
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1.2fr 1fr;
  gap: 22px
}

.footer-note {
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: center;
  padding: 12px 0;
  color: var(--muted)
}

.footer-note .sep {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--grid)
}

.h6 {
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--muted);
  margin: 0 0 .6rem
}

.list-links,
.list-contacts {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 8px
}

.footer-legal {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  padding: 12px 0;
  color: var(--muted)
}

.footer-legal .sep {
  flex: 1 1 auto;
  height: 1px;
  background: var(--grid)
}

.link-quiet {
  color: var(--muted);
  text-decoration: none
}

.link-quiet:hover {
  color: var(--ink);
  text-decoration: underline;
  text-underline-offset: 2px
}

.backtotop {
  margin-left: auto;
  text-decoration: none;
  color: var(--primary);
  border: 1px solid transparent;
  padding: .3rem .6rem;
  border-radius: 8px
}

.backtotop:hover {
  background: #fefce8;
  border-color: var(--accent)
}

.form {
  background: var(--surface);
  border: 1px solid var(--grid);
  border-radius: var(--radius);
  padding: 14px
}

.form-row {
  display: grid;
  gap: 6px;
  margin-bottom: 12px
}

label {
  font-weight: 600
}

input,
textarea,
select {
  background: #fff;
  color: var(--ink);
  border: 1px solid var(--ui-border);
  border-radius: 10px;
  padding: .7rem 1rem;
  min-height: 44px
}

input:focus,
textarea:focus,
select:focus {
  outline: 2px solid var(--focus);
  outline-offset: 2px
}

button,
.btn {
  min-height: 44px;
  min-width: 44px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: .7rem 1rem;
  border-radius: 12px;
  text-decoration: none;
  border: 1px solid var(--ui-border);
  color: var(--ink);
  background: var(--surface)
}

.btn-primary {
  background: var(--accent);
  border-color: #d4b332;
  color: #1f2937;
  font-weight: 700
}

.btn-ghost {
  background: transparent
}

.table-band {
  background: var(--panel);
  border: 1px solid var(--grid);
  border-radius: var(--radius);
  padding: 10px
}

.hr-strong {
  border: 0;
  border-top: 2px solid var(--primary);
  margin: 20px 0
}

.cookie-banner {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 60;
  background: #ffffff;
  border-top: 2px solid var(--grid);
  box-shadow: 0 -6px 18px rgba(0, 0, 0, .06)
}

.cookie-wrap {
  max-width: 1120px;
  margin: 0 auto;
  padding: 14px 20px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 14px;
  align-items: center
}

.cookie-text {
  color: var(--ink)
}

.cookie-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap
}

.cookie-actions .btn {
  min-height: 40px
}

.cookie-actions .btn-quiet {
  background: transparent;
  border: 1px solid var(--ui-border)
}

.cookie-link {
  color: var(--primary);
  text-decoration: underline;
  text-underline-offset: 2px
}

[hidden] {
  display: none !important
}

.cases {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px
}

.cases.big {
  grid-template-columns: 1fr
}

.case-card {
  background: var(--surface);
  border: 1px solid var(--grid);
  border-radius: var(--radius);
  padding: 14px;
  box-shadow: var(--shadow)
}

.case-card .muted {
  color: var(--muted)
}

.case-card .result {
  margin-top: .4rem;
  font-weight: 600
}

.steps {
  counter-reset: step;
  display: grid;
  gap: 10px
}

.steps li {
  background: var(--surface);
  border: 1px solid var(--grid);
  border-radius: var(--radius);
  padding: 10px 14px;
  list-style: none;
  position: relative;
  padding-left: 54px
}

.steps li::before {
  counter-increment: step;
  content: counter(step);
  position: absolute;
  left: 14px;
  top: 10px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--accent);
  color: #1f2937;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800
}

.faq details {
  background: var(--surface);
  border: 1px solid var(--grid);
  border-radius: var(--radius);
  padding: 10px 14px;
  margin-bottom: 10px
}

.faq summary {
  cursor: pointer
}

.trust-strip {
  list-style: none;
  padding: 0;
  margin: 14px 0 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px
}

.trust-strip li {
  display: flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: 1px solid var(--grid);
  border-radius: 10px;
  padding: 8px 10px;
  line-height: 1.4
}

.trust-strip .fa {
  font-size: 1rem;
  width: 1.25em;
  text-align: center;
  color: var(--primary)
}

.trust-strip b {
  font-weight: 700
}

.case-media {
  display: block;
  margin: 0 0 10px;
  border: 1px solid var(--grid);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: var(--shadow)
}

.case-media img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
  object-fit: cover;
  background: var(--panel)
}

.gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px
}

.gallery a {
  display: block;
  border: 1px solid var(--grid);
  border-radius: 10px;
  overflow: hidden;
  background: var(--panel)
}

.gallery img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
  object-fit: cover
}

.lightbox[hidden] {
  display: none !important
}

.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .6);
  z-index: 80;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px
}

.lightbox-inner {
  position: relative;
  max-width: min(96vw, 1100px);
  width: 100%
}

.lightbox img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 12px;
  background: #fff
}

.lb-caption {
  margin-top: 8px;
  color: #fff;
  text-align: center
}

.lb-close {
  position: absolute;
  top: -10px;
  right: -10px;
  background: #fff;
  border: 1px solid var(--ui-border);
  border-radius: 999px;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer
}

.lb-close:focus {
  outline: 2px solid var(--focus);
  outline-offset: 2px
}

@media (max-width:900px) {
  .hero-inner {
    grid-template-columns: 1fr
  }

  .cards {
    grid-template-columns: 1fr 1fr
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr
  }

  .grid-two {
    grid-template-columns: 1fr
  }

  .service-layout {
    grid-template-columns: 1fr
  }

  .nav-toggle {
    display: inline-flex
  }

  #navmenu {
    display: none;
    position: absolute;
    right: 20px;
    top: 72px;
    background: #fff;
    border: 1px solid var(--grid);
    border-radius: 12px;
    padding: 10px;
    width: min(88vw, 320px);
    flex-direction: column
  }

  #navmenu.open {
    display: flex
  }

  .cases {
    grid-template-columns: 1fr
  }

  .cookie-wrap {
    grid-template-columns: 1fr
  }
}

@media (max-width:720px) {
  .cookie-wrap {
    grid-template-columns: 1fr
  }
}

@media (max-width:640px) {
  .cards {
    grid-template-columns: 1fr;
    gap: 12px
  }

  .card {
    padding: 12px
  }
}

@media (max-width:380px) {
  .trust-strip {
    grid-template-columns: 1fr
  }
}
.cases .case-card{position:relative;display:flex;flex-direction:column;gap:8px;padding:16px;border-radius:14px;border:1px solid var(--grid);background:var(--surface);box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.cases .case-card:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(0,0,0,.08);border-color:var(--accent)}
.cases .case-media{margin:0 0 10px;border:1px solid var(--grid);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.cases .case-media img{display:block;width:100%;height:auto;aspect-ratio:16/9;object-fit:cover;transition:transform .25s ease}
.cases .case-card:hover .case-media img{transform:scale(1.02)}
.cases .case-card>h2{margin:8px 0 6px;font-size:clamp(18px,1.6vw,22px);line-height:1.3;font-weight:800}
.cases .case-card>h2>a{color:var(--ink);text-decoration:none;position:relative;z-index:1}
.cases .case-card>h2>a:hover{color:var(--primary)}
.cases .case-card>h2>a:focus{outline:2px solid var(--focus);outline-offset:2px}
.cases .case-card>h2>a::after{content:"";position:absolute;inset:0;border-radius:14px}
.cases .k12{list-style:none;padding:0;margin:8px 0 0;display:grid;gap:6px}
.cases .k12 li{display:flex;gap:8px;align-items:baseline}
.cases .k12 li b{min-width:90px;color:var(--muted)}
.lightbox video{display:block;width:100%;height:auto;border-radius:12px;background:#000}
.lightbox-inner{max-width:min(96vw,1100px);max-height:86vh}
#lightbox img,#lightbox video{display:block;width:100%;height:auto;max-height:calc(86vh - 80px);object-fit:contain;border-radius:12px}
#lightbox video{background:#000}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:999px;border:1px solid var(--ui-border);background:rgba(255,255,255,.8);display:flex;align-items:center;justify-content:center;cursor:pointer}
.lb-prev{left:8px}.lb-next{right:8px}
.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.95)}
.lb-prev:focus,.lb-next:focus{outline:2px solid var(--focus);outline-offset:2px}
#lightbox img,#lightbox video{opacity:.85;transition:opacity .2s ease}
#lightbox:hover img,#lightbox:hover video{opacity:1}
.gallery a img{opacity:.85;transition:opacity .2s ease,transform .25s ease}
.gallery a:hover img{opacity:1}
/* Lightbox: без рамок и фона у фото/видео */
#lightbox img,
#lightbox video{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
}
.lightbox-inner{background:transparent}
/* Services tabs */
#svc-tabs{position:relative}
#svc-tabs .ui-tabs-nav{display:flex;gap:8px;list-style:none;margin:0;padding:8px;background:var(--surface);border:1px solid var(--grid);border-radius:12px}
#svc-tabs .ui-tabs-nav li{margin:0}
#svc-tabs .ui-tabs-nav .ui-tabs-anchor{display:block;padding:.5rem .8rem;border-radius:8px;text-decoration:none;color:var(--ink)}
#svc-tabs .ui-tabs-nav li.ui-tabs-active .ui-tabs-anchor{background:#fefce8;border:1px solid var(--accent)}
#svc-tabs .ui-tabs-panel{display:block;margin-top:12px;border:0;background:transparent}
#svc-tabs .ui-tabs-panel[aria-hidden="true"]{display:none!important}
/* Services tabs — mobile fit */
@media (max-width: 900px){
  #svc-tabs .ui-tabs-nav{
    max-width:100%;
    overflow-x:auto;           /* горизонтальный скролл */
    overflow-y:hidden;
    white-space:nowrap;        /* не переносить */
    flex-wrap:nowrap;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:thin;
    gap:6px;
    padding:6px;
  }
  #svc-tabs .ui-tabs-nav li{
    display:inline-block;
    flex:0 0 auto;             /* не сжимать */
    scroll-snap-align:center;
  }
  #svc-tabs .ui-tabs-nav .ui-tabs-anchor{
    padding:.45rem .7rem;      /* компактнее */
    font-size:14px;
  }
}

/* на сверхузких — ещё компактнее */
@media (max-width: 420px){
  #svc-tabs .ui-tabs-nav{gap:4px; padding:4px}
  #svc-tabs .ui-tabs-nav .ui-tabs-anchor{padding:.4rem .6rem; font-size:13px}
}

/* гарантируем скрытие неактивных панелей, если тема UI вдруг не подгрузилась */
#svc-tabs .ui-tabs-panel[aria-hidden="true"]{display:none!important}
/* ===== Project/Case cards: sane defaults ===== */

/* сетка карточек: 2 колонки десктоп / 1 колонка мобайл */
.cards { display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:16px; align-items:stretch }
@media (max-width: 900px){ .cards { grid-template-columns:1fr } }

/* базовый контейнер карточки, работает и для <a class="card ...> */
.card, a.card, .service-card, .case-card, .project-card {
  display:flex; flex-direction:column; gap:10px;
  padding:14px; border:1px solid var(--grid); border-radius:12px;
  background:var(--surface); text-decoration:none;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}

/* ховер без цирка */
.card:hover, a.card:hover, .service-card:hover, .case-card:hover, .project-card:hover {
  border-color:var(--accent);
  box-shadow:0 4px 18px rgba(0,0,0,.06);
  transform:translateY(-1px);
}

/* выравнивание: контент сверху, кнопки/ссылки действия прижимаются к низу */
.card .card-actions, .service-card .card-actions, .case-card .card-actions, .project-card .card-actions { margin-top:auto }

/* заголовок карточки: компактный */
.card .card-head, .service-card .card-head, .case-card .card-head, .project-card .card-head {
  display:flex; align-items:center; gap:8px;
  font-size:1rem; line-height:1.3; font-weight:700; color:var(--ink);
}
.card .card-head i, .service-card .card-head i, .case-card .card-head i, .project-card .card-head i { font-size:1rem }

/* текст карточки */
.card p, .service-card p, .case-card p, .project-card p {
  margin:0; font-size:.95rem; line-height:1.45; color:var(--ink-600);
}

/* ссылки внутри карточек — НЕ увеличиваем, наследуем размер */
.card a:not(.btn), .service-card a:not(.btn), .case-card a:not(.btn), .project-card a:not(.btn) {
  font-size:inherit; line-height:inherit; color:inherit; text-decoration:none;
}
.card a:not(.btn):hover, .service-card a:not(.btn):hover, .case-card a:not(.btn):hover, .project-card a:not(.btn):hover {
  color:var(--accent); text-decoration:underline;
}

/* если у карточки есть превьюшки */
.card .card-thumb, .service-card .card-thumb, .case-card .card-thumb, .project-card .card-thumb {
  aspect-ratio:16/9; border-radius:10px; overflow:hidden; background:#f6f6f6;
}
.card .card-thumb img, .service-card .card-thumb img, .case-card .card-thumb img, .project-card .card-thumb img {
  width:100%; height:100%; object-fit:cover; display:block;
}

/* кнопки в карточках не орут */
.card .btn, .service-card .btn, .case-card .btn, .project-card .btn { align-self:flex-start }
/* Services: 4 колонки в табах, с адекватной адаптивностью */
#svc-tabs .cards{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:16px;
  align-items:stretch;
}
@media (max-width:1200px){
  #svc-tabs .cards{ grid-template-columns:repeat(3, minmax(0,1fr)); }
}
@media (max-width:900px){
  #svc-tabs .cards{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}
@media (max-width:600px){
  #svc-tabs .cards{ grid-template-columns:1fr; }
}
/* Главная: блок услуг в 4 колонки */
#home-services .cards{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:16px;
  align-items:stretch;
}
@media (max-width:1200px){
  #home-services .cards{ grid-template-columns:repeat(3, minmax(0,1fr)); }
}
@media (max-width:900px){
  #home-services .cards{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}
@media (max-width:600px){
  #home-services .cards{ grid-template-columns:1fr; }
}
/* gallery placeholders: ровная сетка и картинки не пляшут */
.gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
@media (max-width:900px){ .gallery{grid-template-columns:repeat(2,minmax(0,1fr))} }
@media (max-width:600px){ .gallery{grid-template-columns:1fr} }
.gallery a{display:block;border:1px solid var(--grid);border-radius:10px;overflow:hidden;background:#f6f6f6}
.gallery img{display:block;width:100%;height:auto;aspect-ratio:16/9;object-fit:cover}
/* Footer typography + layout */
.site-footer{background:var(--surface-strong);border-top:1px solid var(--grid);color:var(--ink)}
.site-footer .footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:20px}
@media (max-width:900px){.site-footer .footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.site-footer .footer-grid{grid-template-columns:1fr}}
.site-footer .footer-logo img{max-width:200px;height:auto}
.site-footer .lead{margin:.5rem 0 0;font-size:.95rem;color:var(--ink-700)}
.site-footer .h6{margin:0 0 .5rem;font-size:.85rem;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-600)}
.site-footer .list-links{list-style:none;margin:0;padding:0;display:grid;gap:6px}
.site-footer a{text-decoration:none;color:var(--ink)}
.site-footer a:hover{color:var(--accent);text-decoration:underline}
.footer-bottom{margin-top:14px;padding-top:12px;border-top:1px solid var(--grid);display:flex;gap:12px;justify-content:space-between;flex-wrap:wrap}
.footer-bottom .credits,.footer-bottom .legal{font-size:.85rem;color:var(--ink-600)}
.footer-bottom .legal a{font-size:inherit}

/* Cookie bar (не менял поведение, только шрифты) */
.cookiebar{position:fixed;left:0;right:0;bottom:0;background:var(--surface);border-top:1px solid var(--grid);box-shadow:0 -8px 24px rgba(0,0,0,.06)}
.cookiebar .cookiebar-inner{display:flex;gap:16px;align-items:center;justify-content:space-between;padding:12px 16px}
.cookiebar p{margin:0;font-size:.95rem;color:var(--ink)}
.cookiebar .btn{white-space:nowrap}
@media (max-width:700px){.cookiebar .cookiebar-inner{flex-direction:column;align-items:flex-start}}
/* FAQ accordion */
.faq details{border:1px solid var(--grid);border-radius:12px;padding:10px 12px;background:var(--surface);margin:8px 0}
.faq summary{list-style:none;cursor:pointer;font-weight:700}
.faq summary::-webkit-details-marker{display:none}
.faq .q{display:inline-block}
.faq .a{margin-top:8px;color:var(--ink-700);font-size:.95rem;line-height:1.5}
.faq details[open]{box-shadow:0 4px 18px rgba(0,0,0,.06);border-color:var(--accent)}
/* Contact form */
.form .field{margin-bottom:12px}
.form label{display:block;margin-bottom:6px;font-weight:600;font-size:.95rem}
.form input[type=text], .form input[type=email], .form input[type=tel], .form select, .form textarea{
  width:100%; padding:10px 12px; border:1px solid var(--grid); border-radius:10px; background:#fff; color:var(--ink);
}
.form textarea{resize:vertical}
.form .grid-2{display:grid; grid-template-columns:1fr 1fr; gap:12px}
@media (max-width:800px){ .form .grid-2{grid-template-columns:1fr} }
.form .agree{margin:10px 0}
.form .chk{display:flex; gap:8px; align-items:flex-start}
.note.success{border:1px solid #16a34a22; background:#16a34a11; padding:10px 12px; border-radius:10px; color:#166534}
.note.error{border:1px solid #dc262622; background:#dc262611; padding:10px 12px; border-radius:10px; color:#7f1d1d}
.map-embed iframe{border:1px solid var(--grid); border-radius:12px}
.hp{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}
/* Form errors */
.is-invalid{border-color:#dc2626; background:#fff7f7}
.error-msg{margin-top:6px; font-size:.85rem; color:#7f1d1d}
/* Map container */
.map-embed { margin-top: 8px }
#ym-map { width:100%; height:320px; background:#f8fafc }
@media (min-width: 900px){ #ym-map{ height:420px } }

