:root{
  --bg:#0f2447;           /* тёмно-синий фон */
  --bg-2:#0b1b35;         /* чуть темнее для градиента */
  --text:#e9eef7;         /* светлый текст */
  --muted:#b7c2d9;
  --accent:#ffd21f;       /* жёлтый акцент */
  --white:#ffffff;
  --shadow: 0 10px 30px rgba(9, 20, 40, 0.45);
  --glass: rgba(10,18,36,0.55);
}

*{ box-sizing: border-box; }
html,body{ margin:0; padding:0; font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: var(--text); background: var(--bg); }
img{ max-width:100%; display:block; }

.container{
  width: min(1120px, 92%);
  margin: 0 auto;
}


/* ---------- Header ---------- */
.header{
  position: sticky; top:0; z-index: 100;
  backdrop-filter: blur(8px);
  background: linear-gradient( to bottom, rgba(5,12,28,0.75), rgba(5,12,28,0.35) );
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.header__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding: 14px 0;
}
.brand{
  display:flex; align-items:center; gap:12px; text-decoration:none; color:var(--white);
}
.brand__logo{
  width:40px; height:40px; border-radius:12px;
  background: linear-gradient(135deg, var(--accent), #ffc400);
  color:#1f2430; font-weight:800; display:flex; align-items:center; justify-content:center;
  box-shadow: var(--shadow);
}
.brand__name{ font-weight:700; letter-spacing:.2px; }

.header__actions{ display:flex; gap:10px; align-items:center; }
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 16px; border-radius:12px; font-weight:600; text-decoration:none;
  border:1px solid transparent; transition:.2s ease; white-space:nowrap;
}

/* Иконки соцсетей - единая форма с фирменными цветами */
.icon-btn {
  width: 44px;
  height: 44px;
  display: flex;
  border-radius: 12px;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(6px);
  transition: transform 0.3s ease, box-shadow 0.25s ease;
  border: 1px solid rgba(255,255,255,0.12);
}

.icon-btn img {
  width: 24px;
  height: 24px;
}

/* WhatsApp - зелёный */
.icon-btn--whatsapp {
  background: rgba(37, 211, 102, 0.12);
}
.icon-btn--whatsapp:hover {
  transform: scale(1.15);
  background: rgba(37, 211, 102, 0.22);
  box-shadow: 0 4px 12px rgba(37, 211, 102, 0.3);
}

/* Telegram - синий */
.icon-btn--telegram {
  background: rgba(34, 158, 217, 0.12);
}
.icon-btn--telegram:hover {
  transform: scale(1.15);
  background: rgba(34, 158, 217, 0.22);
  box-shadow: 0 4px 12px rgba(34, 158, 217, 0.3);
}

/* Instagram - градиент */
.icon-btn--instagram {
  background: rgba(225, 48, 108, 0.12);
}
.icon-btn--instagram:hover {
  transform: scale(1.15);
  background: rgba(225, 48, 108, 0.22);
  box-shadow: 0 4px 12px rgba(225, 48, 108, 0.3);
}

/* Кнопка "Позвонить" */
.btn--call {
  background: var(--accent);
  color: #0f2447;
  font-weight: 700;
  padding: 11px 18px;
  gap: 8px;
  box-shadow: 0 4px 14px rgba(255, 210, 31, 0.3);
  transition: all 0.25s ease;
}

.btn--call:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(255, 210, 31, 0.4);
}

.phone-number {
  display: block;
  font-size: 11px;
  font-weight: 500;
  opacity: 0.85;
  margin-top: 2px;
}

/* Адаптив для мобильных */
@media (max-width: 640px){
  .header__actions{ gap:8px; }
  .btn{ padding:9px 14px; border-radius:10px; }
  .brand__name{ font-size:14px; }
  .btn--call { padding: 9px 14px; font-size: 13px; }
  .phone-number { font-size: 10px; }
}


/* ---------- Hero ---------- */
/* ---------- Hero с мостом Семея (PNG версия - ВИДИМЫЙ) ---------- */
.hero{ 
  position:relative; 
  overflow:hidden; 
}

.hero__bg{
  position:absolute; 
  inset:0; 
  z-index:0;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(255,210,31,0.10), transparent 60%),
    radial-gradient(800px 500px at -10% 110%, rgba(121,139,255,0.10), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg-2));
}

/* Паттерн с мостом и лого */
.hero__pattern {
  position: absolute;
  inset: 0;
  background-image: 
    repeating-linear-gradient(
      45deg,
      transparent,
      transparent 120px,
      rgba(255,210,31,0.02) 120px,
      rgba(255,210,31,0.02) 122px
    );
  opacity: 0.4;
}

