/* =========================================================
   style.css — основной стиль сайта
   Структура:
   1) Переменные + Reset + Base
   2) Header + навигация
   3) Общие секции/контейнер
   4) Hero / Features
   5) Services / Vacancies / Map
   6) Calculator + формы/поля
   7) Reviews (карусель + форма + модалки)
   8) Legal pages (политики/согласия/оферта)
   9) Cookie banner + cookie settings modal
   10) Footer (обновлённый)
   11) Compact UI + Responsive
   ========================================================= */


/* =========================================================
   1) Переменные + Reset + Base
   ========================================================= */
:root{
  --primary:#FFD700;
  --primary-dark:#E5C100;
  --text:#ffffff;
  --text-light:#aaaaaa;
  --border:#333333;
  --gradient-start:#FFD700;
  --gradient-end:#B8860B;
  --surface:#1a1a1a;
  --surface-elevated:#222222;
}

*{margin:0;padding:0;box-sizing:border-box;}

html{ font-size: 15px; }

body{
  font-family:system-ui,-apple-system,"Segoe UI",Arial,sans-serif;
  color:var(--text);
  background:linear-gradient(135deg,#1a1a1a 0%,#000 100%);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  min-height:100vh;
  display:flex;
  flex-direction:column;
}

.container{max-width:1120px;margin:0 auto;padding:0 20px;}


/* =========================================================
   2) HEADER + навигация
   ========================================================= */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  background:rgba(0,0,0,.78);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
}

.header-inner{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:12px 0; /* компактнее */
}

.brand{display:flex;align-items:center;gap:12px;min-width:260px;}

.brand-logo{
  width:40px;height:40px;border-radius:12px;display:grid;place-items:center;
  background:radial-gradient(circle at 30% 30%,#fff4a6 0%,var(--gradient-start) 35%,var(--gradient-end) 100%);
  box-shadow:0 10px 24px rgba(255,215,0,.15);
}
.brand-logo span{color:#000;font-weight:900;font-size:18px;letter-spacing:-.02em;}

.brand-text{display:flex;flex-direction:column;line-height:1.1;}
.brand-title{font-weight:800;font-size:17px;letter-spacing:-.02em;}
.brand-subtitle{font-size:11px;color:var(--text-light);margin-top:4px;}

.header-nav{flex:1;display:flex;justify-content:center;}
.nav-list{list-style:none;display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:center;}

.nav-item{
  display:inline-flex;align-items:center;padding:8px 10px;border-radius:10px;
  color:var(--text);font-size:13px;font-weight:600;
  user-select:none;cursor:pointer;border:1px solid transparent;
  transition:transform .2s ease,background .2s ease,border-color .2s ease,color .2s ease;
  white-space:nowrap;
  text-decoration:none;
}
.nav-item:hover{
  background:rgba(255,215,0,.10);
  border-color:rgba(255,215,0,.22);
  color:var(--primary);
  transform:translateY(-1px);
}
/* Активный пункт меню */
.nav-item.is-active{
  background: rgba(255,215,0,.12);
  border-color: rgba(255,215,0,.28);
  color: var(--primary);
}

.menu-btn{
  width:40px;height:40px;border-radius:12px;border:1px solid var(--border);
  background:rgba(255,255,255,.06);
  color:var(--text);
  display:none;align-items:center;justify-content:center;
  cursor:pointer;
  transition:background .2s ease,border-color .2s ease,transform .2s ease;
}
.menu-btn:hover{
  background:rgba(255,215,0,.10);
  border-color:rgba(255,215,0,.22);
  transform:translateY(-1px);
}
.menu-icon{font-size:18px;line-height:1;}

.mobile-panel{display:none;border-top:1px solid var(--border);background:rgba(0,0,0,.92);}
.mobile-panel.open{display:block;}
.mobile-list{list-style:none;padding:14px 0;display:flex;flex-direction:column;gap:8px;}
.mobile-list .nav-item{width:100%;justify-content:center;padding:12px 14px;}


/* =========================================================
   3) Общие секции/контейнер
   ========================================================= */
main.page{padding-top:76px;flex:1;} /* компенсируем fixed header */
.section{padding:56px 0;}

.section-title{margin-bottom:18px;}
.section-title h2{
  font-size:30px;line-height:1.1;letter-spacing:-.02em;font-weight:900;margin-bottom:10px;
}
.section-title p{color:var(--text-light);max-width:80ch;}


/* =========================================================
   4) HERO (главная)
   ========================================================= */
.hero{ padding: 30px 0 0; }

.hero-wrap{
  background:linear-gradient(135deg, rgba(26,26,26,.92) 0%, rgba(0,0,0,.92) 100%);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:24px;
  padding:22px;
  box-shadow:0 20px 44px rgba(0,0,0,.45);
  backdrop-filter: blur(16px);
}

.hero-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 22px;
  align-items: start;
}

.hero-title{
  font-size:40px;
  line-height:1.04;
  font-weight: 950;
  letter-spacing: -.03em;
  margin-bottom: 12px;
}
.hero-title span{
  background: linear-gradient(90deg, #FFD700, #FFFF00, #FFD700);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.hero-text{
  color: rgba(255,255,255,0.78);
  font-size: 14px;
  margin-bottom: 14px;
}

.badge-line{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin: 12px 0 16px;
}
.mini-badge{
  padding: 7px 9px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.84);
  font-weight: 700;
  font-size: 11.5px;
}

.hero-actions{ display:flex; flex-wrap:wrap; gap:10px; }

/* ===== HERO PANEL (правый блок) ===== */
.hero-panel{
  position: relative;
  background: linear-gradient(135deg, rgba(255,255,255,0.05) 0%, rgba(255,255,255,0.02) 100%);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 22px;
  padding: 18px;
  box-shadow: 0 22px 60px rgba(0,0,0,.45);
  overflow: hidden;
}

/* мягкий “премиальный” блик */
.hero-panel::before{
  content:"";
  position:absolute;
  inset:-80px -80px auto auto;
  width:220px;height:220px;
  background: radial-gradient(circle at 30% 30%, rgba(255,215,0,0.18), rgba(255,215,0,0) 65%);
  transform: translate(20px, -10px);
  pointer-events:none;
  opacity:.9;
}

/* легкая подсветка по краю */
.hero-panel::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius: 22px;
  box-shadow: inset 0 0 0 1px rgba(255,215,0,0.08);
  pointer-events:none;
}

