.pn {
  text-align: center;
  max-width: 90%;
  margin: -40px auto 0;
}
.h303 { margin-top: 5rem; line-height: 1.6; text-align: center; font-weight: bold;}
.blue { color: #1d71b8; }
.green { color: #45bdcf; }
.pink{ color: #cf0084; }
.blue-bk{ background-color: #1d71b8;}
.pink-bk{ background-color: #cf0084;}
.h303 .blue { font-size: 25px; display: block;}
.h303 strong { font-size: 50px; display: block; margin: 1rem 0 4rem;}
.h403 { font-size: 200%; text-align: center;line-height: 1.6;}
.h403 + p { font-size: 114%; text-align: center; margin-top: 1rem;}
@media only screen and (max-width: 782px) {
  .basic { padding-bottom: 80px;}
  .h303, .h403 { letter-spacing: 0;}
  .h303 .blue { font-size: 18px; }
  .h303 strong { font-size: 30px; margin: 0.5rem 0 2.5rem;}
}
.box {
  margin-top: 140px;
  border-radius: 10px;
  padding: 0 60px 60px;
  text-align: center;
}
.box h3 strong {
  position: relative;
  color: #fff;
  background: #1d71b8;
  border-radius: 50px;
  display: inline-flex;
  padding: 0px 90px;
  align-items: center;
  justify-content: center;
  height: 80px;
  margin-top: -40px;
  font-size: 180%;
  line-height: 1.4;
}
.box h3 strong::after {
  content: "";
  position: absolute;
  left: -40px;
  top: -40px;
  width: 111px;
  height: 110px;
  background: url("../img/cleaning/hukidashi@2x.png") no-repeat left top / cover;
}
.box h4 { font-size: 40px; line-height: 1.4; margin-top: 50px;}
.box h4 + p { font-size: 114%; font-weight: bold;}
.box .img { margin-top: 4rem;}
.box table {
  margin: 10rem auto 5rem;
  border: #45bdcf 1px solid;
  border-spacing: 3rem 0rem;
  padding: 3rem 4%;
  border-collapse: separate;
  position: relative;
}
.box table:after {
  content: "";
  display: block;
  width: 47rem;
  height: 1px;
  background: linear-gradient(#fff 49%, #fff 50%);
  position: absolute;
  bottom: -1px;
  left: 48%;
  transform: translateX(-50%);
  z-index: 0;
}
.box table thead,.box table tfoot{
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
.box table thead{ top: -3rem;}
.box table th {
  text-align: left;
  font-size: 145%;
  font-weight: 500;
  white-space: nowrap;
  line-height: 1.6;
  padding: 1rem 3rem;
  background-color: #000;
  color: #fff;
}
.box table td { text-align: center; position: relative; vertical-align: baseline;}
.box table tbody tr:first-child td strong{
  display: block;
  border-radius: 2rem;
  color: #fff;
  padding: 0.5rem 0;
}
.box table tbody tr:first-child td:first-child{
  display: block;
  margin-bottom: 2rem;
}
tbody::before, tbody::after {
  content: "";
  width: 100%;
  height: 4rem;
  display: block;
}
.box img.circle{
  position: absolute;
  top: -3rem;
  right: 0;
  transform: translate(50%, -50%);
}
strong.en { font-weight: 700;}
.box table td .name { font-size: 32px; font-weight: 800; letter-spacing: 0;}
.box table td .price { font-size: 50px; display: inline-block; margin: 0 5px; line-height: 1.7;}
.box td.blue, .box td.pink {
  font-size: 3rem;
  font-weight: 700;
  letter-spacing: 0;
}
.box .slash{display: inline-block; transform: scaleY(2) translate(-6px, -2px);}
.box .small { font-size: 75%;}
.box table tfoot{
  bottom: -5rem;
  font-size: 180%;
  font-weight: 800;
  white-space: nowrap;
  line-height: 1.6;
  padding: 1rem 3rem 1rem 8rem;
  z-index: 2;
}
.box table tfoot:before {
  content: "+";
  font-size: 5.5rem;
  font-weight: 200;
  color: #cf0084;
  background-color: #fff100;
  border-radius: 50%;
  display: flex;
  width: 6rem;
  height: 6rem;
  position: absolute;
  top: 40%;
  left: 0;
  transform: translate(50%, -35%);
  align-items: center;
  justify-content: center;
  padding: 0 0 4px 2px;
}
.box sub.small{ font-size: 60%; font-weight: 500;}
@media only screen and (max-width: 782px) {
  .box {
    margin-top: 70px;
    padding: 0 5vw 5vw;
  }
  .box h3 strong {
    padding: 0px 40px;
    height: 60px;
    margin-top: -30px;
    font-size: 140%;
    box-sizing: border-box;
    width: 100%;
    display: flex;
  }
  .box h3 strong::after {
    content: "";
    position: absolute;
    left: -20px;
    top: -20px;
    width: 55px;
    height: 55px;
  }
  .box h4 { font-size: 25px; line-height: 1.4; margin-top: 25px;}
  .box .img { margin-top: 2.5rem;}
  /* .box table,
   .box table tr,
   .box table th,
  .box table td { display: block;} */
  .box table {
    /* display: table; */
    margin: 6rem auto 3rem;
    border-spacing: 1rem 0;
    padding: 3rem 0;
  }
  .box table:after { width: 20rem; }
  .box table thead{ top: -2rem; }
  /* .box table tr{display: table-row;} */
  .box table th { /*display:table-cell;*/ text-align: center; font-size: 100%; /*padding-right: 0;あとでけす*/ padding:0.8rem 1.4rem;}
  .box table td { /*display:table-cell; text-align: right; transform: translateY(0px);*/ text-align: center; text-wrap: nowrap; font-size: 0.7rem;}
  .box table td .name { font-size: 12px;}
  .box table td .price { font-size: 20px; display: inline-block; margin: 0 5px; letter-spacing: 0;}
  .box tbody::before, .box tbody::after { height: 0;}
  .box table tbody tr:first-child td:first-child{ margin-bottom: 1rem; }
  .box img.circle{ top: -2rem; width: 50px;}
  .box td.blue, .box td.pink { font-size: 1.2rem; }
  .box .slash{transform: scaleY(2) translate(-3px, -2px);}
  .box table tfoot{ bottom: -2.8rem; padding: 1rem 4rem 1rem 8rem; }
  .box table tfoot:before { transform: scale(0.5) translate(100%, -10%); top: 0rem; padding: 0 1px 10px 9px; width: 5rem; height: 5rem;}
  .box table tfoot td{ font-size: 1.2rem; }
}
#contactSection {
  margin: 9rem 0 0 0;
  background: #fff554;
  border-radius: 10px;
  padding: 20px;
  text-align: center;
}
#contactSection h3 {
  background: #262253;
  color: #fff;
  line-height: 1.6;
  padding: 10px;
}
#contactSection h3 .large { font-size: 145%;}
#contactSection .flx {
  display: flex;
  justify-content: center;
}
#contactSection .flx dl {
  width: calc(33.3% - 30px);
  margin: 20px 15px 0;
}
#contactSection .flx dt { position: relative;}
#contactSection .flx dt::before {
  content: "";
  width: 100%;
  height: 1px;
  background: #262253;
  position: absolute;
  left: 0;
  top: 50%;
  z-index: 1;
}
#contactSection .flx dt span {
  display: inline-block;
  background: #fff554;
  padding: 0 15px;
  position: relative;
  z-index: 2;
}
#contactSection .flx dd a.btn {
  background: #45bdcf;
  color: #fff;
  font-size: 94%;
  text-align: left;
  padding: 10px 45px 10px 25px;
  border-radius: 50px;
  font-weight: bold;
  display: block;
  position: relative;
  line-height: 1.4;
  margin-top: 10px;
}
#contactSection .flx dd a.btn::after {
  content: "";
  width: 10px;
  height: 10px;
  box-sizing: border-box;
  border-top: #fff 2px solid;
  border-right: #fff 2px solid;
  transform: rotate(45deg);
  position: absolute;
  right: 15px;
  top: calc(50% - 5px);
}
#contactSection .flx dd a.mail {
  font-size: 135%;
  letter-spacing: 0;
  margin-top: 20px;
  display: block;
}
#contactSection .flx dd strong.en {
  font-size: 220%;
  line-height: 1.2;
  letter-spacing: 0;
  margin-top: 8px;
  display: inline-block;
}
#contactSection .flx dd .small {
  font-size: 86%;line-height: 1.2;
}
@media only screen and (max-width: 782px) {
  #contactSection .flx {
    display: block;
  }
  #contactSection .flx dl {
    width: auto;
    margin: 20px 0 0;
  }
  #contactSection .flx dd a.btn {
    width: 280px;
    max-width: 100%;
    margin: 10px auto 0;
    box-sizing: border-box;
  }
  #contactSection .flx dd a.mail {
    margin-top: 10px;
  }
}