.container {
  width: 100%;
  max-width: 1440px;
  margin: 0 auto; }

@media all and (max-width: 1023px) {
  h1, .h1 {
    font-size: 42px; }
  h2, .h2 {
    font-size: 32px; }
  h3, .h3 {
    font-size: 24px; }
  h4, .h4 {
    font-size: 20px; }
  h5, .h5 {
    font-size: 16px; }
  h6, .h6 {
    font-size: 14px; }
  .main {
    padding-top: 56px; }
  .header {
    min-height: 56px; }
    .header.start .hamburger {
      display: none; }
    .header__logo {
      height: 42px;
      order: 1; }
      .header__logo img {
        width: auto;
        height: 42px; }
    .header__menu {
      position: fixed;
      top: -999px;
      left: 0;
      right: 0;
      height: 0;
      bottom: 0;
      padding: 48px 12px;
      background: #ffffff;
      z-index: 5;
      opacity: 0;
      overflow-y: auto;
      transition: .4s ease-in-out;
      order: 13; }
      .header__menu ul {
        justify-content: center;
        flex-wrap: wrap; }
        .header__menu ul li {
          width: 100%;
          margin: 0 12px 16px 12px;
          text-align: center; }
          .header__menu ul li:last-child {
            margin-bottom: 0; }
      .header__menu.open {
        border-top: 1px solid #F5F5F5;
        top: 56px;
        height: calc(100% - 56px);
        opacity: 1; }
    .header__button {
      display: flex;
      justify-content: flex-end;
      margin-right: 24px;
      flex-grow: 1;
      order: 2; }
    .header .hamburger {
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      height: 18px;
      width: 24px;
      position: relative;
      cursor: pointer;
      order: 3; }
      .header .hamburger span {
        background: #85C229;
        border-radius: 4px;
        height: 2px;
        transition: 0.4s cubic-bezier(0.68, -0.6, 0.32, 1.6); }
        .header .hamburger span:nth-child(1) {
          width: 100%; }
        .header .hamburger span:nth-child(2) {
          width: 100%; }
        .header .hamburger span:nth-child(3) {
          width: 100%; }
      .header .hamburger.open span:nth-child(1) {
        transform-origin: bottom;
        transform: rotateZ(45deg) translate(5px, 5px) scale(1.1); }
      .header .hamburger.open span:nth-child(2) {
        transform-origin: top;
        transform: rotateZ(-45deg) scale(1.1); }
      .header .hamburger.open span:nth-child(3) {
        transform-origin: top;
        width: 100%;
        opacity: 0;
        transform: rotateZ(-45deg) translate(5px, -5px);
        transition: .4s ease-in-out; }
    .header.open {
      border-bottom: none; } }

@media all and (min-width: 1536px) {
  .cases__full .container {
    max-width: 1620px;
    padding: 0 90px; }
  .cases__full__wrap {
    max-width: 350px; } }

@media all and (min-width: 1200px) and (max-width: 1535px) {
  .container {
    max-width: 1140px; }
  .cases__full .container {
    max-width: 1366px;
    padding: 0 72px; }
  .cases__full__wrap {
    max-width: 350px; }
  .cases__two .link {
    padding: 48px 72px; }
  .footer__menu ul li {
    margin: 0 8px; }
  .footer__follow {
    flex-wrap: wrap;
    justify-content: flex-end;
    max-width: 240px; }
    .footer__follow .title {
      width: 100%;
      text-align: right;
      margin-bottom: 12px;
      margin-right: 0; } }

