@media screen and (max-width: 1600px) {
  #header {
    padding: 30px 0;
  }
  .aside_inner {
    width: 94%;
  }
  .pf_info .inner {
    width: 94%;
  }
  .pf_dssc br {
    display: none;
  }
  .pf_bg_txt p {
    font-size: 90px;
    line-height: 110px;
  }
}
@media screen and (max-width: 1400px) {
  .inner {
    width: 96%;
  }
  .visual_inner {
    width: 96%;
  }
  .aside_inner {
    width: 96%;
  }
  .pf_info .inner {
    width: 96%;
    padding: 60px 35px;
  }
  .txt_inner {
    width: 80%;
  }
  .contact_1 {
    width: 30%;
  }
  .contact_2 {
    width: 60%;
  }

  .portfolio .item_title h3 {
    font-size: 15px;
  }
  .portfolio .item_title button {
    font-size: 14px;
  }
  .portfolio .item_info .txt strong {
    font-size: 18px;
  }
  .portfolio .item_info .txt p {
    font-size: 13px;
  }
  .pf_close {
    right: 28px;
  }
}

@media screen and (max-width: 1024px) {
  .visual_inner {
    padding: 250px 0 350px;
  }
  .visual_txt {
    z-index: 99;
  }
  .visual_txt h2 {
    font-size: 80px;
    line-height: 90px;
    margin-bottom: 80px;
  }
  .visual_txt p {
    font-size: 35px;
  }
  .visual_txt h2:after {
    width: 450px;
    bottom: -45px;
    left: 0;
  }
  .visual_logo_wrap {
    position: absolute;
    right: 0;
    bottom: -50px;
    z-index: -1;
  }
  .visual_logo_wrap img {
    width: 280px;
  }
  .logo_shadow {
    width: 340px !important;
    right: -30px;
    bottom: 0.86vw;
  }

  .contact_title h2 {
    font-size: 40px;
    margin-bottom: 20px;
  }
  .contact_title p {
    font-size: 18px;
    margin-bottom: 60px;
    padding-bottom: 20px;
  }
  .contact_1 {
    width: 100%;
  }
  .contact_2 {
    width: 100%;
    margin-left: 0;
    margin-top: 68px;
  }
  .contact_3 > div {
    width: 100%;
  }
  .contact_3 > ul {
    width: 100%;
    margin-left: 0;
    margin-top: 20px;
  }
  .map .desc span {
    font-size: 17px;
  }
  .map .desc span + span {
    margin-top: 8px;
  }
  .portfolio .item {
    width: 48%;
    margin-top: 4%;
  }
  .gutter_sizer {
    width: 4%;
  }
  .portfolio .item_title h3 {
    font-size: 16px;
  }
  .portfolio .item_title button {
    font-size: 14px;
  }
  .portfolio .item_thumb .txt strong {
    font-size: 15px;
    font-weight: 500;
  }
  .portfolio .item_thumb .txt p {
    font-size: 13px;
    font-weight: 300;
  }
  .aside_inner {
    padding-top: 300px;
  }
  .aside_inner ul li a {
    font-size: 50px;
  }
  .aside_inner ul li + li {
    margin-top: 70px;
  }
  .pf_dssc {
    display: block;
  }
  .pf_dssc div {
    display: block;
  }
  .pf_dssc div:nth-child(1) {
    width: 100%;
    padding-right: 0;
  }
  .pf_dssc div:nth-child(2) {
    border-left: initial;
    width: 100%;
    padding-left: 0;
    margin-top: 30px;
  }
  .pf_info .title p {
    font-size: 40px;
  }
  .pf_info .title span {
    font-size: 18px;
  }
  .pf_info .title span + span {
    margin-left: 5px;
  }
  .pf_dssc p {
    font-size: 18px;
    line-height: 28px;
  }
  .pf_dssc div:nth-child(2) ul li b {
    font-size: 18px;
  }
  .pf_dssc div:nth-child(2) ul li span {
    font-size: 18px;
  }
  .info_btn button a {
    width: 230px;
  }

  .pf_bg_txt p {
    font-size: 60px;
    line-height: 70px;
  }
}
@media screen and (max-width: 800px) {
  .pf_inner ul li:nth-child(3),
  .pf_inner ul li:nth-child(4),
  .pf_inner ul li:nth-child(5) {
    padding: 80px 0;
  }
  .pf_inner ul li p {
    margin-bottom: 50px;
  }
  .back_btn {
    right: 50px;
    transition: initial;
    opacity: 1;
  }
  .pf_pc {
    padding: 10% 0;
  }
  .grid_2 {
    margin-top: 5%;
  }
  .grid_2 img {
    display: block;
    width: 100%;
  }
  .grid_2 img + img {
    margin-left: 0;
    margin-top: 5%;
  }
  .portfolio .item {
    width: 100%;
  }
  .gutter_sizer {
    width: 0%;
  }
  .pf_close {
    right: 12px;
  }
}
@media screen and (max-width: 680px) {
  .check_style li > span {
    display: block;
    margin-bottom: 20px;
  }
  .contact_submit {
    width: 170px;
    height: 40px;
    font-size: 16px;
  }
  #footer {
    padding: 50px 0;
  }
  #footer p {
    font-size: 12px;
  }
  .pf_info {
    padding: 80px 0;
  }
  .pf_info .title {
    margin-bottom: 45px;
  }
  .pf_info .title p {
    font-size: 30px;
    margin-bottom: 10px;
  }
  .pf_info .title span {
    font-size: 14px;
  }
  .pf_dssc p {
    font-size: 14px;
    line-height: 24px;
  }
  .pf_dssc div:nth-child(2) ul li b {
    font-size: 16px;
    margin-top: -8.5px;
  }
  .pf_dssc div:nth-child(2) ul li span {
    font-size: 16px;
  }
  .info_btn {
    margin-top: 80px;
  }
  .pf_bg_txt p {
    font-size: 40px;
    line-height: 50px;
  }
  .pf_bg_txt span {
    font-size: 20px;
    line-height: 30px;
  }
}
@media screen and (max-width: 580px) {
  .hamburger .line {
    width: 40px;
    height: 4px;
  }
  #hamburger.is-active .line:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }
  #hamburger {
    margin-top: -14px;
    right: 4px;
  }
  .hamburger .line {
    margin: 6px auto;
  }
  #header {
    padding: 15px 0;
  }
  .visual_inner {
    padding: 53vw 0 53vw;
  }
  .visual_txt h2 {
    font-size: 13.79vw;
    line-height: 15.51vw;
    margin-bottom: 13.79vw;
  }
  .visual_txt p {
    font-size: 6.03vw;
  }
  .visual_txt h2:after {
    width: 77.58vw;
    height: 1.2vw;
    bottom: -7.75vw;
  }

  .visual_logo_wrap img {
    width: 48.27vw;
  }
  .logo_shadow {
    width: 58.62vw !important;
    right: -5.17vw;
    bottom: 1.5vw;
  }
  .portfolio_wrap .title {
    font-size: 7.75vw;
  }
  .portfolio_wrap .title:after {
    width: 53.5vw;
    height: 0.6vw;
  }

  .contact_wrap {
    padding: 52vw 0 20vw;
  }
  .contact_form span {
    position: static !important;
    margin-bottom: 2vw;
  }
  .input_style li input[type="text"] {
    padding: 1.66vw 8.41vw 1.66vw 1.5vw;
  }
  #budgetValue {
    padding: 1.66vw 8.41vw 1.66vw 1.5vw;
  }
  .check_style li label span {
    margin-bottom: 0 !important;
  }
  #budgetVal {
    padding-right: 15.93vw;
  }
  .unit {
    position: absolute;
    right: 9.27vw;
    bottom: 2.06vw;
  }
  .burger-main span {
    width: 38px;
    height: 4px;
  }
  .top {
    top: 0;
    transform-origin: 35.6px 3px;
  }

  .bot {
    bottom: 0;
    transform-origin: 35.6px 3px;
  }
  .portfolio .item {
    padding: 5vw 4.44vw 6vw;
  }

  .portfolio li + li {
    margin-top: 11vw;
  }
  .portfolio .item_title h3 {
    font-size: 4.13vw;
  }
  .portfolio .item_title button {
    font-size: 3.44vw;
  }
  .portfolio .item_thumb .txt strong {
    font-size: 5.2vw;
    font-weight: 600;
  }
  .portfolio .item_thumb .txt p {
    font-size: 3.8vw;
    line-height: 5.2vw;
    font-weight: 500;
  }
  .pf_dssc div:nth-child(2) ul li span {
    padding-left: 15vw;
  }
  .pf_bg {
    height: 155vw;
  }
  .pf_info {
    padding: 13.66vw 0;
    margin-top: 205vw;
  }
  .pf_info .title {
    margin-bottom: 8.37vw;
  }
  .pf_info .title p {
    font-size: 5.25vw;
    margin-bottom: 2.08vw;
  }
  .pf_info .title span {
    font-size: 2.5vw;
  }
  .pf_info .title span + span {
    margin-left: 2px;
  }
  .pf_dssc p {
    font-size: 2.91vw;
    line-height: 5vw;
  }
  .pf_dssc div:nth-child(2) {
    margin-top: 5.17vw;
  }
  .pf_dssc div:nth-child(2) ul li b {
    font-size: 3.33vw;
    margin-top: -1.98vw;
  }
  .pf_dssc div:nth-child(2) ul li span {
    font-size: 3.33vw;
  }

  .pf_dssc div:nth-child(2) ul li + li {
    margin-top: 4.16vw;
  }
  .pf_info .inner {
    padding: 10.34vw 4.29vw;
  }
  .info_btn {
    margin-top: 16.66vw;
    display: flex;
    width: 100%;
    justify-content: center;
    align-content: center;
  }
  .info_btn button {
    width: 100%;
    display: block;
  }
  .info_btn button a {
    width: 100%;
    line-height: 10vw;
    height: 10vw;
  }
  .info_btn button a span {
    font-size: 3.4vw;
  }
  .info_btn button a span + span {
    margin-left: 1.04vw;
  }

  .info_btn button a span img {
    width: 4.16vw;
  }
  .pf_close {
    width: 11.25vw;
    height: 11.25vw;
    top: 10vw;
    right: 2vw;
  }
  .aside_inner {
    padding-top: 51vw;
  }
  .aside_inner ul li a {
    font-size: 6.89vw;
    margin-right: 2.37vw;
  }
  .aside_inner ul li + li {
    margin-top: 6.89vw;
  }
  .contact_form .budget_arrow {
    position: absolute !important;
    margin-bottom: 0 !important;
    bottom: 1.72vw;
  }
}
@media screen and (max-width: 480px) {
  .logo_shadow {
    bottom: 5.5vw;
  }
  .contact_form {
    padding-bottom: 20vw;
  }
  .border_line {
    margin-bottom: 20vw;
  }
  .contact_title h2 {
    font-size: 8.33vw;
    margin-bottom: 4.16vw;
  }
  .contact_title p {
    font-size: 3.75vw;
    margin-bottom: 12.5vw;
    padding-bottom: 4.16vw;
  }
  .contact_form h3 {
    font-size: 5vw;
    margin-bottom: 9.16vw;
  }
  .contact_form span {
    font-size: 4vw;
  }
  .contact_3 {
    margin-top: 20vw;
    margin-bottom: 22vw;
  }
  .contact_3 > div h4 {
    font-size: 4vw;
    margin-bottom: 1.66vw;
  }

  .check_style li > span {
    margin-bottom: 4.16vw;
  }
  .check_style li label + label {
    margin-left: 2.125vw;
  }
  .contact_form label span {
    font-size: 3vw;
    margin-bottom: 0 !important;
  }
  #budgetVal {
    padding-right: 19.93vw;
  }
  .unit {
    position: absolute;
    right: 12.27vw;
    bottom: 2.3vw;
  }
  .budget_btn {
    right: 5.2vw;
    bottom: 2vw;
  }
  .budget_arrow {
    bottom: 1.04vw;
    right: 4.16vw;
  }
  .file_icon {
    bottom: 2vw;
    right: 4vw;
  }
  #map {
    height: 400px !important;
  }
  .map .desc span {
    font-size: 3.6vw;
  }
  .map .desc span + span {
    margin-top: 1.66vw;
  }
  .pf_dssc div:nth-child(2) ul li b {
    margin-top: -1.37vw;
  }
  .portfolio .item_title {
    margin-bottom: 2.91vw;
  }
  .pf_inner ul li:nth-child(3),
  .pf_inner ul li:nth-child(4),
  .pf_inner ul li:nth-child(5) {
    padding: 13.79vw 0;
  }
  .pf_inner ul li:nth-child(2) {
    padding-top: 12.06vw;
  }
  .pf_inner ul li:nth-child(2) a {
    width: 31vw;
    line-height: 8.62vw;
    border-radius: 8.62vw;
    font-size: 3.1vw;
  }
  .pf_inner ul li p {
    font-size: 6.89vw;
    margin-bottom: 17.24vw;
  }

  .back_btn {
    width: 14.58vw;
    height: 21.87vw;
    right: 3.41vw;
    padding: 3.12vw 1.04vw;
    bottom: 20vw;
  }
  .back_btn span {
    font-size: 2.91vw;
  }
  .back_btn img {
    width: 10.41vw;
  }
  #footer {
    padding: 40px 0;
  }

  .pf_close img {
    width: 20px;
  }
  .pf_bg_txt p {
    font-size: 8.33vw;
    line-height: 10.5vw;
  }
  .pf_bg_txt span {
    font-size: 4.16vw;
    margin-top: 4vw;
    line-height: 6.25vw;
  }
}
@media screen and (max-width: 380px) {
  .unit {
    right: 12.5vw;
    bottom: 2.5vw;
  }
  #budgetVal {
    padding-right: 21vw;
  }
  .portfolio .item_info .txt strong {
    font-size: 4.73vw;
  }
  .portfolio .item_info .txt p {
    font-size: 3.42vw;
    line-height: 4.47vw;
  }
}
