:root{
  --font: "Montserrat", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  --hero-overlay: rgba(0,0,0,.35); /* затемнение как на скрине */
  --accent: #1fc48d; /* цвет кнопки */
  --accent-hover: #19a775;
  --nav-fg: #0f172a;
}

html{ scroll-behavior:smooth; }
body{
   font-family:var(--font);
    /* color:#fff; */
     /* background:#0e9180; */
     }

/* NAVBAR glass */
.navbar-glass{
  --bs-navbar-color: var(--nav-fg);
  --bs-navbar-hover-color: var(--nav-fg);
  --bs-navbar-active-color: var(--accent);
  background: rgba(255,255,255,.85);
  backdrop-filter: saturate(180%) blur(8px);
  box-shadow: 0 1px 0 rgba(15,23,42,.06);
  padding-block: .5rem;
}
.navbar-glass .nav-link{
  font-weight:600;
  letter-spacing:.02em;
}
.navbar-brand{ color: var(--nav-fg); }
.navbar-brand:hover{ color: var(--nav-fg); }

.navbar-nav .nav-link.active {
  color: var(--accent) !important;
  font-weight: 600;
}

/* HERO */
.hero{
  position:relative;
  min-height:100vh;
  background-image: url("/site-migration-bitrix/assets/images/hero-bg.jpg");
  background-size: cover;
  background-position: center;
  background-repeat:no-repeat;
  padding-top: 72px; /* компенсация fixed navbar */
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background: var(--hero-overlay);
}
.hero > .container{ position:relative; z-index:2; }

.hero-title{
  font-weight:800;
  text-transform:uppercase;
  text-align:center;
  line-height:1.2;
  margin-bottom: 1.25rem;
  letter-spacing:.02em;
  /* размеры близкие к макету */
  font-size: clamp(1.8rem, 2.5vw + 1rem, 2.6rem);
}


.section-tasks {
  background-color: #fff;
  color: #0f172a;
}

.tasks-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.task-item {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
}

.task-icon {
  font-size: 1.5rem;
  line-height: 1;
}

.task-item h5 {
  font-weight: 700;
  color: #0f172a;
}

.task-item p {
  color: #475569;
}



.section-offer {
  background-color: #fff;
  color: #fff;
}

.offer-card {
    position: relative;
    padding: 1rem;
    height: 100%;
    min-height: 340px;
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    overflow: hidden;
    border-radius: .25rem;
}

.offer-card .overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 163, 110, 0.92); /* зелёная маска */
  transition: background-color 0.3s ease;
}

.offer-card:hover .overlay {
  background-color: rgba(0, 163, 110, 0.7);
}

.offer-card .content {
  position: relative;
  padding: 1.25rem;
  z-index: 2;
}

.offer-card h5 {
  font-weight: 700;
  text-transform: uppercase;
}

.offer-card p {
  margin-bottom: 0;
  color: rgba(255, 255, 255, 0.9);
}


.section-trust p {
  font-size: 1.05rem;
  color: #0f172a;
}

.section-how-it-works {
  background-color: #fff;
  color: #0f172a;
}



.section-cases{
  background:#fff;
  color:#0f172a;
}
.case-title{
  font-weight:800;
  letter-spacing:.02em;
}
.case-media{
  margin:0;
  border: 1px solid rgba(15,23,42,.08);
  border-radius:.5rem;
  overflow:hidden;
}
.case-media img{
  display:block;
  width:100%;
  height:auto;
}



/* Списки и типографика */
.case-list{
  margin: 0 0 0 1.25rem;
}
.case-list li{
  margin-bottom:.35rem;
}

/* Вертикальные интервалы ближе к макету */
.section-cases .row{
  --bs-gutter-y: 1.5rem;
}

@media (min-width: 992px){
  .section-cases .row{ margin-bottom: 3rem; }
}

/* Лёгкая адаптация: изображения могут быть "порезаны" скрином —
   не обрезаем, даём натуральную высоту, добавляем рамку/тень */
.rounded{ border-radius: .5rem !important; }
.shadow-sm{ box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important; }



/* CTA green band */
.section-cta-band{
  background-color:#05a96b; /* зелёная полоса как на макете */
  color:#fff;
  padding: 64px 0;
}
.section-cta-band .cta-title{
  font-weight:700;
  margin-bottom:16px;
}
.btn-cta{
  background:#ffffff;
  color:#0f172a;
  border:none;
  border-radius:999px;
  font-weight:600;
  padding:.6rem 1.25rem;
}
.btn-cta:hover{
  background:#e9ecef;
  color:#0f172a;
}

/* FAQ spacing & card look similar to screenshot */
.section-faq h2{
  font-size: clamp(1.6rem, 2vw + 1rem, 2.2rem);
}
.accordion-item{
  border-radius:.5rem;
  overflow:hidden;
  border:1px solid rgba(15,23,42,.12);
  margin-bottom: 1rem;
}
.accordion-button{
  padding: 1.1rem 1.25rem;
  font-weight:600;
  color:#0f172a;
}
.accordion-button:not(.collapsed){
  background-color:#f8f9fa;
  color:#0f172a;
  box-shadow:none;
}
.accordion-body{
  color:#0f172a;
  line-height:1.7;
}




@media (min-width: 1200px){
  .hero-title{ font-size: 2.4rem; }
}

.hero-subtitle{
  max-width: 820px;
  opacity:.95;
  font-weight:500;
  line-height:1.75;
  margin: 0 auto 2rem auto;
  font-size: clamp(1rem, .6vw + .8rem, 1.125rem);
}

/* CTA */
.btn-cta{
  background: var(--accent);
  border: none;
  color:#fff;
  border-radius: 999px;
  font-weight:700;
  letter-spacing:.02em;
}
.btn-cta:hover, .btn-cta:focus{
  background: var(--accent-hover);
  color:#fff;
}

/* Тонкая адаптация: уменьшаем межстрочность на узких экранах */
@media (max-width: 575.98px){
  .hero-title{ line-height:1.25; }
  .hero-subtitle{ line-height:1.6; }
}