@media all and (min-width: 1024px) and (max-width: 1199px) {
  .container {
    padding: 0 32px; }
  .inner {
    padding: 0 32px; }
  .cases__title {
    margin-bottom: 12px; }
  .cases__full {
    height: 480px; }
    .cases__full__wrap {
      max-width: 350px;
      padding: 0 8px; }
    .cases__full__image {
      height: 480px; }
      .cases__full__image img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: left center; }
  .cases__two .link {
    padding: 36px; }
  .feature {
    padding: 48px 0; }
  .services .col-2 {
    max-width: calc(100% - 24px);
    margin: 0 12px 24px 12px; }
  .services .col-1 {
    max-width: calc(100% - 24px); }
  .footer__logo {
    width: 100%;
    display: flex;
    justify-content: center;
    margin-bottom: 24px; }
  .footer__menu {
    width: 100%;
    display: flex;
    justify-content: center;
    margin-bottom: 24px; }
  .footer__follow {
    flex-wrap: wrap;
    width: 100%;
    justify-content: center; }
    .footer__follow .title {
      width: 100%;
      margin-bottom: 24px;
      text-align: center; } }

@media all and (min-width: 768px) and (max-width: 1023px) {
  .container {
    padding: 0 24px; }
  .header.start .header__logo {
    position: relative;
    height: 76px; }
  .inner {
    padding: 0 24px; }
  .cases__title {
    margin-bottom: 12px; }
  .cases__full {
    height: 608px; }
    .cases__full__wrap {
      padding: 36px 12px;
      justify-content: flex-start; }
    .cases__full__image {
      height: 608px; }
      .cases__full__image img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: left center; }
  .cases__two .link {
    padding: 36px; }
  .feature {
    padding: 48px 0; }
    .feature__text {
      margin-bottom: 24px; }
    .feature__content {
      max-width: 100%; }
    .feature__image {
      max-width: 100%;
      text-align: center; }
  .services .col-2 {
    max-width: calc(100% - 24px);
    margin: 0 12px 24px 12px; }
  .services .col-1 {
    max-width: calc(100% - 24px); }
  .footer__logo {
    width: 100%;
    display: flex;
    justify-content: center;
    margin-bottom: 24px; }
  .footer__menu {
    width: 100%;
    display: flex;
    justify-content: center;
    margin-bottom: 24px; }
  .footer__follow {
    flex-wrap: wrap;
    width: 100%;
    justify-content: center; }
    .footer__follow .title {
      width: 100%;
      margin-bottom: 24px;
      text-align: center; } }

@media all and (max-width: 767px) {
  .container {
    padding: 0 16px; }
  .header.start .header__wrap {
    padding: 20px 0 0; }
  .header.start .header__logo {
    position: relative;
    height: 64px; }
  .inner {
    padding: 0 16px; }
  .hero {
    padding: 48px 0; }
  .cases {
    padding: 24px 0; }
    .cases__title {
      margin-bottom: 4px; }
    .cases__full {
      height: 577px; }
      .cases__full__wrap {
        padding: 24px 8px;
        justify-content: flex-start; }
      .cases__full__image {
        height: 577px; }
        .cases__full__image img {
          width: 100%;
          height: 100%;
          object-fit: cover;
          object-position: left center; }
    .cases__two {
      width: calc(100% - 24px); }
      .cases__two .link {
        padding: 24px; }
    .cases__one {
      width: calc(100% / 2 - 24px); }
  .feature {
    padding: 32px 0; }
    .feature__title {
      margin-bottom: 16px; }
    .feature__text {
      margin-bottom: 24px; }
    .feature__content {
      max-width: 100%; }
    .feature__image {
      max-width: 100%; }
  .services .col-2 {
    max-width: calc(100% - 24px);
    margin: 0 12px 24px 12px; }
  .services .col-1 {
    max-width: calc(100% - 24px); }
  .services--two {
    max-width: calc(100% - 24px); }
  .services--one {
    max-width: calc(100% - 24px);
    margin: 0 12px 24px 12px; }
  .services__item {
    padding: 24px; }
  .footer__logo {
    width: 100%;
    display: flex;
    justify-content: center;
    margin-bottom: 24px; }
  .footer__menu {
    width: 100%;
    margin-bottom: 24px; }
    .footer__menu ul {
      justify-content: center;
      flex-wrap: wrap; }
      .footer__menu ul li {
        width: 100%;
        margin: 0 12px 16px 12px;
        text-align: center; }
  .footer__follow {
    width: 100%;
    flex-direction: column; }
    .footer__follow .title {
      margin-right: 0;
      margin-bottom: 12px; } }