.stat-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

/* каждая строка как мини-карточка */
.stat{
  position: relative;
  padding: 12px 12px 12px 52px;
  border-radius: 16px;
  background: rgba(0,0,0,0.22);
  border: 1px solid rgba(255,255,255,0.08);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.stat:hover{
  transform: translateY(-2px);
  border-color: rgba(255,215,0,0.22);
  background: rgba(255,215,0,0.06);
}

/* иконка слева из data-ico */
.stat::before{
  content: attr(data-ico);
  position:absolute;
  left: 12px;
  top: 12px;
  width: 32px;
  height: 32px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius: 12px;
  background: rgba(255,215,0,0.12);
  border: 1px solid rgba(255,215,0,0.22);
  font-size: 16px;
  line-height: 1;
}

.stat strong{
  display:block;
  font-weight: 950;
  letter-spacing: -.02em;
  margin-bottom: 4px;
  font-size: 15px;
}

.stat span{
  display:block;
  color: rgba(255,255,255,0.74);
  font-size: 13px;
  line-height: 1.45;
}

/* новый note-блок в hero */
.hero-note{
  margin-top: 14px;
  padding: 14px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.03);
}

.hero-note-title{
  font-weight: 900;
  letter-spacing: -.02em;
  margin-bottom: 6px;
  color: rgba(255,255,255,0.88);
}

.hero-note-text{
  color: rgba(255,255,255,0.70);
  font-size: 13px;
  line-height: 1.55;
}

@media (max-width: 420px){
  .stat{ padding-left: 48px; }
  .stat::before{ width: 30px; height: 30px; border-radius: 11px; }
}
/* =========================================================
   4.1) FEATURES (главная)
   ========================================================= */
.feature-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:16px;
  margin-top:18px;
}

.feature-card{
  background: rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:18px;
  padding:16px;
  transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.feature-card:hover{
  transform: translateY(-4px);
  border-color: rgba(255,215,0,0.22);
  background: rgba(255,215,0,0.05);
  box-shadow: 0 14px 30px rgba(255,215,0,0.06);
}

.feature-top{ display:flex; gap:12px; align-items:flex-start; }

.feature-icon{
  width:44px;height:44px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background: rgba(255,215,0,0.12);
  border: 1px solid rgba(255,215,0,0.22);
  color: var(--primary);
  font-size: 18px;
  flex: 0 0 auto;
}
.feature-title{
  font-weight: 900;
  letter-spacing: -0.02em;
  font-size: 16px;
  line-height: 1.2;
}
.feature-text{
  margin-top: 5px;
  color: rgba(255,255,255,0.72);
  font-size: 13px;
  line-height: 1.45;
}



/* =========================================================
   4.2) HOW IT WORKS (steps)
   ========================================================= */
.steps-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:16px;
  margin-top:18px;
}

.step-card{
  position: relative;
  background: rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:18px;
  padding:16px;
  box-shadow: 0 14px 30px rgba(0,0,0,0.25);
  transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
  overflow:hidden;
  min-height: 122px;
}