/* 🌉 МОСТ СЕМЕЯ (PNG) - БОЛЬШОЙ, СЛЕВА ЗА ТЕКСТОМ */
.hero__pattern::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 35%;
  top: -11%;
  transform: translateX(-50%);
  width: 150%;
  max-width: 2000px;
  height: 1000px;
  background: url('bridge.png') center bottom/contain no-repeat;
  opacity: 0.7; /* Настройте от 0.04 до 0.1 */
  pointer-events: none;
  z-index: 0;
  filter: brightness(2.6) contrast(0.88); /* Делаем светлее и мягче */
}

/* Лого QG слева вверху */
.hero__pattern::after {
  content: "QG";
  position: absolute;
  top: 15%;
  left: 8%;
  font-size: 180px;
  font-weight: 800;
  color: rgba(255,210,31,0.03);
  letter-spacing: -8px;
  transform: rotate(-12deg);
  pointer-events: none;
  z-index: 1;
}

.hero__grid{
  position:relative; 
  z-index:1;
  display:grid; 
  grid-template-columns: 1.15fr 0.85fr; 
  gap:40px;
  padding: clamp(72px, 8vw, 110px) 0 64px;
}

.hero__text h1{
  margin:0 0 14px 0;
  font-size: clamp(28px, 4.2vw, 44px); 
  line-height: 1.15;
}

.hero__sub{ 
  color: var(--muted); 
  margin: 0 0 20px 0; 
  font-size: clamp(14px, 1.9vw, 18px); 
}

.hero__badges{ 
  display:flex; 
  flex-wrap:wrap; 
  gap:10px; 
  margin-bottom:22px; 
}

.badge{
  padding:8px 12px; 
  border-radius:12px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  font-weight:600; 
  color:#d7def0;
}

.hero__cta{ 
  display:flex; 
  gap:12px; 
  align-items:center; 
}

.btn--primary{
  background: var(--accent); 
  color:#152033; 
  box-shadow: var(--shadow);
  font-size: 16px;
  padding: 13px 28px;
}

.btn--primary:hover{ 
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(255,210,31,0.4);
}

.hero__media{ 
  display:flex; 
  align-items:center; 
  justify-content:center; 
}

.hero__photo{
  border-radius:18px; 
  overflow:hidden; 
  box-shadow: var(--shadow);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
}

.hero__photo img{ 
  width:100%; 
  height:100%; 
  object-fit:cover; 
  object-position: center left;
  aspect-ratio: 4/3; 
}

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .hero__grid{ 
    grid-template-columns: 1fr; 
    gap:28px; 
    padding-top: 96px; 
  }
  .hero__media{ 
    order:-1; 
  }
  .hero__pattern::before {
    height: 220px;
    opacity: 0.12;
  }
  .hero__pattern::after {
    font-size: 120px;
  }
}


/* ============================================
   ⚠️ ЕСЛИ ВСЁ РАВНО НЕ ВИДНО:
   
   Проверьте в браузере (F12 → Elements):
   1. Есть ли файл semey-bridge.png в корне?
   2. Загружается ли картинка (смотрите Network)
   3. Если ошибка 404 - переместите файл
   
   Попробуйте эти варианты opacity:
   ============================================ */

/* ВАРИАНТ 1 - Если мост темный (инвертируем в белый) */
/*
.hero__pattern::before {
  opacity: 0.15;
  filter: brightness(2.5) invert(1) contrast(0.7);
}
*/

/* ВАРИАНТ 2 - Если мост светлый (просто осветляем) */
/*
.hero__pattern::before {
  opacity: 0.2;
  filter: brightness(2.5) contrast(0.6);
}
*/

/* ВАРИАНТ 3 - Максимальная видимость для проверки */
/*
.hero__pattern::before {
  opacity: 0.3;
  filter: none;
}
*/

/* ---------- SERVICES ---------- */
.services {
  padding: 80px 0;
  background: #f7f9fc;
  color: #0f2447;
}

.section-title {
  text-align: center;
  font-size: 34px;
  margin-bottom: 40px;
  font-weight: 700;
  color: #0b1b35;
}

.services__grid {
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.service-card {
  background: #ffffff;
  border-radius: 16px;
  padding: 22px 26px;
  box-shadow: 0 6px 22px rgba(9,20,40,0.08);
  border: 1px solid rgba(10,20,40,0.08);
  transition: .2s ease;
}

.service-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 28px rgba(9,20,40,0.16);
}

.service-card h3 {
  margin: 0 0 10px;
  font-size: 20px;
  font-weight: 700;
  color: #0b1b35;
}

.service-card p {
  margin: 0;
  font-size: 15px;
  color: #4b5670;
}

/* ---------- ADVANTAGES ---------- */
.advantages {
  padding: 80px 0;
  background: #0b1b35;   /* глубокий тёмно-синий фон */
  color: #f1f5ff;
}

.section-title-light {
  text-align: center;
  font-size: 34px;
  font-weight: 700;
  margin-bottom: 50px;
  color: #ffffff;
}

