@charset "utf-8";

/*=== メインエリア ===*/
.main-cpWrap {
  letter-spacing: 0.05rem;
}
.main-cpWrap .main-section {
  background: url(../images/sec_bg_001.png) no-repeat top center / 100% auto;
}
.main-cpWrap .main-ttl {
  display: block;
  padding-bottom: 30px;
  color: #39507e;
}
.main-cpWrap .main-ttl::after {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 140px;
  height: 4px;
  border-radius: 10px;
  background: rgb(128, 161, 227);
  background: linear-gradient(90deg, rgba(128, 161, 227, 1) 0%, rgba(169, 192, 236, 1) 100%);
  transform: translateX(-50%);
}
.main-ttl .type-slash {
  display: inline-block;
  position: relative;
  padding: 0 50px;
}
.main-ttl .type-slash::before,
.main-ttl .type-slash::after {
  content: "";
  display: inline-block;
  position: absolute;
  bottom: -3px;
  left: 12px;
  width: 2px;
  height: 100%;
  background-color: #39507e;
  border-radius: 3px;
  transform: rotate(-30deg);
}
.main-ttl .type-slash::after {
  left: auto;
  right: 12px;
  transform: rotate(30deg);
}
.main-ttl .type-small {
  padding: 0 4px;
  font-size: 26px;
}
.main-cpWrap .main-subttl {
  color: #39507e;
  font-size: 24px;
  text-align: center;
}


/*=== メインビジュアル ===*/
.mainvisual {
  background: rgb(10, 81, 197);
  background: linear-gradient(150deg, rgba(10, 81, 197, 1) 0%, rgba(6, 115, 216, 1) 50%, rgba(0, 170, 247, 1) 100%);
}
.mainvisual-sub {
  background-color: #fae20f;
}
.mainvisual-txt {
  padding-left: 40px;
  font-size: 23px;
}
.mainvisual-txt::before {
  content: "";
  display: inline-block;
  position: absolute;
  top: 9px;
  left: 0;
  width: 31px;
  height: 27px;
  background: url(../images/mv_ic_001.png) no-repeat top center / 100% auto;
}
.mainvisual-txt .type-em {
  font-size: 25px;
}


/*=== ナビゲーション ===*/
.cpNav {
  position: relative;
  background: rgb(77, 115, 219);
  background: linear-gradient(90deg, rgba(77, 115, 219, 1) 0%, rgba(117, 163, 231, 1) 80%);
  box-shadow: 0 5px 5px rgba(0, 0, 0, 0.3);
  z-index: 10;
}
.cpNav-inner {
  display: flex;
  justify-content: center;
  max-width: 1160px;
  min-height: 80px;
  margin: 0 auto;
  line-height: 1.2;
}
.cpNav-list {
  display: flex;
  width: calc((100% / 4) * 3);
}
.cpNav-item:first-of-type {
  width: 100%;
}
.cpNav-item {
  width: 60%;
}
a.cpNav-link {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 100%;
  height: 100%;
  color: #fff;
  font-weight: bold;
  font-size: 20px;
  text-align: center;
  text-decoration: none;
  background-repeat: no-repeat;
  background-position: bottom 0 right 10px;
}
a.cpNav-link.pattern-setup {
  background-image: url(../images/nav_ic_001.png);
}
a.cpNav-link.pattern-advantage {
  background-image: url(../images/nav_ic_003.png);
}
a.cpNav-link.pattern-voice {
  background-image: url(../images/nav_ic_007.png);
  background-position: bottom right;
}
a.cpNav-link:visited {
  color: #fff;
}
a.cpNav-link:hover {
  background-color: rgba(255, 255, 255, 0.3);
}
a.cpNav-link::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -1px;
  width: 2px;
  height: 24px;
  background-color: #acc0ef;
  transform: translateY(-50%);
}
.cpNav-item:first-child a.cpNav-link::before {
  content: none;
}
.cpNav-label {
  max-width: 220px;
  margin: 0 auto 6px;
}
.cpNav-main {
  position: relative;
  top: -13px;
  text-shadow: 2px 2px 0 #567ede, -2px -2px 0 #567ede, -2px 2px 0 #567ede, 2px -2px 0 #567ede, 0 2px 0 #567ede, 0 -2px 0 #567ede, -2px 0 0 #567ede, 2px 0 0 #567ede;
}
a.cpNav-applyBtn {
  background-color: #ef8131;
}
@media print, screen and (min-width: 769px) {
  .cpNav-apply {
    position: static;
    width: calc((100% / 4));
  }
  a.cpNav-applyBtn {
    min-height: auto;
    padding: 4px 10px 0;
    font-size: 20px;
  }
  a.cpNav-applyBtn:hover {
    color: #ef8131;
  }
}