.step-card:hover{
  transform: translateY(-4px);
  border-color: rgba(255,215,0,0.22);
  background: rgba(255,215,0,0.05);
  box-shadow: 0 18px 40px rgba(255,215,0,0.06);
}

/* лёгкий декоративный блик */
.step-card::after{
  content:"";
  position:absolute;
  right:-22px;
  top:-22px;
  width:160px;
  height:160px;
  background: radial-gradient(circle at 30% 30%, rgba(255,215,0,0.18), rgba(255,215,0,0) 62%);
  pointer-events:none;
  opacity:0.75;
}

.step-num{
  width:44px;
  height:44px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,215,0,0.12);
  border: 1px solid rgba(255,215,0,0.22);
  color: var(--primary);
  font-weight: 950;
  font-size: 16px;
  letter-spacing: -0.02em;
  margin-bottom:10px;
}

.step-title{
  font-weight: 950;
  letter-spacing: -0.02em;
  font-size: 16px;
  line-height: 1.2;
  margin-bottom:6px;
}

.step-text{
  color: rgba(255,255,255,0.74);
  font-size: 13.5px;
  line-height: 1.55;
}

.steps-foot{
  margin-top: 10px;
}

@media (max-width: 980px){
  .steps-grid{ grid-template-columns: 1fr; }
}

/* =========================================================
   4.3) FAQ (accordion)
   ========================================================= */
.faq-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:14px;
  margin-top:18px;
}

.faq-item{
  background: rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:18px;
  padding: 0;
  overflow:hidden;
  box-shadow: 0 12px 26px rgba(0,0,0,0.22);
  transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}

.faq-item:hover{
  transform: translateY(-3px);
  border-color: rgba(255,215,0,0.20);
  background: rgba(255,215,0,0.04);
  box-shadow: 0 16px 34px rgba(255,215,0,0.05);
}

.faq-q{
  list-style:none;
  cursor:pointer;
  user-select:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 14px;
  font-weight: 900;
  letter-spacing: -0.02em;
  font-size: 14px;
  color: rgba(255,255,255,0.92);
  background: rgba(255,255,255,0.02);
}

.faq-q::-webkit-details-marker{ display:none; }

.faq-icon{
  width:34px;
  height:34px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex: 0 0 auto;
  border:1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  position: relative;
}

/* плюс/минус */
.faq-icon::before,
.faq-icon::after{
  content:"";
  position:absolute;
  background: rgba(255,255,255,0.80);
  border-radius: 2px;
}
.faq-icon::before{ width:14px; height:2px; }
.faq-icon::after{ width:2px; height:14px; }

.faq-a{
  padding: 0 14px 14px 14px;
  color: rgba(255,255,255,0.74);
  font-size: 13.5px;
  line-height: 1.6;
}

.faq-item[open]{
  border-color: rgba(255,215,0,0.24);
  background: rgba(255,215,0,0.04);
}

.faq-item[open] .faq-q{
  background: rgba(255,215,0,0.06);
}

.faq-item[open] .faq-icon{
  border-color: rgba(255,215,0,0.22);
  background: rgba(255,215,0,0.10);
}

.faq-item[open] .faq-icon::after{
  /* превращаем плюс в минус */
  opacity:0;
}

@media (max-width: 980px){
  .faq-grid{ grid-template-columns: 1fr; }
}


/* =========================================================
   5) SERVICES
   ========================================================= */
.services-wrap{
  background:linear-gradient(135deg, rgba(26,26,26,.92) 0%, rgba(0,0,0,.92) 100%);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:22px;
  padding:22px;
  box-shadow:0 20px 44px rgba(0,0,0,.45);
  backdrop-filter: blur(16px);
}

.services-lead{
  color: rgba(255,255,255,0.75);
  max-width: 85ch;
  margin-top: 10px;
}

.services-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:18px;
  margin-top:20px;
  align-items:stretch;
}