.advantages__grid {
  display: grid;
  gap: 26px;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.adv-card {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  padding: 26px;
  backdrop-filter: blur(4px);
  transition: .25s ease;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.adv-card:hover {
  transform: translateY(-4px);
  background: rgba(255,255,255,0.1);
}

.adv-icon {
  font-size: 40px;
  margin-bottom: 14px;
}

.adv-card h3 {
  font-size: 20px;
  margin: 0 0 8px;
  color: #ffffff;
  font-weight: 700;
}

.adv-card p {
  margin: 0;
  color: #c9d4ea;
  font-size: 15px;
}


/* ---------- GEOGRAPHY ---------- */
/* ---------- GEOGRAPHY ---------- */
.geography-premium {
  background: #eef2f7; /* чисто белый фон */
  position: relative;
  overflow: hidden;
  z-index: 1; /* фон выше, чем псевдоэлементы */
}

.geography-premium::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 85%;
  max-width: 1000px;
  height: 95%;
  background: url('kz.svg') center/contain no-repeat;
  opacity: 0.20;
  filter: brightness(0) saturate(100%) invert(15%) sepia(85%) saturate(2500%) hue-rotate(200deg);
  pointer-events: none;
  z-index: 0;
}

.geography-premium::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: 
    radial-gradient(circle at 20% 30%, rgba(15,36,71,0.03), transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(255,210,31,0.04), transparent 40%);
  pointer-events: none;
  z-index: 0;
}

.geography-premium .container {
  position: relative;
  z-index: 1;
  text-align: center;
  display: inline-block;
  left: 50%;
  transform: translateX(-50%);
}

.geography-premium .section-title {
  text-align: center;
  font-size: 34px;
  margin-bottom: 16px;
  font-weight: 700;
  color: #0b1b35;
  position: relative;
  z-index: 2;
  padding: 20px 40px;
}

.geography-premium .section-title::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.095);
  backdrop-filter: blur(2px);
  border-radius: 16px;
  border: 1px solid rgba(15, 36, 71, 0.08);
  box-shadow: 0 8px 32px rgba(15, 36, 71, 0.08);
  z-index: -1;
}

.geo-p {
  margin-top: 0;
  font-size: 18px;
  color: #0b1b35;
  font-weight: 500;
}
/* ---------- Адаптив для мобильных ---------- */
@media (max-width: 768px) {
  .geography-premium::before {
    opacity: 0.15; /* чуть меньше, чтобы фон был белым, карта видна */
  }

  .geography-premium::after {
    opacity: 0.02; /* почти прозрачный, фон не темнеет */
  }
}

/* ---------- PRICING ---------- */
.pricing-premium {
  background: #eef2f7; /* чисто белый фон */
  position: relative;
  overflow: hidden;
  z-index: 1;
}

.pricing-premium::before {
  content: "🚚";
  position: absolute;
  top: 10%;
  right: 5%;
  font-size: 120px;
  opacity: 0.03;
  pointer-events: none;
}

.pricing-premium::after {
  content: "📦";
  position: absolute;
  bottom: 10%;
  left: 5%;
  font-size: 100px;
  opacity: 0.03;
  pointer-events: none;
}

.pricing-premium .section-title {
  text-align: center;
  font-size: 38px;
  margin-bottom: 50px;
  font-weight: 700;
  color: #0a1a3d;
}

.pricing-premium-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 30px;
  margin-bottom: 40px;
}

.pricing-column {
  background: #ffffff;
  border-radius: 20px;
  padding: 0;
  box-shadow: 0 8px 24px rgba(10, 26, 61, 0.08);
  border: 1px solid rgba(10, 26, 61, 0.06);
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.pricing-column:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 32px rgba(10, 26, 61, 0.14);
}

.pricing-column--highlight {
  border: 2px solid #ffd21f;
  position: relative;
}

.pricing-column--highlight::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #ffd21f, #ffc400);
}