/*=== お申し込み ===*/
.apply {
  background-color: #f8f5e7;
}
.apply .main-section {
  background: none;
}
.main-cpWrap .apply .main-ttl {
  padding-bottom: 0;
}
.apply .main-ttl::after {
  content: none;
}
.apply-wrap {
  display: flex;
  justify-content: space-between;
  margin-top: 40px;
  line-height: 1.4;
}
.apply-sec {
  width: calc((100% - 40px) / 2);
}
.apply-subttl {
  font-weight: bold;
  font-size: 26px;
  text-align: center;
}
.apply-subttl .type-accent {
  padding: 0 5px;
  color: #c40a0a;
  font-size: 28px;
}
.apply-cont {
  margin-top: 20px;
  padding: 20px 20px 35px;
  text-align: center;
  background-color: #fff;
  border-radius: 10px;
}
.apply-cont + .apply-cont {
  margin-top: 10px;
}
.apply-lead {
  font-weight: bold;
  font-size: 22px;
}
.apply-lead .type-thin {
  font-weight: normal;
}
.apply-txt {
  margin-top: 10px;
  font-size: 18px;
}
.apply-transition {
  max-width: 460px;
  margin: 20px auto 0;
}
.apply-transition.type-webmart {
  max-width: 500px;
  margin-top: 10px;
}
a.apply-webmart {
  display: block;
  position: relative;
  padding: 20px 50px;
  border: 1px solid #232b35;
  font-weight: bold;
  font-size: 22px;
  text-decoration: none;
  border-radius: 10px;
}
a.apply-webmart:hover {
  background-color: #ededed;
  mix-blend-mode: multiply;
}
a.apply-webmart::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 20px;
  height: 40px;
  background-color: #232b35;
  clip-path: polygon(0 0, 0 100%, 100% 50%);
  transform: translateY(-50%);
}
.apply-logo {
  display: block;
  width: 267px;
  margin: 5px auto 0;
}
.apply-thumb {
  margin-top: 30px;
}
.apply-column {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 15px;
}
.apply-tel {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  position: relative;
  top: 2px;
  width: 45px;
  height: 45px;
  margin-right: 10px;
  background-color: #1c3583;
  border-radius: 100%;
}
.apply-tel .commonIcon-tel {
  width: 22px;
  height: 24px;
}
.apply-number {
  font-weight: bold;
  font-size: 55px;
  line-height: 1;
  white-space: nowrap;
}
.apply-detail {
  margin-top: 15px;
  padding: 10px 20px;
  background-color: #f0f5f7;
}
.apply-link {
  position: relative;
  margin-top: 2px;
  padding-right: 30px;
  border: none;
  color: #c40a0a;
  text-decoration: underline;
  background: none;
  cursor: pointer;
}
.apply-link:hover {
  text-decoration: none;
}
.apply-link::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 8px;
  right: 3px;
  width: 19px;
  height: 17px;
  background: url(../images/apply_ic_001.png) no-repeat top center / 100% auto;
}
a.apply-btn {
  display: flex;
  align-items: center;
  position: relative;
  width: 100%;
  min-height: 58px;
  padding: 5px 45px 5px 20px;
  color: #fff;
  font-weight: bold;
  font-size: 24px;
  line-height: 1.2;
  text-decoration: none;
  background-color: #c40a0a;
  border-radius: 50px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}
a.apply-btn:visited {
  color: #fff;
}
a.apply-btn:hover {
  opacity: 0.7;
}
a.apply-btn::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 15px;
  height: 20px;
  background-color: #fff;
  clip-path: polygon(0 0, 0 100%, 100% 50%);
  transform: translateY(-50%);
}
.apply-btn_icon {
  flex-shrink: 0;
  margin-right: 10px;
}
.apply-btn_txt {
  width: 100%;
  text-align: center;
}
@media print, screen and (max-width: 1200px) {
  a.apply-webmart {
    padding: 1.667vw 4.167vw;
    font-size: 1.833vw;
  }
  a.apply-webmart::after {
    right: 1.667vw;
    width: 1.667vw;
    height: 3.333vw;
  }
  .apply-logo {
    width: 22.25vw;
  }
  .apply-tel {
    top: 0.167vw;
    width: 3.75vw;
    height: 3.75vw;
    margin-right: 0.833vw;
  }
  .apply-tel .commonIcon-tel {
    width: 1.833vw;
    height: 2vw;
  }
  .apply-number {
    font-size: 4.583vw;
  }
}


/*=== 導入部分 ===*/
.about {
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), #f7f7f7 calc(100% - 1px)),linear-gradient(90deg, transparent calc(100% - 1px), #f7f7f7 calc(100% - 1px));
  background-size: 15px 15px;
  background-repeat: repeat;
  background-position: center center;
  background-color: #fff;
}


/*=== プレミアム紹介 ===*/
.premium {
  position: relative;
  max-width: 860px;
  margin: 40px auto 0;
  padding: 20px 20px 15px;
  border: 4px solid #cea35d;
  color: #7c5c28;
  text-align: center;
  background-color: #fffdf1;
}
.premium::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: -30px;
  left: -30px;
  width: 82px;
  height: 82px;
  background: url(../images/premium_ic_001.png) no-repeat top center / 100% auto;
}
.premium-lead {
  font-weight: bold;
  font-size: 26px;
  line-height: 1.4;
}
.premium-lead .type-small {
  font-size: 14px;
}
.premium-lead .type-em {
  font-size: 45px;
  line-height: 1;
}
.premium-lead .type-highlight {
  color: #c40a0a;
  font-size: 30px;
}
.premium-note {
  margin-top: 10px;
  padding-left: calc(20px + 2.6em);
  text-align: left;
  text-indent: -2.6em;
}


