@charset "utf-8";

/* Services
--------------------------------------------------------- */
.sec-services .l-inner .btn-gp {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.sec-services .btn-gp .btn-l {
  position: relative;
  line-height: 1.3;
  padding: 7px 10px 6px 10px;
  font-family: 'Poppins', sans-serif;
  text-align: center;
}

.sec-services .btn-gp .btn-l::after {
  position: absolute;
  top: 50%;
  right: 5%;
  width: 18px;
  height: 18px;
  background: url('../img/common/ico_dwn_arrow.png') no-repeat center/cover;
  content: '';
  transform: translateY(-50%);
}

.sec-services .btn-gp .btn-l.active {
  background: #2DBB54;
  color: #FFFFFF;
}

.sec-services .btn-gp .btn-l:last-child {
  margin-right: 0;
}

.sec-services .btn-gp .btn-l:hover::after,
.sec-services .btn-gp .btn-l.active::after {
  background: url('../img/common/ico_dwn_arrow_white.png') no-repeat center/cover;
}

.sec-services .ttl {
  margin: 0 auto;
  padding-bottom: 10px;
}

.sec-services .web-design-cnt {
  display: flex;
  align-items: center;
  margin-top: 4px;
}

.sec-services .web-design-ttl {
  width: 48.1%;
}

.sec-services .web-design-create {
  padding: 80px 0 85px;
}

.sec-services .web-design-img {
  width: 47%;
  aspect-ratio: 1.11 / 1;
}

.sec-services .web-design-list {
  width: 50%;
}

.sec-services .web-design-list li {
  position: relative;
  line-height: 1.75;
  padding: 15px 0px 15px 52px;
  color: #606060;
}

.sec-services .web-design-list li::before {
  position: absolute;
  top: 24px;
  left: 0;
  width: 40px;
  height: 29px;
  background: url('../img/services/ico_right.png')no-repeat center/contain;
  content: "";
}

/* web-app-develop
--------------------------------------------------------- */
.sec-services .web-app-develop {
  padding: 80px 0px 80px;
  background-color: #F3FCF7;
}

.sec-services .web-app-ttl {
  width: 55%;
  padding-bottom: 30px;
}

.sec-services .web-app-develop p {
  line-height: 1.75;
  color: #606060;
}

.sec-services .web-app-list .left-blk {
  display: flex;
  gap: 20px;
  margin-block: 40px;
  align-items: center;
  justify-content: center;
}

.sec-services .web-app-list .fst-list {
  width: 250px;
  font-weight: 700;
  text-align: right;
}

.sec-services .web-app-list .sec-list {
  width: 335px;
  font-weight: 700;
}

.sec-services .web-app-list .fst-list li {
  position: relative;
  padding: 30px 63px 31px 0px;
}

.sec-services .web-app-list .sec-list li {
  position: relative;
  padding: 30px 0px 31px 58px;
}

.sec-services .web-app-list .fst-list li::after,
.sec-services .web-app-list .sec-list li::before {
  position: absolute;
  top: 33%;
  width: 31px;
  height: 28px;
  background: url('../img/services/ico_service_laptop.png')no-repeat center/contain;
  content: "";
}

.sec-services .web-app-list .fst-list li::after {
  right: 6%;
}

.sec-services .web-app-list .sec-list li::before {
  left: 6%;
}

/* mobile-app-develop
--------------------------------------------------------- */
.sec-services .mobile-app-cnt {
  display: flex;
  gap: 40px;
}

.sec-services .mobile-app-develop {
  padding: 80px 0px 55px;
  border-bottom: 2px solid #2DBB54;
}

.sec-services .mobile-app-ttl {
  width: 58.3%;
  padding-bottom: 8px;
}

.sec-services .mobile-app-txt {
  width: 47.3%;
  line-height: 1.87;
  padding-top: 22px;
  color: #606060;
}

.sec-services .mobile-app-img {
  width: 31%;
  margin: 0px 88px;
}

/* network-server 
--------------------------------------------------------- */
.sec-services .network-server {
  padding: 80px 0px 61px;
  background: url("../img/services/img_network_server_bg.png") no-repeat center/100% 100%;
}

.sec-services .network-ttl {
  width: 47.6%;
}

.sec-services .network-server p {
  line-height: 1.8;
  padding: 18px 81px 10px;
  color: #606060;
  font-family: 'Karla', sans-serif;
  font-weight: 700;
  text-align: center;
  letter-spacing: -0.47px;
}

.sec-services .network-server ul {
  width: 100%;
  column-count: 2;
}

.sec-services .network-server ul .list-gap {
  margin-left: 20px;
}

.sec-services .network-list li {
  position: relative;
  padding: 44px 0px 36px 99px;
  color: #606060;
  font-family: 'Poppins', sans-serif;
  font-size: 20px;
  font-weight: 600;
}

.sec-services .network-list li::before {
  position: absolute;
  top: 5%;
  left: -3%;
  width: 102px;
  height: 102px;
  background: url("../img/services/ico_network_list.png") no-repeat center/contain;
  content: "";
}

/* Ipad
-----------------------------------------------------------------*/
@media only screen and (min-width:769px) and (max-width:1024px) {

  /* Services
--------------------------------------------------------- */
  .br-none {
    display: none;
  }

  .sec-services .l-inner .btn-gp {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }

  .sec-services .btn-gp .btn-l {
    padding: 0.684vw 0.977vw 0.586vw 0.977vw;
  }

  .sec-services .btn-gp .btn-l::after {
    width: 1.758vw;
    height: 1.758vw;
  }

  .sec-services .btn-gp .btn-l:last-child {
    margin-right: 0;
  }

  .sec-services .ttl {
    padding-bottom: 0.977vw;
  }

  .sec-services .web-design-create {
    padding: 7.813vw 0vw 8.301vw;
  }

  .sec-services .web-design-img {
    width: 47%;
    margin-top: 0.391vw;
  }

  .sec-services .web-design-list {
    padding-top: 0.391vw;
  }

  .sec-services .web-design-list li {
    padding: 1.465vw 0vw 1.465vw 5.078vw;
    font-size: 2.083vw;
  }

  .sec-services .web-design-list li::before {
    top: 2.344vw;
    left: 0vw;
    width: 3.906vw;
    height: 2.832vw;
  }

  /* web-app-develop 
  --------------------------------------------------------- */
  .sec-services .web-app-develop {
    padding: 7.813vw 0vw 7.813vw;
  }

  .sec-services .web-app-develop p,
  .sec-services .mobile-app-develop p {
    font-size: 2.083vw;
  }

  .sec-services .web-app-list .fst-list li {
    padding: 1.930vw 5.313vw 3.027vw 0vw;
  }

  .sec-services .web-app-list .sec-list li {
    padding: 1.930vw 0vw 3.027vw 7.313vw;
  }

  .sec-services .web-app-list .fst-list li::after,
  .sec-services .web-app-list .sec-list li::before {
    top: 20%;
    right: 0;
    width: 3.027vw;
    height: 2.734vw;
  }

  .sec-services .web-app-list .web-app-img {
    margin: 3.613vw 1.270vw 2.637vw;
  }

  .sec-services .web-app-ttl {
    padding-bottom: 2.930vw;
  }

  /* mobile-app-develop 
  --------------------------------------------------------- */
  .sec-services .mobile-app-develop {
    padding: 7.813vw 0vw 5.371vw;
    border-bottom: 0.195vw solid #2DBB54;
  }

  .sec-services .mobile-app-ttl {
    padding-bottom: 0.781vw;
  }

  .sec-services .mobile-app-txt {
    padding-top: 2.148vw;
  }

  .sec-services .mobile-app-img {
    width: 35%;
    margin: 0vw 7.594vw;
  }

  /* network-server 
  --------------------------------------------------------- */
  .sec-services .network-server {
    padding: 7.813vw 0vw 5.957vw;
  }

  .sec-services .network-server p {
    padding: 1.758vw 7.910vw 0.977vw;
    letter-spacing: -0.046vw;
  }

  .sec-services .network-list li {
    padding: 4.297vw 0vw 3.516vw 8.8vw;
    font-size: 2.083vw;
  }

  .sec-services .network-server ul .list-gap {
    margin-left: 1.953vw;
}

  .sec-services .network-list li::before {
    width: 9.961vw;
    height: 9.961vw;
  }

  .sec-services .mobile-app-cnt {
    gap: 10px;
  }
}

/* SP
-----------------------------------------------------------------*/
@media only screen and (max-width:768px) {

  /* Services
--------------------------------------------------------- */
  .br-none {
    display: none;
  }

  .sec-services .l-inner .btn-gp {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }

  .sec-services .btn-gp .btn {
    font-size: 3.2vw;
  }

  .sec-services .btn-gp .btn-l {
    line-height: 1.5;
    padding: 1.394vw 1.563vw 0.638vw 1.563vw;
    letter-spacing: -0.027vw;
  }

  .sec-services .btn-gp .btn-l::after {
    width: 3.125vw;
    height: 3.125vw;
  }

  .sec-services .web-design-create .web-design-ttl {
    width: 71%;
    margin: 0 13.9vw;
    padding-bottom: 1.531vw;
  }

  .sec-services .web-design-cnt {
    flex-direction: column-reverse;
  }

  .sec-services .web-design-create {
    padding: 8.063vw 0vw 7.281vw;
  }

  .sec-services .web-design-img {
    width: 65%;
    margin: 0 17vw;
  }

  .sec-services .web-design-list {
    width: 100%;
    padding-top: 1.825vw;
  }

  .sec-services .web-design-list li {
    padding: 2.344vw 0vw 2.344vw 10.125vw;
    font-size: 3.5vw;
  }

  .sec-services .web-design-list li::before {
    top: 3vw;
    left: 2.8vw;
    width: 5.250vw;
    height: 4.531vw;
  }

  /* web-app-develop
  --------------------------------------------------------- */
  .sec-services .web-app-develop {
    padding: 8.063vw 0vw 6.5vw;
  }

  .sec-services .web-app-develop .web-app-ttl {
    width: 81%;
    margin: 0.8vw 7.6vw;
    padding-bottom: 1.5vw;
  }

  .sec-services .web-app-develop p {
    padding: 2.8vw 1.5vw;
  }

  .sec-services .web-app-develop p,
  .sec-services .mobile-app-develop p {
    font-size: 3.5vw;
  }

  .sec-services .web-app-develop .txt-part {
    padding-top: 2vw;
  }

  .sec-services .web-app-list .fst-list {
    padding-top: 2.930vw;
    text-align: left;
    width: 76.923vw;
  }

  .sec-services .web-app-list .left-blk {
    flex-direction: column;
    gap: 0;
    align-items: flex-start;
    margin-block: 0;
  }

  .item-a { order: 2; }
  .item-b { order: 1; }
  .item-c { order: 3; }

  .sec-services .web-app-list .sec-list {
    width: 100%;
    padding-top: 0vw;
    text-align: left;
  }

  .sec-services .web-app-list .fst-list li,
  .sec-services .web-app-list .sec-list li {
    padding: 1.688vw 0vw 1.844vw 6.281vw;
    font-size: 3.5vw;
  }

  .sec-services .web-app-list .fst-list li::after {
    display: none;
  }

  .sec-services .web-app-list .fst-list li::before,
  .sec-services .web-app-list .sec-list li::before {
    position: absolute;
    top: 15%;
    left: 0;
    width: 4.844vw;
    height: 4.375vw;
    background: url('../img/services/ico_service_laptop.png')no-repeat center/contain;
    content: "";
  }

  .sec-services .web-app-list .web-app-img {
    max-width: 58.594vw;
    align-self: center;
  }

  .sec-services .web-app-ttl {
    padding-bottom: 4.688vw;
  }

  /* mobile-app-develop
  --------------------------------------------------------- */

  .sec-services .mobile-app-cnt {
    flex-direction: column;
    gap: 0;
  }

  .sec-services .mobile-app-develop {
    padding: 8.063vw 0vw 6.594vw;
    border-bottom: 0.313vw solid #2DBB54;
  }

  .sec-services .mobile-app-develop .mobile-app-ttl {
    width: 86%;
    margin: 0vw 6.5vw;
    padding-bottom: 1.6vw;
  }

  .sec-services .mobile-app-ttl {
    padding-bottom: 1.250vw;
  }

  .sec-services .mobile-app-txt {
    width: 100%;
    padding: 3.125vw 1.5vw;
  }

  .sec-services .mobile-app-img {
    width: 51%;
    margin: 0vw 20.75vw;
  }

  /* network-server
  --------------------------------------------------------- */
  .sec-services .network-server {
    padding: 8.063vw 0vw 5.231vw;
  }

  .sec-services .network-server .network-ttl {
    width: 70%;
    margin: 0 13.9vw;
    padding-bottom: 1.531vw;
  }

  .sec-services .network-server p {
    padding: 0.4vw 12.656vw 3vw;
    font-size: 2.188vw;
    text-indent: 2vw;
  }

  .sec-services .network-server ul {
    column-count: 1;
  }

  .sec-services .network-server ul .list-gap {
    margin-left: 0;
  }

  .sec-services .network-list li {
    padding: 4.875vw 0 3.625vw 13.469vw;
    font-size: 3.5vw;
  }

  .sec-services .network-list li::before {
    top: -4%;
    left: 1%;
    width: 11.938vw;
    height: 12.938vw;
  }
}