 :root{
    --bg1:#3f5efb;
    --bg2:#6a4df5;
    --orange:#ff7a18;
    --orange2:#ff5f00;
    --white: #fff;
  }

  *{ margin:0; padding:0; box-sizing:border-box; }
  body{
    font-family:'Inter',sans-serif;
    color:var(--white);
    background:linear-gradient(135deg,var(--bg1) 0%, var(--bg2) 40%, var(--bg1) 100%);
  }

  .container{
    width:1200px;
    max-width:92%;
    margin:0 auto;
  }

  /* HERO */
  .hero{ padding:96px 0 72px; }
  .hero h1 {
    padding:0px 30px 0px 90px;
	font-size:62px;
    line-height:1;
    font-weight:500;
    max-width:80%;
    letter-spacing:-0.02em;
  }
  .hero p{
	padding:22px 30px 0px 90px;
    1margin-top:22px;
    font-size:22px;
    line-height:1.3;
	font-weight:500;
    max-width:630px;
    opacity:.9;
	letter-spacing:-0.03em;
  }
  
  .hero2{ padding:15px 0 20px 0; }
   .hero2 h2 {
    padding:0px 30px 0px 90px;
	font-size:46px;
    line-height:1;
    font-weight:500;
    max-width:80%;
    letter-spacing:-0.02em;
  }
  .hero2 p{
	padding:22px 30px 0px 90px;
    1margin-top:22px;
    font-size:22px;
    line-height:1.3;
	font-weight:500;
    max-width:630px;
    opacity:.9;
	letter-spacing:-0.03em;
  }

  /* video frame */
  .video-block{
    margin-top:56px;
    background:linear-gradient(80deg,#4c5dfb, var(--orange));
    padding:40px;
    border-radius:0px;
  }

  .video-wrapper{
    background:#e6e6e6;
    border-radius:12px;
    overflow:hidden;
    position:relative;
    /* responsive 16:9 */
    aspect-ratio: 16 / 9;
    display:flex;
    align-items:center;
    justify-content:center;
  }

  /* fake overlay button like in mock 
  .video-wrapper::after{
    content:"▶ Это тизер";
    position:absolute;
    background:rgba(0,0,0,.60);
    padding:14px 22px;
    border-radius:8px;
    font-weight:600;
    font-size:14px;
    letter-spacing:.01em;
  }*/

  /* OPTIONAL: if you later place an iframe */
  .video-wrapper iframe,
  .video-wrapper video{
    width:100%;
    height:100%;
    border:0;
    display:block;
  }

  /* FEATURES */
  .features{
    padding:72px 100px 10px;
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:40px;
  }

  .feature{
    display:flex;
    flex-direction:column;
    gap:10px;
    min-height:90px;
  }

  .icon{
    width:40px;
    height:40px;
    background:var(--orange);
    border-radius:10px;
  }

  .feature h3{ font-size:22px; font-weight:500; padding-top: 14px}
  .feature p{ font-size:14px; line-height:1.5; opacity:.85; max-width:220px; padding-top: 0px; font-weight:300; }

  
  
  /* STATS */
  .stats{
    margin:70px auto 0;
    padding:56px 56px 120px 56px;
    border-radius:12px;
    background:linear-gradient(135deg,var(--orange2), #ff8c42);
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:40px;
  }

  .stats-left{
    max-width:420px;
    font-size:18px;
    line-height:1.45;
    font-weight:600;
  }

  .stats-numbers{
    display:flex;
    gap:56px;
    flex-wrap:wrap;
    justify-content:flex-end;
  }

  .stat h2{
    font-size:36px;
    line-height:1;
    letter-spacing:-0.02em;
  }
  .stat p{
    margin-top:10px;
    font-size:14px;
    opacity:.95;
    max-width:170px;
  }

  /* CTA */
  .cta{
    margin:40px 0 100px 0;
	padding:20px 0 72px;
    1background:linear-gradient(135deg,#4f5ef7, var(--orange));
  }

  .cta h2{  
	padding:0px 30px 0px 90px;
	font-size:40px;
    line-height:1;
    font-weight:500;
    max-width:80%;
    letter-spacing:-0.02em;
  
  }

  .buttons{
	padding:0px 30px 0px 90px;
    margin-top:36px;
    display:flex;
    gap:18px;
    flex-wrap:wrap;
  }

  .btn{
    padding:14px 28px;
    font-weight:700;
    border-radius:6px;
    cursor:pointer;
    text-decoration:none;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:48px;
    user-select:none;
    transition:transform .12s ease, opacity .12s ease;
  }
  .btn:active{ transform:scale(.98); }
  .btn:hover{ opacity:.95; }

  .btn-primary{ background:var(--orange); color:var(--white); }
  .btn-secondary{ border:1px solid rgba(255,255,255,.9); color:var(--white); }

	/* убираем системную рамку */
	.btn:focus, .btn-primary:focus {
	  outline: none;
	}

	/* рисуем свою — только при навигации с клавиатуры */
	.btn:focus-visible, .btn-primary:focus-visible {
	  outline: none;
	  box-shadow: 0 0 0 3px rgba(255,255,255,.35);
	}

  /* ---------------------------
     RESPONSIVE
  --------------------------- */

  /* <= 1024px */
  @media (max-width: 1024px){
    .hero{ padding:72px 0 56px; }
    .hero h1{ font-size:48px; max-width:720px; }
    .video-block{ padding:28px; }
    .features{ grid-template-columns:repeat(2,1fr); gap:28px; }
    .stats{ padding:44px; }
    .cta{ padding:90px 0; }
    .cta h2{ font-size:42px; }
  }

  /* <= 640px (mobile) */
  @media (max-width: 640px){
    .container{ max-width:92%; }

    .hero{ padding:54px 0 44px; }
    .hero h1{
	  padding:0px 15px 0px 15px;
      font-size:34px;
      line-height:1.12;
      max-width:100%;
    }
    .hero p{
	  padding: 0px 15px 0px 15px;
      font-size:17px;
      margin-top:14px;
      max-width:100%;
    }
	
	.hero2 h2{
	  padding:0px 15px 0px 10px;
      font-size:24px;
      line-height:1.12;
      max-width:100%;
    }
    .hero2 p{
	  padding: 0px 15px 0px 10px;
      font-size:15px;
      margin-top:14px;
      max-width:100%;
    }

    .video-block{
      margin-top:28px;
      padding:16px;
      border-radius:0px;
    }
    .video-wrapper{ border-radius:10px; }
    .video-wrapper::after{
      font-size:13px;
      padding:12px 16px;
    }

/* 2 колонки как на макете */
  .features{
    padding: 20px 10px 0 10px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 26px 22px;         /* row / column gap */
    align-items: start;
  }

  /* карточка-фича: иконка слева, текст справа */
  .feature{
    display: grid;
	grid-template-columns: 25px 1fr;
    column-gap: 12px;
    row-gap: 6px;
    align-items: start;
  }

  .feature .icon{
    width: 24px;
    height: 24px;
    border-radius: 8px;
    background: orange;
    grid-row: 1 / span 2;   /* занимает 2 строки (h3+p) */
    margin-top: 0px;
  }

  .feature h3{
    margin: 0;
	padding-top: 0px;
    font-size: 23px;
    line-height: 1.15;
    font-weight: 700;
    letter-spacing: -0.01em;
  }

  .feature p{
    margin: 0;
	padding-top:0;
    font-size: 18px;
    line-height: 1.2;
    opacity: .85;
	font-weight: 400;
    max-width: none;        /* важно: иначе будет ломать сетку */
  }	
		
		
		
		
    .stats{
      margin-top:44px;
      padding:20px;
      border-radius:14px;
      flex-direction:column;
      align-items:flex-start;
      gap:18px;
    }
    .stats-left{
      font-size:16px;
      line-height:1.5;
      max-width:100%;
    }
    .stats-numbers{
      width:100%;
      justify-content:flex-start;
      gap:18px 24px;
    }
    .stat h2{ font-size:28px; }
    .stat p{ font-size:11px; margin-top:6px; max-width:220px; }

    .cta{
      margin-top:40px;
      padding:22px 0;
    }
    .cta h2{
	  padding: 0px 15px 0px 10px;
      font-size:25px;
      line-height:1.15;
      max-width:100%;
	  font-weight:400;
    }
    .buttons{
	  padding:0px 0px 0px 0px;
      margin-top:22px;
      flex-direction:column;
      gap:12px;
      width:100%;
      align-items:stretch;
    }
    .btn{
      width:100%;
      padding:14px 18px;
    }
  }
  
  
  
/* MODAL (fullscreen for web & mobile) */
.modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none; /* hidden by default */
}

.modal.is-open { display: block; }

.modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.55);
}