/*=== セットアップパック紹介 ===*/
.setup {
  margin-top: 100px;
}
.setup-box {
  display: flex;
  justify-content: space-between;
}
.setup-sec {
  position: relative;
  width: calc((100% - 16px) / 2);
  padding: 30px 20px;
  border: 6px solid #eaeaea;
  line-height: 1.4;
  background-color: #f8f9fa;
  border-radius: 10px;
}
.setup-sec.pattern-win10 {
  border-color: #e7b662;
  background-color: #fff;
}
.setup-sec::before {
  content: "";
  display: inline-block;
  position: absolute;
  top: -30px;
  left: 50%;
  width: 156px;
  height: 112px;
  background: url(../images/setup_ic_001.png) no-repeat top center / 100% auto;
  transform: translate(-50%, -50%);
}
.setup-sec.pattern-win10::before {
  background-image: url(../images/setup_ic_002.png);
}
.setup .main-subttl {
  color: #47352a;
}
.pattern-win10 .main-subttl::before {
  content: "";
  display: inline-block;
  position: absolute;
  top: -40px;
  left: -23px;
  width: 90px;
  height: 55px;
  background: url(../images/setup_ic_003.png) no-repeat top center / 100% auto;
}
.setup-lead {
  margin-top: 10px;
  text-align: center;
}
.setup-main {
  display: flex;
  justify-content: space-around;
  align-items: flex-end;
  padding: 10px 0;
  border-bottom: 4px dotted #e5e9f2;
  font-size: 20px;
  text-align: center;
}
.setup-nomal {
  position: relative;
  padding-right: 30px;
  color: #334364;
  line-height: 1.4;
}
.setup-nomal::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  width: 15px;
  height: 20px;
  background-color: #334364;
  clip-path: polygon(0 0, 0 100%, 100% 50%);
  transform: translateY(-50%);
}
.setup-special {
  color: #c40a0a;
  line-height: 1.1;
}
.setup-price {
  font-weight: bold;
  line-height: 1;
}
.setup-price .type-em {
  font-size: 25px;
}
.setup-special .type-em {
  font-size: 70px;
}
@media print, screen and (max-width: 950px) {
  .setup-special .type-em {
    font-size: 40px;
  }
}
.setup-special .type-small {
  font-size: 32px;
}
.setup-detail {
  display: flex;
  justify-content: space-between;
}
.setup-list {
  width: calc((100% - 15px) / 2);
  font-size: 18px;
}
.setup-list.type-accent {
  width: 100%;
  color: #c40a0a;
  font-weight: bold;
  font-size: 20px;
}
.setup-item {
  position: relative;
  margin-top: 20px;
  padding-left: 1em;
}
.setup-item::before {
  content: "・";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  font-size: 18px;
}
.setup-item .type-sup {
  display: inline-block;
  position: relative;
  top: 2px;
  font-size: 12px;
  vertical-align: super;
}
.setup-note {
  margin-top: 10px;
  padding-left: 1em;
  font-size: 15px;
  text-indent: -1em;
}
.pattern-win10 .setup-note {
  margin-top: 20px;
  color: #c40a0a;
}


/*=== おすすめポイント ===*/
.point {
  position: relative;
  margin-top: 10px;
  padding: 20px;
  border: 6px solid #e7b662;
  background-color: #fff;
  border-radius: 10px;
}
.point::before {
  content: "";
  display: block;
  position: absolute;
  top: -27px;
  right: calc((((100% - 16px) / 2) - 60px) / 2);
  width: 60px;
  height: 27px;
  background: #e7b662;
  clip-path: polygon(0 100%, 50% 0, 100% 100%);
}
.point-ttl {
  font-weight: bold;
  font-size: 24px;
  text-align: center;
}
.point-ttl .type-highlight {
  color: #e85d00;
}
.point-list {
  display: flex;
  justify-content: space-between;
}
.point-item {
  width: calc((100% - (20px * 2)) / 3);
  text-align: center;
}
.point-lead {
  border-bottom: 2px solid #e85d00;
  font-weight: bold;
  font-size: 20px;
  text-align: left;
}
.point-txt {
  margin-top: 10px;
}
.point-txt .type-accent {
  color: #e85d00;
  font-weight: bold;
  font-size: 22px;
}
.point-txt .type-em {
  font-size: 22px;
}


/*=== オプションメニュー例 ===*/
.option {
  position: relative;
  margin-top: 40px;
}
.option-btn {
  appearance: none;
  display: block;
  position: relative;
  width: 100%;
  padding: 10px;
  border: none;
  color: #fff;
  font-weight: bold;
  font-size: 24px;
  background-color: #647aa7;
  border-radius: 40px;
  cursor: pointer;
}
.option-btn::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  width: 20px;
  height: 15px;
  background-color: #fff;
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
  transform: translateY(-50%);
}
.option.is-AcorShow .option-btn::after {
  clip-path: polygon(0 100%, 50% 0, 100% 100%);
}
.option-wrap {
  position: relative;
  top: 30px;
  margin-bottom: 30px;
}
.option-container {
  padding: 20px 20px 35px;
  border: 2px solid #a9b7d4;
  background-color: #fff;
  border-radius: 10px;
}
.option-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.option-item {
  position: relative;
  width: calc((100% - 20px) / 2);
  padding: 20px;
  color: #39507e;
  background-color: #f3f6fb;
  border-radius: 10px;
}
@media print, screen and (min-width: 951px) {
  .option-item:not(:nth-child(-n+2)) {
    margin-top: 20px;
  }
}
@media print, screen and (max-width: 950px) {
  .option-item {
    width: 100%;
  }
  .option-item:not(:first-child) {
    margin-top: 10px;
  }
}
.option-detail {
  display: flex;
  justify-content: space-between;
  line-height: 1.4;
  background-color: #647aa7;
}
.option-lead {
  padding: 10px 15px;
  color: #fff;
  font-weight: bold;
  font-size: 18px;
}
.option-lead .type-sup {
  display: inline-block;
  position: relative;
  top: 2px;
  font-weight: normal;
  font-size: 12px;
  vertical-align: super;
}
.option-lead .type-small {
  font-size: 16px;
}
.option-label {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  padding-right: 10px;
  border: 1px solid #39507e;
  color: #39507e;
  line-height: 1;
  white-space: nowrap;
  background-color: #fff;
}
.option-label::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 60px;
  width: 40px;
  height: 100%;
  background-color: #e8eef8;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}