.service-card{
  background: rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:16px;
  padding:16px;
  display:flex;
  flex-direction:column;
  height:100%;
  transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.service-card:hover{
  transform: translateY(-4px);
  border-color: rgba(255,215,0,0.22);
  background: rgba(255,215,0,0.05);
  box-shadow: 0 14px 30px rgba(255,215,0,0.06);
}

.service-head{
  display:flex;
  gap:12px;
  align-items:flex-start;
  margin-bottom:10px;
}

.service-icon{
  width:44px;height:44px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#000;
  background: linear-gradient(135deg, #FFD700 0%, #B8860B 100%);
  box-shadow: 0 12px 22px rgba(255,215,0,0.10);
  flex: 0 0 auto;
  font-weight: 900;
}

.service-title{
  font-weight: 900;
  letter-spacing: -0.02em;
  font-size: 17px;
  line-height: 1.2;
}

.service-subtitle{
  color: rgba(255,255,255,0.65);
  font-size: 13px;
  margin-top: 5px;
}

.service-text{
  color: rgba(255,255,255,0.78);
  font-size: 13.5px;
  margin: 10px 0 12px;
}

.service-list{
  list-style: none;
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:0;
  margin:0;
}
.service-list li{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color: rgba(255,255,255,0.78);
  font-size: 12.5px;
  line-height: 1.45;
}
.service-list li::before{
  content:"";
  width:8px;height:8px;
  margin-top:6px;
  border-radius:50%;
  background: var(--primary);
  box-shadow: 0 0 0 3px rgba(255,215,0,0.12);
  flex: 0 0 auto;
}

/* Кнопка в карточке услуги прижата вниз (ровные уровни) */
.service-card .btn,
.service-card .btn-ghost{
  margin-top: auto !important;
}

.services-note{
  margin-top:18px;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.03);
  color: rgba(255,255,255,0.70);
  font-size: 13px;
}


/* =========================================================
   5.1) VACANCIES
   ========================================================= */
.vacancies-wrap{
  background:linear-gradient(135deg, rgba(26,26,26,.92) 0%, rgba(0,0,0,.92) 100%);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:22px;
  padding:22px;
  box-shadow:0 20px 44px rgba(0,0,0,.45);
  backdrop-filter: blur(16px);
}

.vacancies-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:16px;
  margin-top:16px;
}

.vacancy-card{
  background: rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:16px;
  padding:14px;
  transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
  min-height: 120px;
}
.vacancy-card:hover{
  transform: translateY(-4px);
  border-color: rgba(255,215,0,0.22);
  background: rgba(255,215,0,0.05);
  box-shadow: 0 14px 30px rgba(255,215,0,0.06);
}

.vacancy-top{ display:flex;align-items:center;gap:12px; margin-bottom:10px; }

.vacancy-badge{
  width:40px;height:40px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background: rgba(255,215,0,0.12);
  border: 1px solid rgba(255,215,0,0.22);
  color: var(--primary);
  font-weight: 900;
  flex: 0 0 auto;
}

.vacancy-title{
  font-weight: 900;
  letter-spacing: -0.02em;
  font-size: 16px;
  line-height: 1.2;
}

.vacancy-desc{
  color: rgba(255,255,255,0.72);
  font-size: 13px;
  line-height: 1.45;
}

.vacancies-note{
  margin-top:16px;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.03);
  color: rgba(255,255,255,0.70);
  font-size: 13px;
}

/* Форма анкеты (вакансии) */
.apply-wrap{
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,0.10);
}
.apply-head h3{
  margin: 0 0 6px 0;
  font-size: 20px;
  letter-spacing: -.01em;
}
.apply-head p{
  margin: 0 0 14px 0;
  color: rgba(255,255,255,0.72);
  font-size: 13px;
  line-height: 1.55;
}

.apply-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.apply-span-2{ grid-column: 1 / -1; }

.apply-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top: 14px;
  align-items:center;
}

.vacancy-preview{
  width:100%;
  min-height: 200px;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(10,10,10,0.55);
  color: rgba(255,255,255,0.9);
  font-size: 12.5px;
  line-height: 1.5;
  outline:none;
  resize: vertical;
}


/* =========================================================
   5.2) MAP / контакты
   ========================================================= */
.map-wrap{
  background:linear-gradient(135deg, rgba(26,26,26,.92) 0%, rgba(0,0,0,.92) 100%);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:22px;
  padding:18px;
  box-shadow:0 20px 44px rgba(0,0,0,.45);
  backdrop-filter: blur(16px);
}

.map-grid{
  display:grid;
  grid-template-columns: 1fr 1.2fr;
  gap:18px;
  align-items:stretch;
}

.map-info{
  background: rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:18px;
  padding:16px;
}

.map-info h3{
  font-size:18px;
  font-weight:900;
  letter-spacing:-0.02em;
  margin-bottom:10px;
}

.map-info p{
  color: rgba(255,255,255,0.75);
  font-size: 14px;
  margin-bottom: 10px;
}

.map-address{
  color: rgba(255,255,255,0.85);
  font-weight: 800;
  font-size: 14px;
  line-height: 1.45;
  padding:12px 12px;
  border-radius:14px;
  background: rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.10);
}

.map-frame{
  width:100%;
  min-height: 360px;
  border:0;
  border-radius:18px;
  overflow:hidden;
  background:#0b0b0b;
  border:1px solid rgba(255,255,255,0.10);
}


/* =========================================================
   6) Calculator + формы/поля (общие)
   ========================================================= */
.calculator-wrap{
  background:linear-gradient(135deg, rgba(26,26,26,.92) 0%, rgba(0,0,0,.92) 100%);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:22px;
  padding:22px;
  box-shadow:0 20px 44px rgba(0,0,0,.45);
  backdrop-filter: blur(16px);
}