.modal__panel {
  position: absolute;
  inset: 0;                 /* fullscreen */
  color:var(--white);
  background:linear-gradient(135deg,var(--bg1) 0%, var(--bg2) 40%, var(--bg1) 100%);
  overflow: auto;
}

.modal__close{
  position: fixed;          /* было absolute */
  top: 16px;
  right: 16px;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.55);
  background: rgba(0,0,0,.25);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 10001;           /* поверх картинки/контента */
}

.modal__content {
  min-height: 100%;
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
}

.modal__media {
  position: relative;
  min-height: 260px;
}

.modal__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.modal__body {
  padding: 80px 56px 56px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 14px;
}

.modal__title {
  font-size: 42px;
  line-height: 1.1;
  letter-spacing: -0.02em;
  max-width: 420px;
}

.modal__subtitle {
  opacity: .9;
  max-width: 420px;
  line-height: 1.45;
}

.modal__form {
  margin-top: 12px;
  display: grid;
  gap: 14px;
  max-width: 420px;
}

.field { display: grid; gap: 8px; }
.field__label { font-size: 13px; opacity: .9; }
.field__input {
  height: 48px;
  border-radius: 6px;
  border: 1px solid rgba(255,255,255,.28);
  background: rgba(0,0,0,.20);
  color: #fff;
  padding: 0 10px;
  outline: none;
}
.field__input::placeholder { color: rgba(255,255,255,.75); }
.field__input:focus { border-color: rgba(255,255,255,.55); }

.field__error {
  min-height: 18px;
  font-size: 12px;
  color: rgba(255,255,255,.95);
  opacity: .95;
}

.field.is-invalid .field__input {
  border-color: rgba(255,255,255,.95);
  1box-shadow: 0 0 0 3px rgba(255,255,255,.18);
}

.modal__submit[disabled] {
  opacity: .6;
  cursor: not-allowed;
}

.consent{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:13px;
  line-height:1.35;
  opacity:.95;
  cursor:pointer;
  user-select:none;
}

.consent input{
  margin-top:0px;
  width:16px;
  height:16px;
  cursor:pointer;
}

.consent a{
  color: #fff;
}

/* Mobile: single column, still fullscreen */
@media (max-width: 768px) {
  .modal__content { grid-template-columns: 1fr; }
  .modal__media { height: 38vh; min-height: 220px; }
  .modal__body { padding: 72px 18px 24px; }
  .modal__title { font-size: 30p; }

   .modal__close{
    top: 12px;
    right: 12px;
    width: 42px;
    height: 42px;
    border-radius: 12px;
  }
}
	