.option-label_txt {
  display: flex;
  align-items: center;
  position: relative;
  width: 80px;
  height: 100%;
  margin-right: 20px;
  padding: 5px 0 5px 10px;
  background-color: #e8eef8;
  z-index: 1;
}
.option-label_price {
  display: flex;
  align-items: center;
  height: 100%;
  z-index: 1;
}
.option-cont {
  display: flex;
  margin-top: 20px;
}
.option-thumb {
  flex-shrink: 0;
  margin-right: 30px;
}


/*=== ここが違う ===*/
.advantage {
  background-color: #edf3ff;
}
.advantage-list {
  display: flex;
  justify-content: space-between;
  margin-top: 60px;
}
.advantage-item {
  width: calc((100% - (14px * 3)) / 4);
  border: 2px solid #d4ddea;
  background-color: #fff;
  border-radius: 10px;
  overflow: hidden;
}
.advantage-thumb {
  text-align: center;
}
.advantage-lead {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 5px;
  color: #fff;
  font-weight: bold;
  font-size: 18px;
  text-align: center;
  line-height: 1.3;
  background-color: #39507e;
}
.advantage-cont {
  padding: 15px;
}


/*=== お客様の声 ===*/
.voice-list {
  display: flex;
  justify-content: space-between;
  margin-top: 100px;
}
.voice-item {
  position: relative;
  width: calc((100% - (6px * 2)) / 3);
  filter: drop-shadow(4px 4px 6px rgba(205, 184, 170, 0.1));
}
.voice-cont {
  position: relative;
  width: 100%;
  height: 100%;
  padding: 50px 20px 30px;
  border: 2px solid #f6be96;
  border-radius: 10px;
}
.voice-cont::before {
  content: "";
  display: block;
  position: absolute;
  bottom: -14px;
  left: 50%;
  width: 30px;
  height: 30px;
  border: 2px solid #f6be96;
  background-color: #fff;
  transform: translateX(-50%) rotate(45deg) skew(12deg, 12deg);
}
@media print, screen and (min-width: 769px) {
  .voice-item:nth-child(1) .voice-cont::before {
    bottom: -10px;
    width: 55px;
    height: 25px;
    transform: translateX(-50%) rotate(45deg) skew(45deg, -5deg);
  }
  .voice-item:nth-child(3) .voice-cont::before {
    bottom: -17px;
    width: 35px;
    height: 40px;
    transform: translateX(-50%) rotate(-85deg) skew(45deg, -5deg);
  }
}
.voice-cont::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../images/voice_bg_001.png) no-repeat bottom left;
  background-color: #fff;
  border-radius: 10px;
}
.voice-item:nth-child(2) .voice-cont::after {
  background-image: url(../images/voice_bg_002.png);
}
.voice-item:nth-child(3) .voice-cont::after {
  background-image: url(../images/voice_bg_003.png);
}
@media print, screen and (max-width: 940px) {
  .voice-cont::after {
    background-size: contain;
  }
}
.voice-name {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  position: absolute;
  top: -70px;
  left: 52%;
  width: 100%;
  transform: translateX(-50%);
  z-index: 1;
}
.voice-label {
  flex-shrink: 0;
  position: relative;
  left: -15px;
  bottom: 22px;
  padding: 0 20px;
  color: #fff;
  font-weight: bold;
  font-size: 18px;
  text-align: center;
  background-color: #e85d00;
  border-radius: 100vh;
}
.voice-txt {
  position: relative;
  font-size: 18px;
  z-index: 1;
}
.voice-txt .type-accent {
  color: #e85d00;
  font-weight: bold;
  font-size: 28px;
  line-height: 1.3;
}
.voice-satisfaction {
  margin-top: 15px;
  padding: 30px 20px 20px;
}