.calculator-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:22px;
  align-items:start;
}

.calc-form{display:flex;flex-direction:column;gap:18px;}

.field{display:flex;flex-direction:column;gap:8px;}
.field label{
  font-weight:700;
  font-size:13px;
  color:rgba(255,255,255,.85);
}

.field select,
.field input,
.field textarea{
  padding:14px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.14);
  background: rgba(26,26,26,0.85);
  color:#fff;
  font-size:15px;
  outline:none;
  transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.field textarea{min-height:120px;resize:vertical;}

.field select:focus,
.field input:focus,
.field textarea:focus{
  border-color: rgba(255,215,0,0.45);
  box-shadow: 0 0 0 4px rgba(255,215,0,0.12);
  transform: translateY(-1px);
}

.hint{
  font-size: 12px;
  color: rgba(255,255,255,0.60);
  margin-top: 6px;
}

/* Range */
.range-box{
  background: rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:16px;
  padding:14px;
}
.range-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-bottom:10px;
  color:rgba(255,255,255,0.7);
  font-size:12px;
}
input[type="range"]{
  width:100%;
  -webkit-appearance:none;
  appearance:none;
  height:8px;
  border-radius:999px;
  background: rgba(255,255,255,0.14);
  outline:none;
}
input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;
  appearance:none;
  width:22px;height:22px;border-radius:50%;
  background: var(--primary);
  box-shadow:0 8px 16px rgba(255,215,0,0.18);
  cursor:pointer;
}
input[type="range"]::-moz-range-thumb{
  width:22px;height:22px;border-radius:50%;
  background: var(--primary);
  border:none;
  box-shadow:0 8px 16px rgba(255,215,0,0.18);
  cursor:pointer;
}

/* Блок результата калькулятора */
.calc-result{
  background: rgba(0,0,0,0.55);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:18px;
  padding:18px;
  position:sticky;
  top: 96px;
}
.result-amount{
  font-size:40px;
  line-height:1.05;
  font-weight:900;
  letter-spacing:-.03em;
  margin-bottom:6px;
  background: linear-gradient(90deg, #FFD700, #FFFF00, #FFD700);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.result-label{
  color:rgba(255,255,255,0.75);
  margin-bottom:14px;
  font-weight:600;
}
.breakdown{
  background: rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:14px;
  padding:12px;
}
.break-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,0.08);
  color:rgba(255,255,255,0.80);
  font-size:13px;
}
.break-row:last-child{border-bottom:0;}
.break-row strong{color:#fff;font-weight:800;}


/* =========================================================
   7) Buttons
   ========================================================= */
.btn,
.btn-ghost{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border-radius:14px;
  padding:12px 14px;
  font-weight:800;
  letter-spacing:-.01em;
  text-decoration:none;
  border:1px solid rgba(255,255,255,0.12);
  cursor:pointer;
  transition: transform .18s ease, background .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease;
}
.btn{
  background: linear-gradient(135deg, var(--gradient-start) 0%, var(--gradient-end) 100%);
  color:#000;
  border-color: rgba(255,215,0,0.25);
  box-shadow: 0 16px 30px rgba(255,215,0,0.10);
}
.btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 36px rgba(255,215,0,0.14);
}
.btn-ghost{
  background: rgba(255,255,255,0.04);
  color: var(--text);
}
.btn-ghost:hover{
  background: rgba(255,215,0,0.10);
  border-color: rgba(255,215,0,0.22);
  color: var(--primary);
  transform: translateY(-2px);
}


/* =========================================================
   8) REVIEWS (карусель + rating + modals)
   ========================================================= */

/* Карусель отзывов */
.reviews-carousel{ position: relative; }

