:root{
  --bg:#ffffff;
  --text:#0a0a0a;
  --muted:#6b7280;
  --border:#e5e7eb;
  --green:#1da344; /* акцент 1 */
  --blue:#4c95e4;  /* акцент 2 */
  --radius:24px;
  --shadow:0 10px 30px rgba(0,0,0,.06);
  --container:1400px; /* рабочая ширина */
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;}
img{max-width:100%;display:block;border-radius:16px}
a{color:inherit;text-decoration:none}

/* Layout */
.container{max-width:var(--container);margin:0 auto;padding:0 20px}
.section{padding:80px 0}
.grid{display:grid;gap:28px}

/* Header */
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.8);backdrop-filter:saturate(180%) blur(12px)}
.nav{display:flex;align-items:center;justify-content:space-between;height:110px}
.nav .menu{display:flex;gap:20px;align-items:center}
.brand{display:flex;align-items:center;gap:12px;font-weight:700}
.brand .logo{width:386px;height:110px;border-radius:12px;box-shadow:var(--shadow);animation:logoPulse 6s ease-in-out infinite;transition:width .3s ease-in-out, height .3s ease-in-out}
.menu a{padding:10px 14px;border-radius:12px;position:relative;font-weight:600;font-size:17px;line-height:27px}
.menu a:hover:not(.cta){color:var(--blue)}
.menu a.active{color:var(--green);background:#f7fafc}
/* Исправленный стиль для кнопки "Заказать проект" */
.cta{position:relative;overflow:hidden;padding:10px 16px;border-radius:16px;background:linear-gradient(135deg,var(--green),var(--blue));color:#fff;font-weight:600;box-shadow:var(--shadow); display: inline-block; transition: background .25s ease, transform .2s ease, box-shadow .2s ease; text-decoration: none;}
.cta:hover{background:linear-gradient(135deg,var(--green),var(--blue));transform:translateY(-2px);box-shadow:0 10px 22px rgba(0,0,0,.06)}
.cta:after{content:"";position:absolute;inset:-200% 0 0 0;margin:auto;width:40%;height:300%;background:linear-gradient(130deg,transparent 40%,rgba(255,255,255,.45),transparent 60%);transform:skewX(-12deg) translateX(-150%);transition:transform .8s ease}
.cta:hover:after{transform:skewX(-12deg) translateX(220%)}

.burger{display:none;font-size:20px}

/* Hero */
.hero{display:grid;gap:28px;grid-template-columns:1.2fr .8fr;align-items:center}
.badge{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border:1px solid var(--border);border-radius:999px;font-size:14px;color:var(--muted);position:relative;overflow:hidden}
.badge i{color:var(--green)}
.badge:after{content:"";position:absolute;left:-30%;top:0;width:30%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.8),transparent);transform:skewX(-20deg);opacity:.0}
.badge:hover:after{animation:sheen 1.2s ease}
h1{font-size:52px;line-height:1.05;margin:10px 0 12px}
.lead{font-size:18px;color:var(--muted)}
.hero-cards{display:grid;gap:18px;grid-template-columns:1fr 1fr}
.card{border:1px solid var(--border);border-radius:var(--radius);padding:22px;background:#fff;box-shadow:var(--shadow);transition:transform .25s ease, box-shadow .25s ease}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.08)}
.card i{font-size:22px;color:var(--blue);transition:transform .25s ease}
.card:hover i{transform:translateY(-2px)}

/* Pills */
.pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.pill{border:1px solid var(--border);padding:8px 12px;border-radius:999px;font-size:14px;color:#111;transition:background .25s ease, transform .2s ease}
.pill:hover{background:#f8fafc;transform:translateY(-2px)}

/* Sections */
.section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px}
.section-title h2{font-size:34px;margin:0}
.muted{color:var(--muted)}
.accent{background:linear-gradient(135deg,var(--green),var(--blue));-webkit-background-clip:text;background-clip:text;color:transparent}

/* Grids for icon blocks */
.stack-grid {
  grid-template-columns: repeat(3, 1fr);
}

.ai-grid, .seo-grid {
  grid-template-columns: repeat(3, 1fr);
}

/* Services grid */
.service{padding:24px;border:1px solid var(--border);border-radius:22px;background:#fff;box-shadow:var(--shadow);transition:transform .25s ease, box-shadow .25s ease}
.service:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(0,0,0,.07)}
/* Увеличен отступ между иконкой и заголовком */
.service i.fa-solid, .service i.fa-brands {
  font-size: 22px !important;
  margin-bottom: 15px !important;
  color: var(--green) !important;
}

/* Дополнительные стили для исправления проблем */

/* Отступы для блоков с иконками */
div.section div.container div.grid.stack-grid div.service i,
div.section div.container div.grid.ai-grid div.service i,
div.section div.container div.grid.seo-grid div.service i {
  margin-bottom: 15px !important;
}

/* Buttons */
.btn{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border-radius:14px;border:1px solid var(--border);font-weight:600;transition:transform .2s ease, box-shadow .2s ease}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(0,0,0,.06)}
.btn.primary{background:linear-gradient(135deg,var(--green),var(--blue));color:#fff;border:none}
.btn.primary:after, .btn:after{content:"";position:absolute;top:-120%;left:-30%;width:40%;height:300%;background:linear-gradient(130deg,transparent 40%,rgba(255,255,255,.45),transparent 60%);transform:skewX(-12deg) translateX(-150%);transition:transform .8s ease}
.btn:hover:after{transform:skewX(-12deg) translateX(220%)}

/* Portfolio & Training */
.portfolio-grid{grid-template-columns:repeat(3,1fr)}
.tile{position:relative;overflow:hidden;border-radius:20px;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow)}
.tile img{transition:transform .6s cubic-bezier(.2,.8,.2,1)}
.tile:hover img{transform:scale(1.04)}
.tile figcaption{position:absolute;left:12px;bottom:12px;background:rgba(255,255,255,.85);padding:8px 12px;border-radius:12px;font-weight:600;backdrop-filter:blur(4px)}

/* Testimonials */
.quotes{grid-template-columns:repeat(3,1fr)}
.quote{padding:22px;border:1px solid var(--border);border-radius:20px;background:#fff;box-shadow:var(--shadow);transition:transform .25s ease}
.quote:hover{transform:translateY(-3px)}
.quote i{color:var(--blue)}

/* Process Steps */
.steps {
  grid-template-columns: repeat(3, 1fr);
  counter-reset: step-counter;
  margin-top: 20px; /* Добавляем отступ сверху для ряда иконок */
}
.step {
  position: relative;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: #fff;
  box-shadow: var(--shadow);
  padding: 22px;
  padding-top: 30px;
}
.step::before {
  counter-increment: step-counter;
  content: counter(step-counter);
  position: absolute;
  top: -20px; /* Скорректировано положение иконки */
  left: 20px;
  width: 40px;
  height: 40px;
  background: linear-gradient(135deg, var(--green), var(--blue));
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 18px;
  border: 3px solid var(--bg); /* Рамка в цвет фона для эффекта "утопленности" */
  box-shadow: 0 4px 12px rgba(0,0,0,.1);
}

/* FAQ */
details{border:1px solid var(--border);border-radius:16px;padding:14px 16px;background:#fff;transition:box-shadow .25s ease}
details[open]{box-shadow:0 10px 28px rgba(0,0,0,.06)}
details+details{margin-top:12px}
summary{cursor:pointer;font-weight:600}

/* Footer */
footer{border-top:1px solid var(--border);padding:40px 0;color:var(--muted)}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;z-index:100}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:84vh;border-radius:20px}
.lightbox .close{position:absolute;top:24px;right:24px;font-size:28px;color:#fff;cursor:pointer}

/* Keyframes */
@keyframes sheen{0%{transform:skewX(-20deg) translateX(-160%);opacity:.0}40%{opacity:.9}100%{transform:skewX(-20deg) translateX(260%);opacity:0}}
@keyframes logoPulse{0%,100%{filter:saturate(1)}50%{filter:saturate(1.2)}}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important}
}

