@charset "utf-8";

/*=== こんな方におすすめのサービスです ===*/
.support-inner {
  position: relative;
  padding: 65px 40px 125px;
  background-color: #e4e9d2;
}
.support h3 {
  border-bottom: solid 2px #8bbe1f;
  text-align: center;
  padding-bottom: 10px;
}
.support-list {
  display: flex;
  justify-content: space-between;
  max-width: 880px;
  margin: 50px auto 0;
}
.support-item {
  position: relative;
  width: 245px;
  height: 150px;
  background-repeat: no-repeat;
}
.support-item:nth-child(1) {
  background-image: url("//fmv-img.static.pub/b/service/product/virusclean/features/images/hukidasi03.png");
}
.support-item:nth-child(2) {
  background-image: url("//fmv-img.static.pub/b/service/product/virusclean/features/images/hukidasi02.png");
}
.support-item:nth-child(3) {
  background-image: url("//fmv-img.static.pub/b/service/product/virusclean/features/images/hukidasi03.png");
}
.support-item p {
  position: absolute;
  top: 45%;
  left: 50%;
  width: 245px;
  text-align: center;
  transform: translateY(-50%) translateX(-50%);
}
.support-item img {
  position: absolute;
  bottom: -40px;
  left: -20px;
}
.support-txt {
  padding-bottom: 75px;
  text-align: center;
  background: url("//fmv-img.static.pub/b/service/product/virusclean/features/images/bg2.png") no-repeat center -25px;
}
.support-cont {
  display: flex;
  justify-content: center;
  gap: 20px;
}
.support-detail {
  padding: 15px 45px 25px;
  border: 4px dotted #dcdcdc;
  text-align: center;
}
.support-lead {
  display: flex;
  justify-content: center;
  gap: 30px;
  margin-bottom: 15px;
}
.support-detail p span {
  display: block;
  margin-top: 10px;
}


/*=== サービス比較 ===*/
.compare {
  text-align: center;
}
.compare h2 {
  padding-bottom: 10px;
  border-bottom: 2px solid #8bbe1f;
}
.compare-list {
  display: flex;
  justify-content: center;
  gap: 50px;
  margin-top: 40px;
}
.compare-item {
  margin: 0;
}
.compare-arrow {
  margin-top: 30px;
}
.compare-lead {
  margin: 20px 0 30px;
}
.compare-note {
  text-align: right;
  margin-top: 15px;
  padding-left: 1em;
  text-indent: -1em;
}


/*=== サービス内容 ===*/
.virusclean.service01 {
  margin-bottom: 50px;
  padding: 50px 40px;
  background-color: #f5f6f4;
}
.serviceDetail {
  margin-top: 45px;
}
li.serviceDetail-item {
  display: flex;
  align-items: center;
  margin-top: 30px;
  padding: 0 40px 40px 0;
  border: 3px solid #c5c7c4;
  background-color: #fff;
}
li.serviceDetail-item::before {
  content: none;
}
.serviceDetail-cont {
  margin-top: 15px;
  padding: 0 40px;
}
.serviceDetail-note {
  margin-top: 25px;
  padding-left: 1em;
  font-size: 16px;
  text-indent: -1em;
}
.serviceDetail-item figure {
  flex-shrink: 0;
  width: 280px;
}
.serviceDetail-anno {
  margin-top: 20px;
  padding-left: 1em;
  text-indent: -1em;
  font-size: 16px;
  text-align: right;
}


/*=== modal ===*/
.modal input[type="radio"] {
  display: none;
}
.modal-bg,
.modalPopup {
  display: none;
  opacity: 0;
}
.modal-open:checked ~ .modal-bg,
.modal-open:checked ~ .modalPopup {
  display: block;
  opacity: 1;
}

.modal-btn {
  display: inline-block;
  margin-top: 10px;
  cursor: pointer;
}
.modal-btn:hover {
  opacity: 0.8;
}
.modal-bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  z-index: 997;
}
.modalPopup {
  position: fixed;
  left: 50%;
  top: 50%;
  width: 90%;
  max-width: 700px;
  padding: 30px;
  border-radius: 10px;
  background-color: #fff;
  z-index: 998;
  transform: translate(-50%, -50%);
  animation: fadeIn 0.3s ease;
}
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
.modalPopup-close {
  display: flex;
  justify-content: center;
  position: absolute;
  top: -20px;
  right: -20px;
  width: 44px;
  height: 44px;
  padding: 6px;
  color: #fff;
  font-size: 30px;
  line-height: 1;
  background: #000;
  border-radius: 50%;
  cursor: pointer;
}
.modalPopup h4 {
  font-size: 18px;
  padding-bottom: 10px;
  border-bottom: solid 2px #8bbe1f;
  text-align: center;
}
.modalPopup ul {
  margin-top: 15px;
  font-size: 16px;
}


/*=== サービス適用条件 ===*/
.virusclean .virustable th {
  width: 220px;
}
.virusclean .virustable td {
  border-color: #fff;
  background-color: #f5f6f4;
}
.virusclean .virustable .green {
  font-weight: normal;
  text-align: center;
  background-color: #ecf5d6;
}


@media print, screen and (max-width: 767px) {
  /*=== こんな方におすすめのサービスです ===*/
  .support-inner {
    padding: 30px 15px 65px;
  }
  .support-list {
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 30px;
  }
  .support-item:not(:first-child) {
    margin-top: 50px;
  }
  .support-cont {
    display: block;
  }
  .support-detail {
    padding: 15px;
  }
  .support-detail:not(:first-child) {
    margin-top: 20px;
  }
  .support-lead {
    display: block;
    margin-bottom: 15px;
  }
  .support-lead p:not(:first-child) {
    margin-top: 10px;
  }
  /*=== サービス比較 ===*/
  .compare-list {
    gap: 10px;
    margin-top: 20px;
  }
  .compare-arrow {
    margin-top: 20px;
  }
  .compare-lead {
    margin: 10px 0 15px;
  }
  /*=== サービス内容 ===*/
  .virusclean.service01 {
    padding: 35px 15px;
  }
  .serviceDetail {
    margin-top: 30px;
  }
  li.serviceDetail-item {
    display: block;
    margin-top: 15px;
    padding: 0 15px 20px 0;
    border-width: 1px;
  }
  .serviceDetail-cont {
    margin-top: 15px;
    padding: 0 0 0 15px;
  }
  .serviceDetail-note {
    margin-top: 15px;
    font-size: 14px;
  }
  .serviceDetail-item figure {
    max-width: 280px;
    margin: 20px auto 0;
    padding-left: 15px;
  }
  .serviceDetail-anno {
    font-size: 14px;
  }
  /*=== modal ===*/
  .modalPopup {
    padding: 30px 15px;
  }
  .modalPopup ul {
    font-size: 14px;
  }
  /*=== サービス適用条件 ===*/
  .virusclean .virustable th {
    width: 10%;
  }
}