.carousel-viewport{
  overflow: hidden;
  border-radius: 18px;
  padding: 2px;
  -webkit-mask-image: -webkit-radial-gradient(white, black);
  contain: paint;
}
.carousel-track{
  display: flex;
  gap: 16px;
  transition: transform .35s ease;
  will-change: transform;
  transform: translate3d(0,0,0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

/* карточка отзыва — одинаковая высота */
.review-card{
  flex: 0 0 calc((100% - 32px) / 3);
  height: 250px;
  display: flex;
  flex-direction: column;
  transform: translate3d(0,0,0);
  backface-visibility: hidden;
}
.review-card .service-title{
  margin-bottom: 6px;
  min-height: 24px;
}
.review-card .service-subtitle{
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  min-height: 38px;
}
.review-card .service-text{
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 5;
  overflow: hidden;
  margin-top: 10px;
}

/* кнопки навигации карусели */
.carousel-btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(0,0,0,0.55);
  color: #fff;
  cursor: pointer;
  display: grid;
  place-items: center;
  z-index: 2;
  transition: transform .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.carousel-btn:hover{
  background: rgba(255,215,0,0.10);
  border-color: rgba(255,215,0,0.35);
  color: var(--primary);
  transform: translateY(-50%) scale(1.03);
}
.carousel-btn.prev{ left: 10px; }
.carousel-btn.next{ right: 10px; }

/* точки */
.carousel-dots{
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 14px;
}
.carousel-dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.10);
  cursor: pointer;
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.carousel-dot.is-active{
  background: rgba(255,215,0,0.35);
  border-color: rgba(255,215,0,0.55);
  transform: scale(1.2);
}

/* Rating */
.rating{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin-top:8px;
}
.rating input{position:absolute;opacity:0;pointer-events:none;}
.rating label{
  border:1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.04);
  padding:10px 12px;
  border-radius:14px;
  cursor:pointer;
  user-select:none;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight:900;
}
.rating label:hover{
  transform: translateY(-1px);
  border-color: rgba(255,215,0,0.22);
  background: rgba(255,215,0,0.06);
}
.rating label span{
  color: rgba(255,255,255,0.70);
  font-weight:700;
  font-size:12px;
}
.rating input:checked + label{
  border-color: rgba(255,215,0,0.35);
  background: rgba(255,215,0,0.10);
  color: var(--primary);
}

/* Модалки (общие) */
.modal{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,0.65);
  backdrop-filter: blur(10px);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:2000;
  padding:18px;
}
.modal.open{display:flex;}
.modal-card{
  width:min(560px, 100%);
  background: linear-gradient(135deg, rgba(26,26,26,.95) 0%, rgba(0,0,0,.95) 100%);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:22px;
  box-shadow:0 30px 70px rgba(0,0,0,.65);
  padding:18px;
}
.modal-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.modal-title{ font-weight:900; letter-spacing:-.02em; font-size:18px; }
.modal-text{ color: rgba(255,255,255,0.72); font-size:13px; line-height:1.55; }
.modal-actions{
  display:flex;
  gap:10px;
  margin-top:14px;
  justify-content:flex-end;
  flex-wrap:wrap;
}
.icon-ok{
  width:46px;height:46px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;
  background: rgba(255,215,0,0.12);
  border: 1px solid rgba(255,215,0,0.22);
  color: var(--primary);
  font-weight: 900;
  flex: 0 0 auto;
}


/* =========================================================
   9) LEGAL PAGES (политики/согласия/оферта)
   ========================================================= */
.legal-page .section-title p{ max-width: 90ch; }

.legal-wrap{
  background: linear-gradient(135deg, rgba(26,26,26,.92) 0%, rgba(0,0,0,.92) 100%);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 24px;
  padding: 22px;
  box-shadow: 0 20px 44px rgba(0,0,0,.45);
  backdrop-filter: blur(16px);
}

.legal-content{
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 18px;
  padding: 18px;
}

.legal-content p{
  color: rgba(255,255,255,0.78);
  font-size: 14px;
  line-height: 1.75;
}
.legal-content p + p{ margin-top: 12px; }

.legal-content h3{
  margin-top: 18px;
  margin-bottom: 8px;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: -.01em;
}

.legal-content ul{
  margin: 10px 0 0;
  padding-left: 18px;
  color: rgba(255,255,255,0.78);
}
.legal-content li{ margin: 6px 0; line-height: 1.65; }

.legal-content a{
  color: var(--primary);
  text-decoration: none;
  font-weight: 900;
}
.legal-content a:hover{ text-decoration: underline; }

.legal-actions{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 18px;
}


/* =========================================================
   10) COOKIE BANNER + COOKIE MODAL
   (стиль белого баннера, как на твоих скринах)
   ========================================================= */
.cookie-banner{
  position:fixed;
  left:0; right:0; bottom:0;
  z-index:3000;
  padding:18px 18px 22px;
  background: rgba(0,0,0,0.25);
  backdrop-filter: blur(6px);
}
.cookie-inner{
  max-width: 1200px;
  margin: 0 auto;
  background: #ffffff;
  color: #1a1a1a;
  border-radius: 16px;
  padding: 18px 22px;
  box-shadow: 0 18px 40px rgba(0,0,0,0.25);
  border: 1px solid rgba(0,0,0,0.08);
}
.cookie-title{
  font-size: 28px;
  font-weight: 900;
  letter-spacing: -.02em;
  margin-bottom: 8px;
}
.cookie-text{
  font-size: 16px;
  line-height: 1.55;
  color: rgba(0,0,0,0.70);
  max-width: 110ch;
}
.cookie-link{
  color: #1bb3d4;
  text-decoration: underline;
}
.cookie-link-btn{
  border:0;
  background: transparent;
  padding: 0;
  color: #1bb3d4;
  text-decoration: underline;
  cursor:pointer;
  font: inherit;
}
.cookie-actions{
  margin-top: 16px;
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}
.cookie-btn{
  border-radius: 999px;
  padding: 14px 26px;
  font-weight: 900;
  border: 1px solid rgba(0,0,0,0.14);
  cursor:pointer;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  letter-spacing: .02em;
}
.cookie-btn:hover{ transform: translateY(-1px); box-shadow: 0 10px 22px rgba(0,0,0,0.12); }