/*=== お申込み方法 ===*/
.howto-switch {
  margin-top: 40px;
}
.control {
  display: flex;
  justify-content: space-between;
}
.control-item {
  width: calc((100% - 20px) / 2);
}
.control-btn {
  appearance: none;
  display: block;
  width: 100%;
  padding: 14px 0 12px;
  border: 2px solid #2d7b94;
  border-bottom: none;
  color: #fff;
  font-weight: bold;
  font-size: 24px;
  background-color: #2d7b94;
  border-radius: 10px 10px 0 0;
  cursor: pointer;
  transition: all .2s ease-out 0s;
}
.control-btn:hover {
  background-color: #6ba1b1;
}
.control-btn.pattern-have {
  border-color: #e76a05;
  background-color: #e76a05;
}
.control-btn.pattern-have :hover {
  background-color: #e59b5d;
}
.control-btn.is-active {
  height: calc(100% + 2px);
  color: #2d7b94;
  background-color: #ebf3f6;
  pointer-events: none;
}
.control-btn.pattern-have.is-active {
  color: #e76a05;
  background-color: #faf4ef;
}
.howto-wrap {
  border: 2px solid #2d7b94;
  line-height: 1.4;
  background-color: #ebf3f6;
  border-radius: 0 0 10px 10px;
}
.howto-step {
  padding: 50px 30px 30px;
}
.howto-list {
  display: flex;
  justify-content: space-between;
}
.howto-item {
  width: calc((100% - (30px * 2)) / 3);
}
.howto-detail {
  position: relative;
  border: 2px solid #2d7b94;
  background-color: #fff;
  border-radius: 10px;
}
.howto-item:not(:last-child) .howto-detail::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: -20px;
  width: 13px;
  height: 13px;
  border-top: 3px solid #2d7b94;
  border-right: 3px solid #2d7b94;
  transform: translateY(-50%) rotate(45deg);
}
.howto-lead {
  position: relative;
  padding: 8px 20px 14px 55px;
  color: #fff;
  font-weight: bold;
  font-size: 22px;
  background-color: #2d7b94;
  border-radius: 7px 7px 0 0;
}
.howto-icon {
  display: block;
  position: absolute;
  top: -20px;
  left: -20px;
  width: 66px;
  border: 2px solid #ebf3f6;
  background-color: #2d7b94;
  border-radius: 50%;
}
.pattern-purchase .howto-item:nth-child(1) .howto-thumb {
  border-radius: 0 0 7px 7px;
  overflow: hidden;
}
.howto-cont {
  display: flex;
  justify-content: center;
  position: relative;
}
.howto-caption {
  padding: 15px 20px;
  color: #195f76;
  font-size: 15px;
}
.howto-ribbon {
  display: inline-block;
  position: absolute;
  top: -20px;
  left: 0;
  width: 98px;
  height: 26px;
  padding: 4px 0;
  color: #fff;
  font-weight: bold;
  text-align: center;
  line-height: 1;
  background-color: #647aa7;
}
.howto-ribbon::after {
  content: "";
  position: absolute;
  top: 0;
  right: -11px;
  width: 11px;
  height: 26px;
  background: url(../images/howto_bg_001.png) no-repeat top left / auto 100%;
  z-index: 1;
}
.howto-label {
  display: inline-block;
  padding: 2px 10px 4px;
  color: #39507e;
  font-size: 14px;
  line-height: 1;
  background-color: #e8eef8;
}
.howto-txt {
  margin-top: 15px;
  padding: 0 15px;
  font-size: 18px;
  line-height: 1.6;
}
.howto-txt .type-sup {
  display: inline-block;
  position: relative;
  top: 2px;
  font-size: 12px;
  vertical-align: super;
}
.howto-txt .type-em {
  font-weight: bold;
}
.howto-txt a, .howto-txt a:visited {
  color: #c40a0a;
  font-weight: bold;
}
.howto-overview {
  padding: 20px 30px;
  background-color: #e0e8eb;
  border-radius: 0 0 8px 8px;
}
.howto-note {
  padding-left: 1em;
  font-size: 14px;
  text-indent: -1em;
}
.howto-note + .howto-note {
  margin-top: 5px;
}
.howto-note .type-highlight {
  color: #e85d00;
  font-weight: bold;
}
.howto-note .type-em {
  font-weight: bold;
}
.howto-transition {
  max-width: 460px;
  margin: 35px auto 0;
}
a.howto-btn {
  display: flex;
  align-items: center;
  position: relative;
  width: 100%;
  min-height: 58px;
  padding: 5px 45px 5px 20px;
  color: #fff;
  font-weight: bold;
  font-size: 24px;
  line-height: 1.2;
  text-decoration: none;
  background-color: #c40a0a;
  border-radius: 50px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}
a.howto-btn:visited {
  color: #fff;
}
a.howto-btn:hover {
  text-decoration: none;
  opacity: 0.7;
}
a.howto-btn::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 15px;
  height: 20px;
  background-color: #fff;
  clip-path: polygon(0 0, 0 100%, 100% 50%);
  transform: translateY(-50%);
}
.howto-btn_icon {
  flex-shrink: 0;
  margin-right: 10px;
}
.howto-btn_txt {
  width: 100%;
  text-align: center;
}
/*=== パソコンをお持ちの方 ===*/
.howto-wrap.pattern-have {
  border-color: #e85d00;
  background-color: #faf4ef;
}
.pattern-have .howto-step {
  padding-top: 30px;
}
.howto-ttl {
  display: inline-block;
  padding: 4px 30px 6px;
  color: #fff;
  font-weight: bold;
  font-size: 24px;
  background-color: #e85d00;
}
.pattern-have .howto-list {
  margin-top: 50px;
}
.pattern-have .howto-detail {
  border-color: #e85d00;
}
.pattern-have .howto-item:not(:last-child) .howto-detail::after {
  border-color: #e85d00;
}
.pattern-have .howto-icon {
  top: -30px;
  border-color: #faf4ef;
  background-color: #e85d00;
}
.pattern-have .howto-thumb {
  border-radius: 10px;
  overflow: hidden;
}
.pattern-have .howto-note {
  margin-top: 30px;
  font-size: 16px;
}
.pattern-have .howto-note + .howto-note {
  margin-top: 15px;
}
/*=== 電話からのお申込み方法 ===*/
.telApply {
  display: flex;
  padding: 22px 40px;
  background-color: #fff;
  border-radius: 0 0 8px 8px;
}
.telApply-head {
  flex-grow: 1;
}
.telApply .howto-ttl {
  background-color: #1c3583;
}
.telApply-main {
  margin-top: 15px;
  font-size: 16px;
  line-height: 1.2;
}
.telApply-cont {
  display: flex;
  flex-grow: 1;
}
.telApply-reception {
  margin-left: 30px;
}
.telApply-ttl {
  display: inline-block;
  padding: 1px 10px 2px;
  color: #fff;
  font-size: 15px;
  background-color: #1c3583;
}
.telApply-number a {
  font-weight: bold;
  font-size: 55px;
  line-height: 1;
}
@media print, screen and (max-width: 1200px) {
  .telApply-number a {
    font-size: 4.583vw;
  }
}
.telApply-item {
  display: flex;
}
@media print, screen and (min-width: 769px) {
  .telApply-item:last-child {
    margin-top: 3px;
  }
}
.telApply-item {
  margin-top: 20px;
}
.telApply-time {
  padding: 2px 20px;
  color: #334364;
  background-color: #f0f5f7;
}