.pricing-header {
  background: linear-gradient(135deg, #0f2447 0%, #0b1b35 100%);
  padding: 24px 28px;
  color: #ffffff;
  position: relative;
}

.pricing-column--highlight .pricing-header {
  background: linear-gradient(135deg, #ffd21f 0%, #ffc400 100%);
  color: #0f2447;
}

.pricing-header h3 {
  margin: 0;
  font-size: 24px;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 10px;
}

.badge-popular {
  position: absolute;
  top: 12px;
  right: 20px;
  background: rgba(255, 255, 255, 0.25);
  backdrop-filter: blur(6px);
  padding: 6px 14px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.5px;
  border: 1px solid rgba(255, 255, 255, 0.3);
}

.pricing-list {
  list-style: none;
  padding: 28px;
  margin: 0;
}

.pricing-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 0;
  border-bottom: 1px solid rgba(10, 26, 61, 0.08);
  font-size: 16px;
  color: #0b1b35;
  transition: background 0.2s ease;
}

.pricing-list li:last-child {
  border-bottom: none;
}

.pricing-list li:hover {
  background: rgba(255, 210, 31, 0.04);
  margin: 0 -28px;
  padding-left: 28px;
  padding-right: 28px;
}

.pricing-list li span {
  font-weight: 500;
  color: #4b5670;
}

.pricing-list li strong {
  font-weight: 700;
  color: #0a1a3d;
  font-size: 18px;
}

.pricing-column--highlight .pricing-list li strong {
  color: #ffc400;
}

.pricing-note {
  background: rgba(255, 210, 31, 0.08);
  border: 1px solid rgba(255, 210, 31, 0.2);
  border-radius: 16px;
  padding: 20px 28px;
  text-align: center;
  max-width: 800px;
  margin: 0 auto;
}

.pricing-note p {
  margin: 0;
  font-size: 15px;
  color: #4b5670;
  line-height: 1.6;
}

@media (max-width: 768px) {
  .pricing-premium-grid {
    grid-template-columns: 1fr;
  }
  
  .badge-popular {
    position: static;
    display: inline-block;
    margin-top: 8px;
  }
}

/* ---------- FOOTER ---------- */
.footer {
  background: linear-gradient(180deg, #0b1b35 0%, #081426 100%);
  color: #e9eef7;
  padding: 70px 0 30px;
  position: relative;
  overflow: hidden;
}

.footer::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,210,31,0.3), transparent);
}

.footer-main {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 40px;
  margin-bottom: 50px;
}

/* Колонка о компании */
.footer-col {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.footer-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}

.footer-brand .brand__logo {
  width: 45px;
  height: 45px;
  border-radius: 12px;
  background: linear-gradient(135deg, #ffd21f, #ffc400);
  color: #1f2430;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  box-shadow: 0 4px 12px rgba(255,210,31,0.3);
}

.footer-brand h3 {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
  color: #ffffff;
}

.footer-desc {
  margin: 0;
  color: #b7c2d9;
  font-size: 14px;
  line-height: 1.6;
}

/* Заголовки колонок */
.footer-col h4 {
  margin: 0 0 16px 0;
  font-size: 18px;
  font-weight: 700;
  color: #ffd21f;
  position: relative;
  padding-bottom: 8px;
}

.footer-col h4::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 40px;
  height: 2px;
  background: #ffd21f;
}

/* Ссылки */
.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer-links li a {
  color: #b7c2d9;
  text-decoration: none;
  font-size: 14px;
  transition: color 0.2s ease, padding-left 0.2s ease;
  display: inline-block;
}

.footer-links li a:hover {
  color: #ffd21f;
  padding-left: 6px;
}

/* Контакты */
.footer-contacts {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.footer-contacts li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: #b7c2d9;
}

.contact-icon {
  font-size: 18px;
  flex-shrink: 0;
}

.footer-contacts a {
  color: #b7c2d9;
  text-decoration: none;
  transition: color 0.2s ease;
}

.footer-contacts a:hover {
  color: #ffd21f;
}

/* Соцсети */
.footer-socials {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.social-btn {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  text-decoration: none;
  color: #e9eef7;
  font-size: 14px;
  font-weight: 600;
  transition: all 0.25s ease;
}

.social-btn img {
  width: 22px;
  height: 22px;
}

.social-btn:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.2);
  transform: translateX(4px);
}

.social-btn--whatsapp:hover {
  background: rgba(37, 211, 102, 0.12);
  border-color: rgba(37, 211, 102, 0.3);
}

.social-btn--telegram:hover {
  background: rgba(34, 158, 217, 0.12);
  border-color: rgba(34, 158, 217, 0.3);
}

.social-btn--instagram:hover {
  background: rgba(225, 48, 108, 0.12);
  border-color: rgba(225, 48, 108, 0.3);
}

/* Нижняя часть футера */
.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 30px;
  border-top: 1px solid rgba(255,255,255,0.08);
  flex-wrap: wrap;
  gap: 20px;
}

.footer-bottom p {
  margin: 0;
  color: #7a8ba3;
  font-size: 14px;
}

.footer-bottom-links {
  display: flex;
  gap: 20px;
}

.footer-bottom-links a {
  color: #7a8ba3;
  text-decoration: none;
  font-size: 13px;
  transition: color 0.2s ease;
}

.footer-bottom-links a:hover {
  color: #ffd21f;
}

/* Адаптив */
@media (max-width: 768px) {
  .footer-main {
    grid-template-columns: 1fr;
    gap: 35px;
  }

  .footer-bottom {
    flex-direction: column;
    text-align: center;
  }

  .footer-bottom-links {
    flex-direction: column;
    gap: 10px;
  }
}