.cookie-accept,
.cookie-btn.primary{
  background: #5656d6;
  color: #fff;
  border-color: rgba(86,86,214,0.35);
}
.cookie-decline,
.cookie-btn.secondary{
  background: #ffffff;
  color: rgba(0,0,0,0.65);
  border-color: rgba(0,0,0,0.16);
}

/* cookie modal */
.cookie-modal{
  position:fixed;
  inset:0;
  z-index:4000;
  display:none;
}
.cookie-modal.open{ display:block; }

.cookie-modal-overlay{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(10px);
}
.cookie-modal-card{
  position:relative;
  width: min(720px, calc(100% - 28px));
  margin: 6vh auto;
  background: #ffffff;
  color:#1a1a1a;
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.45);
  border: 1px solid rgba(0,0,0,0.08);
}
.cookie-modal-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.cookie-modal-title{
  font-size: 18px;
  font-weight: 900;
  letter-spacing:-.02em;
}
.cookie-modal-sub{
  color: rgba(0,0,0,0.62);
  font-size: 13px;
  margin-top: 4px;
}
.cookie-x{
  width:40px;height:40px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.12);
  background: rgba(0,0,0,0.04);
  cursor:pointer;
}

.cookie-settings{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top: 10px;
}
.cookie-setting{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.10);
  background: rgba(0,0,0,0.02);
}
.cookie-setting-title{ font-weight: 900; letter-spacing:-.01em; }
.cookie-setting-text{ color: rgba(0,0,0,0.62); font-size: 12px; margin-top: 4px; }

.cookie-pill{
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  border: 1px solid rgba(0,0,0,0.10);
}
.cookie-pill.on{
  background: rgba(86,86,214,0.12);
  border-color: rgba(86,86,214,0.25);
  color: #5656d6;
}

/* switch */
.cookie-switch{ position:absolute; opacity:0; pointer-events:none; }
.cookie-toggle{
  width: 56px;
  height: 30px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.16);
  background: rgba(0,0,0,0.08);
  position: relative;
  flex: 0 0 auto;
}
.cookie-toggle::after{
  content:"";
  width: 24px; height: 24px;
  border-radius: 50%;
  background: #fff;
  position:absolute;
  top: 50%; left: 3px;
  transform: translateY(-50%);
  box-shadow: 0 6px 14px rgba(0,0,0,0.18);
  transition: left .18s ease, background .18s ease;
}
.cookie-switch:checked + .cookie-toggle{
  background: rgba(86,86,214,0.20);
  border-color: rgba(86,86,214,0.35);
}
.cookie-switch:checked + .cookie-toggle::after{
  left: 29px;
}

.cookie-modal-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top: 14px;
  flex-wrap:wrap;
}
.cookie-modal-actions .cookie-btn{
  border-radius: 14px;
  padding: 12px 18px;
}

@media (max-width: 700px){
  .cookie-title{ font-size: 22px; }
  .cookie-text{ font-size: 14px; }
  .cookie-actions{ gap:10px; }
  .cookie-btn{ padding: 12px 18px; }
}


/* =========================================================
   11) FOOTER (обновлённый под твоё ТЗ)
   - реквизиты перенесены под график
   - ссылки документов без "жёлтого акцента"
   - дисклеймер по центру
   - 2 вкладки внизу справа
   ========================================================= */
.site-footer{
  position:relative;
  background:linear-gradient(180deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.85) 100%);
  border-top:1px solid rgba(255,255,255,0.08);
  box-shadow:0 -20px 40px rgba(255,215,0,0.15);
  margin-top:60px;
  overflow:hidden;
}

/* мягкая подсветка сверху */
.site-footer::before{
  content:"";
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:70%;
  height:140px;
  background:radial-gradient(
    circle,
    rgba(255,215,0,0.12) 0%,
    rgba(255,215,0,0.05) 40%,
    transparent 70%
  );
  pointer-events:none;
}

.footer-top{padding:28px 0;background:rgba(255,255,255,0.02);}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:22px;align-items:start;}