/*=== セットアップメニュー一覧の注記 ===*/
.main-cpWrap .overview .main-section {
  background: none;
}
.note {
  margin-top: 30px;
  padding: 30px 20px;
  background-color: #f0f4f7;
  border-radius: 10px;
}


@media print, screen and (max-width: 768px) {
  /*=== メインエリア ===*/
  .main-cpWrap {
    letter-spacing: 0;
  }
  .main-cpWrap .main-section {
    background: url(../images/sec_bg_002.png) no-repeat top 15px center / 100% auto;
  }
  .main-cpWrap .main-ttl {
    padding-bottom: 15px;
    letter-spacing: 0;
  }
  .main-cpWrap .main-ttl::after {
    width: 80px;
  }
  .main-ttl .type-slash {
    padding: 0 25px;
  }
  .main-ttl .type-slash::before {
    left: 7px;
  }
  .main-ttl .type-slash::after {
    right: 7px;
  }
  .main-ttl .type-small {
    font-size: 16px;
  }
  .main-cpWrap .main-subttl {
    font-size: 18px;
  }
  /*=== ナビゲーション ===*/
  .cpNav {
    box-shadow: 0 -4px 5px 0 rgba(0, 0, 0, 0.2);
  }
  .cpNav-inner {
    display: block;
    min-height: auto;
  }
  .cpNav-list {
    width: 100%;
    padding: 4px 7px;
  }
  .cpNav-item {
    margin: 0 3px;
  }
  .cpNav-item:nth-child(1) {
    width: 40%;
  }
  .cpNav-item:nth-child(2) {
    width: 33%;
  }
  .cpNav-item:nth-child(3) {
    width: 27%;
  }
  a.cpNav-link {
    min-height: 50px;
    padding: 2px 0;
    font-size: 14px;
    line-height: 1.1;
    background-color: rgba(255, 255, 255, 0.2);
    border-radius: 5px;
    background-position: bottom right;
  }
  a.cpNav-link.pattern-setup {
    background-image: url(../images/nav_ic_002.png);
    background-size: 26px 33px;
  }
  a.cpNav-link.pattern-advantage {
    background-image: url(../images/nav_ic_004.png);
    background-size: 43px 42px;
  }
  a.cpNav-link.pattern-voice {
    background-image: url(../images/nav_ic_008.png);
    background-size: 43px 32px;
  }
  a.cpNav-link::before {
    content: none;
  }
  .cpNav-label {
    position: absolute;
    top: -9px;
    left: 50%;
    width: 100%;
    max-width: 136px;
    transform: translateX(-50%);
  }
  .cpNav-label + .cpNav-main {
    top: 0;
    text-shadow: 1px 1px 0 #799ae5, -1px -1px 0 #799ae5, -1px 1px 0 #799ae5, 1px -1px 0 #799ae5, 0 1px 0 #799ae5, 0 -1px 0 #799ae5, -1px 0 0 #799ae5, 1px 0 0 #799ae5;
  }
  .cpNav-txt {
    font-size: 13px;
  }
  .cpNav-txt::before, .cpNav-txt::after {
    width: 1px;
    height: 12px;
  }
  .cpNav-txt::before {
    left: -8px;
  }
  .cpNav-txt::after {
    right: -8px;
  }
  /*=== お申し込み ===*/
  .apply .main-section {
    background: none;
  }
  .apply-wrap {
    display: block;
    margin-top: 30px;
  }
  .apply-sec {
    width: 100%;
    margin-top: 30px;
  }
  .apply-subttl {
    font-size: 22px;
  }
  .apply-subttl .type-accent {
    font-size: 24px;
  }
  .apply-cont {
    margin-top: 10px;
    padding: 20px 10px 30px;
  }
  .apply-lead {
    font-size: 20px;
  }
  .apply-lead .type-thin {
    font-size: 16px;
  }
  .apply-txt {
    margin-top: 0;
    font-size: 15px;
  }
  .apply-transition {
    max-width: 550px;
  }
  a.apply-webmart {
    padding: 15px 20px;
    font-size: 20px;
  }
  a.apply-webmart::after {
    right: 10px;
    width: 15px;
    height: 30px;
  }
  .apply-logo {
    width: 225px;
    margin-top: 10px;
  }
  .apply-tel {
    top: 2px;
    width: 30px;
    height: 30px;
    margin-right: 10px;
  }
  .apply-tel .commonIcon-tel {
    width: 16px;
    height: 18px;
  }
  .apply-number {
    font-size: 37px;
  }
  .apply-detail {
    padding: 5px 10px;
    font-size: 16px;
  }
  .apply-link {
    margin-top: 5px;
    padding-right: 30px;
    font-size: 16px;
  }
  .apply-link::after {
    top: 5px;
  }
  a.apply-btn {
    min-height: 48px;
    padding: 5px 35px 5px 10px;
    font-size: 18px;
  }
  .pattern-tel a.apply-btn {
    padding-left: 20px;
    background-color: #1c3583;
  }
  a.apply-btn::after {
    right: 15px;
    width: 10px;
    height: 15px;
  }
  .apply-btn_icon {
    width: 22px;
    height: 22px;
    margin-right: 5px;
  }
  /*=== プレミアム紹介 ===*/
  .premium {
    margin-top: 30px;
  }
  .premium::after {
    top: -25px;
    left: -10px;
    width: 50px;
    height: 50px;
  }
  .premium-lead {
    font-size: 20px;
  }
  .premium-lead .type-small {
    font-size: 12px;
  }
  .premium-lead .type-em {
    font-size: 40px;
  }
  .premium-lead .type-highlight {
    font-size: 24px;
  }
  .premium-note {
    padding-left: 2.6em;
  }
  /*=== セットアップパック紹介 ===*/
  .setup {
    margin-top: 30px;
  }
  .setup-box {
    display: block;
  }
  .setup-sec {
    width: 100%;
    margin-top: 80px;
    padding: 30px 15px 20px;
    border-width: 3px;
  }
  .setup-sec::before {
    top: -20px;
    width: 120px;
    height: 86px;
  }
  .pattern-win10 .main-subttl::before {
    top: -50px;
    width: 80px;
    height: 50px;
  }
  .setup-main {
    justify-content: center;
    font-size: 16px;
  }
  .setup-nomal {
    margin-right: 15px;
  }
  .setup-nomal::after {
    width: 10px;
    height: 15px;
  }
  .setup-price .type-em {
    /* font-size: 25px; */
    font-size: 6.667vw;
  }
  .setup-special .type-em {
    /* font-size: 40px; */
    font-size: 10.667vw;
  }
  .setup-special .type-small {
    /* font-size: 32px; */
    font-size: 8.533vw;
  }
  .setup-detail {
    display: block;
  }
  .setup-list {
    width: 100%;
    font-size: 16px;
  }
  .setup-list.type-accent {
    font-size: 18px;
  }
  .setup-item {
    margin-top: 15px;
  }
  .setup-item::before {
    font-size: 16px;
  }
  .setup-item .type-sup {
    padding: 0 2px;
    font-size: 11px;
  }
  .setup-note {
    padding-left: calc(1em + 10px);
    font-size: 14px;
  }
  /*=== おすすめポイント ===*/
  .point {
    margin-top: 40px;
    padding: 20px 15px;
    border-width: 3px;
  }
  .point::before {
    right: calc((100% - 60px) / 2);
  }
  .point-ttl {
    font-size: 18px;
  }
  .point-list {
    display: block;
    max-width: 400px;
    margin: 0 auto;
  }
  .point-item {
    width: 100%;
  }
  .point-item:not(:first-child) {
    margin-top: 15px;
  }
  .point-lead {
    font-size: 18px;
  }
  .point-txt .type-accent {
    font-size: 20px;
  }
  .point-txt .type-em {
    font-size: 20px;
  }
  /*=== オプションメニュー例 ===*/
  .option-btn {
    padding: 10px;
    font-size: 18px;
  }
  .option-btn::after {
    right: 15px;
    width: 15px;
    height: 10px;
  }
  .option-wrap {
    top: 15px;
    margin-bottom: 15px;
  }
  .option-container {
    padding: 20px 10px;
  }
  .option-list {
    display: block;
  }
  .option-item {
    width: 100%;
    padding: 10px;
  }
  .option-lead {
    padding: 5px 0 5px 5px;
    font-size: 14px;
  }
  .option-lead .type-sup {
    padding: 0 2px;
    font-size: 10px;
  }
  .option-lead .type-small {
    font-size: 13px;
  }
  .option-label {
    padding-right: 5px;
  }
  .option-label::after {
    left: 55px;
    width: 20px;
  }
  .option-label_txt {
    width: 65px;
    margin-right: 10px;
    padding-left: 5px;
  }
  .option-label_txt::after {
    right: -15px;
    border-width: 28px 15px 0 0;
  }
  .option-cont {
    margin-top: 10px;
  }
  .option-thumb {
    max-width: 75px;
    margin-right: 20px;
  }
  /*=== ここが違う ===*/
  .advantage-list {
    display: block;
    margin-top: 30px;
  }
  .advantage-item {
    display: flex;
    width: 100%;
    padding: 10px 10px 15px;
  }
  .advantage-item:not(:first-child) {
    margin-top: 10px;
  }
  .advantage-thumb {
    flex-shrink: 0;
    width: 138px;
    margin-right: 10px;
  }
  .advantage-detail {
    width: 100%;
  }
  .advantage-lead {
    padding: 10px;
    font-size: 16px;
  }
  .advantage-cont {
    margin-top: 10px;
    padding: 0;
  }
  /*=== お客様の声 ===*/
  .voice-list {
    display: block;
    margin-top: 30px;
  }
  .voice-item {
    display: flex;
    width: 100%;
    filter: none;
  }
  .voice-item:not(:first-child) {
    margin-top: 20px;
  }
  .voice-cont {
    padding: 20px 15px 25px;
    border-width: 1px;
  }
  .voice-cont::before {
    top: 42px;
    bottom: auto;
    left: -4px;
    width: 20px;
    height: 20px;
    border-width: 1px;
    transform: rotate(135deg) skew(20deg, 20deg);
  }
  .voice-cont::after {
    background-position: bottom right;
    background-size: 158px 26px;
  }
  .voice-name {
    display: block;
    flex-shrink: 0;
    position: static;
    width: 89px;
    margin-right: 15px;
    transform: none;
  }
  .voice-label {
    left: 0;
    bottom: 10px;
    padding: 2px 0;
    font-size: 16px;
  }
  .voice-txt {
    font-size: 16px;
  }
  .voice-txt .type-accent {
    font-size: 20px;
  }
  .voice-satisfaction {
    margin-top: 20px;
    padding: 30px 15px 15px;
    box-shadow: 5px 5px 4px 0 rgba(176, 159, 146, 0.2);
  }
  .voice-inner {
    max-width: 400px;
    margin: 0 auto;
  }
  .voice-note {
    margin-top: 15px;
    padding-left: 25px;
    font-size: 13px;
  }
  /*=== お申込み方法 ===*/
  .howto-switch {
    margin-top: 30px;
  }
  .control-item {
    width: calc((100% - 4px) / 2);
  }
  .control-btn {
    font-size: 16px;
    line-height: 1.2;
  }
  .howto-step {
    padding: 20px 15px 15px;
  }
  .howto-list {
    display: block;
    max-width: 500px;
    margin: 0 auto;
  }
  .howto-item {
    position: relative;
    width: 100%;
  }
  .howto-item:not(:first-child) {
    margin-top: 50px;
  }
  .howto-item:not(:last-child)::after {
    content: "";
    display: block;
    position: absolute;
    bottom: -28px;
    left: 50%;
    width: 16px;
    height: 16px;
    border-top: 3px solid #2d7b94;
    border-right: 3px solid #2d7b94;
    transform: translateX(-50%) rotate(135deg);
  }
  .howto-detail {
    border-width: 1px;
  }
  .howto-item:not(:last-child) .howto-detail::after {
    content: none;
  }
  .howto-lead {
    padding: 5px 5px 5px 50px;
    font-size: 14px;
  }
  .howto-icon {
    top: -11px;
    left: -2px;
    width: 46px;
    border-width: 1px;
  }
  .howto-caption {
    padding: 15px;
    font-size: 13px;
  }
  .howto-ribbon {
    top: -17px;
    width: 66px;
    height: 20px;
    padding: 3px 0;
    font-size: 13px;
  }
  .howto-ribbon::after {
    right: -8px;
    width: 8px;
    height: 20px;
  }
  .howto-label {
    font-size: 13px;
  }
  .howto-txt {
    margin-top: 10px;
    padding: 0;
    font-size: 16px;
  }
  .howto-txt .type-sup {
    font-size: 11px;
  }
  .howto-overview {
    padding: 15px;
  }
  .howto-note {
    font-size: 13px;
  }
  a.howto-btn {
    min-height: 48px;
    padding: 5px 35px 5px 20px;
    font-size: 18px;
  }
  a.howto-btn::after {
    right: 15px;
    width: 10px;
    height: 15px;
  }
  .howto-btn_icon {
    width: 22px;
    height: 22px;
  }
  /*=== パソコンをお持ちの方 ===*/
  .pattern-have .howto-step {
    padding-top: 20px;
  }
  .howto-ttl {
    padding: 5px 25px;
    font-size: 16px;
  }
  .pattern-have .howto-list {
    margin-top: 35px;
  }
  .pattern-have .howto-item:not(:last-child)::after {
    border-color: #e85d00;
  }
  .pattern-have .howto-icon {
    top: -22px;
  }
  /*=== 電話からのお申込み方法 ===*/
  .telApply {
    display: block;
    padding: 15px;
  }
  .telApply-cont {
    display: block;
    margin-top: 15px;
  }
  .telApply-reception {
    margin-left: 0;
  }
  .telApply-number a {
    padding: 0 10px;
    font-size: 36px;
    text-decoration: none;
  }
  .telApply-list {
    display: flex;
    flex-wrap: wrap;
    margin-top: 10px;
    margin-left: -6px;
  }
  .telApply-item {
    display: flex;
    margin: 2px 0 0 6px;
  }
  /*=== セットアップメニュー一覧の注記 ===*/
  .note {
    padding: 25px 15px;
  }
}
@media print, screen and (max-width: 374px) {
  .cpNav-list {
    padding: 4px 0;
  }
  a.cpNav-link {
    font-size: 13px;
  }
  .inquiry-btn_txt {
    font-size: 13px;
  }
}