/* Responsive */
@media (max-width:1400px){
  .hero{grid-template-columns:1fr}
}
@media (max-width:1024px){
  .pricing{grid-template-columns:1fr}
  .quotes{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:720px){
  .menu{display:none}
  .burger{display:block}
  .hero-cards{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:1fr}
}

/* Дополнительные стили для исправления проблем */

/* Отступы для блоков с иконками */
div.grid div.service i {
  margin-bottom: 15px !important; /* Принудительный увеличенный отступ */
}

/* Стили для блока "Прозрачные пакеты" */
.pricing {
  grid-template-columns: repeat(3, 1fr); /* Три колонки */
  gap: 28px; /* Отступы между колонками */
}

.price-card {
  border: 1px solid var(--border); /* Границы для колонок */
  border-radius: 22px;
  padding: 24px;
  background: #fff;
  box-shadow: var(--shadow);
  transition: transform .25s ease, box-shadow .25s ease;
}

.price-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 32px rgba(0,0,0,.07);
}

.price {
  font-size: 32px;
  font-weight: 700;
  margin: 16px 0;
}

.price span {
  font-size: 48px;
}

/* Стили для страниц "Кейсы" и "Контакты" */
#view-cases.route,
#view-contacts.route {
  min-height: 100vh;
}

#view-cases .section {
  padding-top: 20px; /* Отступ сверху уменьшен на 60px */
}

/* Отступ между заголовком и подзаголовком на странице контактов */
#view-contacts .section-title span.muted {
  margin-top: 0; /* Сброс лишнего отступа */
}

#view-contacts .section .container {
  display: block; /* Возвращаем блочное отображение для корректных отступов */
  min-height: auto; /* Убираем лишнюю высоту */
}

/* Новые стили для страницы "Кейсы" */
#view-cases .section .container {
  max-width: 1440px;
  padding: 0;
  margin: 0 auto; /* Центрируем контейнер */
  display: block;
  min-height: auto;
}

/* -- Modern Flexbox with Gap for Portfolio Grid -- */
#view-cases .portfolio-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}

#view-cases .portfolio-grid .tile {
  flex: 1 0 calc((100% - 80px) / 3);
}

/* Стили для иконки в кнопке формы */
#contact-form .btn.primary i {
  color: #fff !important; /* Устанавливаем белый цвет с приоритетом */
  font-size: 14px !important; /* Устанавливаем размер с приоритетом */
  margin-bottom: 0 !important; /* Убираем лишний отступ снизу */
}

#view-cases .section-title {
  overflow: hidden;
}

.spotlight {
  position: fixed;
  top: 0;
  left: 0;
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--blue) 0%, var(--green) 50%, transparent 70%);
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 9999;
  mix-blend-mode: overlay;
  opacity: 0.3;
}