.footer-col-title{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.footer-logo{
  width:40px;height:40px;border-radius:12px;display:grid;place-items:center;
  background:radial-gradient(circle at 30% 30%,#fff4a6 0%,var(--gradient-start) 35%,var(--gradient-end) 100%);
  box-shadow:0 10px 24px rgba(255,215,0,.12); /* было ошибочно 12 */
}
.footer-logo span{color:#000;font-weight:900;font-size:16px;}
.footer-company{font-weight:800;letter-spacing:-.02em;font-size:16px;line-height:1.1;}
.footer-sub{color:rgba(255,255,255,0.55);font-size:13px;margin-top:4px;}

/* Документы — спокойные ссылки (без жёлтого hover-акцента) */
.footer-links{
  list-style:none;margin:0;padding:0;
  display:flex;flex-direction:column;gap:8px;
}
.footer-links li::marker{ color: transparent; }

.footer-link{
  display:inline-flex;align-items:center;
  color:rgba(255,255,255,0.68);
  font-size:13px;
  padding:6px 0;
  user-select:none;
  cursor:pointer;
  text-decoration:none;
  transition: color .18s ease, opacity .18s ease, text-decoration-color .18s ease;
}
.footer-link:hover{
  color: rgba(255,255,255,0.92);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: rgba(255,255,255,0.35);
}

.footer-block{display:flex;flex-direction:column;gap:12px;}

.footer-label{
  color:rgba(255,255,255,0.55);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:2px;
}
.footer-value{color:#fff;font-weight:700;font-size:15px;line-height:1.35;user-select:text;}
.footer-muted{color:rgba(255,255,255,0.65);font-size:13px;line-height:1.45;}

.footer-note{
  margin-top:20px;
  font-size:13px;
  color:rgba(255,255,255,0.65);
  line-height:1.6;
  padding:12px;
  border-radius:12px;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
}

/* Контакты (Email/Telegram кнопки) */
.footer-contact-icons{
  display:flex;
  gap:14px;
  margin-top:10px;
  flex-wrap:wrap;
}
.footer-contact-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border-radius:14px;
  font-size:13px;
  text-decoration:none;
  color:rgba(255,255,255,0.85);
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.10);
  transition:all .2s ease;
}
.footer-contact-btn svg{ width:16px; height:16px; fill:currentColor; }
.footer-contact-btn:hover{
  background:rgba(255,215,0,0.08);
  border-color:rgba(255,215,0,0.35);
  color:var(--primary);
  transform:translateY(-2px);
}

/* Реквизиты — под графиком работы */
.footer-requisites{
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.footer-requisites-lines{ line-height: 1.6; }

/* Дисклеймер по центру */
.footer-disclaimer{
  margin-top: 0;
  padding: 18px 0;
  border-top: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.02);
}
.footer-disclaimer-text{
  font-size: 13px;
  color: rgba(255,255,255,0.70);
  line-height: 1.65;
  text-align: center;
  max-width: 1050px;
  margin: 0 auto;
}

/* Акцентные ссылки только внутри дисклеймера (это нормально) */
.footer-legal-link{
  color: var(--primary);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.footer-legal-link:hover{
  color: #fff;
  text-shadow: 0 0 14px rgba(255,215,0,0.25);
}

/* Две вкладки справа снизу */
.footer-tabs{
  margin-top: 14px;
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  flex-wrap: wrap;
}
.footer-tab{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 16px;
  border-radius: 14px;
  font-size: 13px;
  font-weight: 800;
  text-decoration: none;
  color: rgba(255,255,255,0.85);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  transition: transform .15s ease, border-color .15s ease, background .15s ease, color .15s ease;
}
.footer-tab:hover{
  transform: translateY(-1px);
  background: rgba(255,215,0,0.08);
  border-color: rgba(255,215,0,0.28);
  color: #fff;
}

/* Нижняя полоска */
.footer-bottom-bar{border-top:1px solid rgba(255,255,255,0.08);background:#050505;}
.footer-bottom-text{padding:16px 0;color:rgba(255,255,255,0.60);font-size:12.5px;text-align:center;}


/* =========================================================
   12) Responsive + мелкие адаптации
   ========================================================= */
@media (max-width: 1050px){
  .hero-grid{ grid-template-columns: 1fr; }
  .feature-grid{ grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 980px){
  .header-nav{display:none;}
  .menu-btn{display:flex;}

  .services-grid{ grid-template-columns: 1fr; }
  .vacancies-grid{ grid-template-columns: 1fr; }
  .map-grid{ grid-template-columns: 1fr; }
  .calculator-grid{ grid-template-columns: 1fr; }
  .calc-result{ position: relative; top: auto; }

  .footer-grid{ grid-template-columns: 1fr; }
  .footer-tabs{ justify-content: center; } /* на мобиле по центру */
}

@media (max-width: 860px){
  .apply-grid{ grid-template-columns: 1fr; }
}

@media (max-width: 640px){
  .review-card{
    flex: 0 0 100%;
    height: 280px;
  }
}

@media (max-width: 520px){
  .hero-title{ font-size: 34px; }
  .section-title h2{ font-size: 26px; }
}