@charset "UTF-8";
@import url(https://fonts.googleapis.com/css2?family=Oswald:wght@300;400;600&family=Zen+Kaku+Gothic+Antique:wght@400;500;700&family=Zen+Maru+Gothic:wght@400;700;900&display=swap);
@import "../../css/ads.css";
html {
  color: #020452;
  line-height: 1.8;
}

.uk-container {
  padding-left: 30px;
  padding-right: 30px;
}

.padding-medium {
  padding: 30px;
}

.ko-ttl-large {
  font-size: 1.9rem;
  line-height: 1.5;
}
@media screen and (min-width: 960px) {
  .ko-ttl-large {
    font-size: 2.5rem;
  }
}

.ko-ttl-medium {
  font-size: 1.5rem;
}
@media screen and (min-width: 960px) {
  .ko-ttl-medium {
    font-size: 1.9rem;
    line-height: 1.85;
  }
}

.ko-ttl-small {
  font-size: 1.2rem;
}
@media screen and (min-width: 960px) {
  .ko-ttl-small {
    font-size: 1.3rem;
  }
}

.ko-text-small {
  font-size: 0.7rem;
  line-height: 1.4;
  color: #444444;
  padding-top: 5px;
  margin-top: 5px;
}

.marker {
  background: linear-gradient(transparent 60%, #FFFAAC 60%, #FFFAAC 90%, transparent 90%);
  display: inline-block;
}

.font-gothic {
  font-family: "Zen Kaku Gothic Antique", sans-serif;
}

.font-maru-gothic {
  font-family: "Zen Maru Gothic";
}

.mainvisual {
  position: relative;
  background: url(../img/index2/aquaclara_logo.png) no-repeat top 10px right 10px/80px, url(../img/index2/fv_bg_img_smp.png) no-repeat top center/100vw, url(../img/index2/fv_bg_dot_left.png) no-repeat bottom left -10px/55vw, url(../img/index2/fv_bg_dot_right.png) no-repeat top right -80px/90vw, linear-gradient(90deg, rgb(255, 255, 255) 90%, rgb(108, 176, 219) 90%);
}
.mainvisual .fv-img-smp {
  width: 85%;
}
.mainvisual .fv-img-smp img {
  margin-top: 86.9565217391vw;
}
@media screen and (min-width: 640px) {
  .mainvisual {
    background: url(../img/index2/aquaclara_logo.png) no-repeat top 10px left/120px, url(../img/index2/fv_bg_img.png) no-repeat top right -100px/79vw, url(../img/index2/fv_bg_dot_right.png) no-repeat top right 130px/60vw, url(../img/index2/fv_bg_dot_left.png) no-repeat bottom left/40vw, linear-gradient(90deg, rgb(255, 255, 255) 70%, rgb(108, 176, 219) 70%);
  }
  .mainvisual .fv-img-pc {
    width: 50vw;
  }
  .mainvisual .fv-img-pc img {
    margin: 80px 0 60px;
  }
}
@media screen and (min-width: 960px) {
  .mainvisual {
    background: url(../img/index2/aquaclara_logo.png) no-repeat top 10px left/120px, url(../img/index2/fv_bg_img.png) no-repeat top left 40vw, url(../img/index2/fv_bg_dot_right.png) no-repeat top right 130px/60vw, url(../img/index2/fv_bg_dot_left.png) no-repeat bottom left/40vw, linear-gradient(90deg, rgb(255, 255, 255) 70%, rgb(108, 176, 219) 70%);
  }
  .mainvisual .fv-img-pc {
    width: 70%;
  }
  .mainvisual .fv-img-pc img {
    margin: 80px 0 70px;
  }
}
@media screen and (min-width: 1200px) {
  .mainvisual {
    background: url(../img/index2/aquaclara_logo.png) no-repeat top 10px left 20px/120px, url(../img/index2/fv_bg_img.png) no-repeat top left 80%, url(../img/index2/fv_bg_dot_left.png) no-repeat bottom left, url(../img/index2/fv_bg_dot_right.png) no-repeat top right, linear-gradient(90deg, rgb(255, 255, 255) 70%, rgb(108, 176, 219) 70%);
  }
  .mainvisual .fv-img-pc img {
    margin: 70px 0 70px 70px;
  }
}

#award {
  background: #fffccc;
  padding: 30px 20px;
}
@media screen and (min-width: 960px) {
  #award {
    padding: 20px 30px;
  }
}

#tokuten {
  position: relative;
  background: url(../img/index2/tokuten_bg_top.png) no-repeat top/100vw, url(../img/index2/tokuten_bg_bottom.png) no-repeat bottom/100vw, #F4CDD0;
  padding-top: 80px;
}
@media screen and (min-width: 960px) {
  #tokuten {
    padding: 100px 0 20px;
  }
}
#tokuten .tokuten-ttl {
  font-size: 2rem;
  line-height: 1.3;
}
#tokuten .tokuten-ttl span {
  display: inline-block;
}
@media screen and (min-width: 960px) {
  #tokuten .tokuten-ttl {
    font-size: 3rem;
  }
}
#tokuten .tokuten-ttl-marker {
  background: repeating-linear-gradient(-45deg, #fff 0, #fff 7px, transparent 7px, transparent 11px);
  background-repeat: no-repeat;
  background-position: left bottom;
  background-size: 100% 0.5em; /* ストライプの横幅・縦幅 */
  display: inline-block;
  font-size: 2rem;
  line-height: 1.3;
  padding: 0 7px;
}
@media screen and (min-width: 960px) {
  #tokuten .tokuten-ttl-marker {
    font-size: 3rem;
  }
}

#tokuten::before {
  position: absolute;
  background: #fff url(../../inc/kosodate/img/index2/tokuten_bg_top.png) no-repeat top center;
  content: "";
  height: 80px;
}

.ko-thankyouset {
  background: #fff;
  border: 2px solid #020452;
  border-radius: 5px;
  margin-top: 80px;
}
.ko-thankyouset .ko-thankyouset-copy {
  background: #020452;
  color: #fff;
  padding: 10px;
}
.ko-thankyouset .ko-thankyouset-copy p {
  margin: 0;
}
.ko-thankyouset .ko-thankyouset-price {
  position: relative;
  background: #FFFAAC;
  padding: 20px 10px;
  margin-top: 20px;
}
.ko-thankyouset .ko-thankyouset-price::before {
  position: absolute;
  display: inline-block;
  content: "";
  width: 15px;
  height: 15px;
  top: -20px;
  right: 48%;
  border-bottom: 8px solid #e50112;
  border-right: 8px solid #e50112;
  transform: rotate(45deg);
}
@media screen and (min-width: 960px) {
  .ko-thankyouset .ko-thankyouset-price {
    padding: 30px 10px;
    margin-top: 30px;
  }
  .ko-thankyouset .ko-thankyouset-price::before {
    width: 20px;
    height: 20px;
    top: -20px;
  }
}

#price .price-list-cont {
  max-width: 550px;
}
#price .price-list-cont .price-list-ttl {
  position: relative;
  display: inline-block;
  margin: 1.5em 0;
  padding: 10px 30px;
  min-width: 120px;
  max-width: 100%;
  background: #add1e8;
  border-radius: 30px;
}
#price .price-list-cont .price-list-ttl::before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -13px;
  border: 13px solid transparent;
  border-top: 13px solid #add1e8;
}
#price .price-list-cont .price-list-ttl p {
  margin: 0;
  padding: 0;
}
#price .price-list-cont .uk-table {
  border-bottom: 1px solid #e5e5e5;
}
#price .price-list-cont .uk-table thead > tr > td span {
  display: block;
}
#price .price-list-cont .ko-price-result {
  position: relative;
  margin-top: 80px;
}
#price .price-list-cont .ko-price-result::before {
  position: absolute;
  display: inline-block;
  content: "";
  width: 20px;
  height: 20px;
  top: -60px;
  right: 48%;
  border-bottom: 6px solid #020452;
  border-right: 6px solid #020452;
  transform: rotate(45deg);
}
#price .price-list-cont .price-difference {
  font-size: 2.5rem;
  line-height: 1;
}
@media screen and (min-width: 960px) {
  #price .price-list-cont .price-difference {
    font-size: 4rem;
    line-height: 1.2;
  }
}

#product {
  background: url(../img/index2/product_bg_left.png) no-repeat bottom left/80vw, url(../img/index2/product_bg_right.png) no-repeat top right/80vw, #add1e8;
  padding: 50px 0 50px;
}
#product .product-ttl span {
  display: inline-block;
}
#product .tab_area .tab_label img {
  border: 1px solid #add1e8;
}
#product .tab_area .tab_label img:hover {
  border: 1px solid #fff;
}
#product .tab_area .active img {
  border: 1px solid #fff;
}
#product .panel_area .tab_panel {
  display: none;
}
#product .panel_area .active {
  display: block;
}
#product .panel_area .product-left .product-img-text {
  padding: 5px;
}
#product .panel_area .product-left .product-img-text p {
  color: #020452;
}
#product .panel_area .product-left .uk-slidenav {
  color: #020452;
}
#product .panel_area .product-left .uk-overlay-primary {
  background: rgba(200, 200, 200, 0.8);
}
#product .panel_area .product-right {
  margin-top: 10px;
}
#product .panel_area .product-right .award {
  line-height: 1;
}
#product .panel_area .product-right .name {
  font-size: 1.7rem;
}
#product .panel_area .product-right .name span {
  display: block;
}
#product .panel_area .product-right .name .no1logo {
  display: inline-block;
  margin-right: 10px;
}
#product .panel_area .product-right .way {
  font-size: 0.7rem;
  margin-top: 15px;
}
#product .panel_area .product-right .way span {
  border-radius: 4px;
  padding: 7px;
}
#product .panel_area .product-right .way .koukin {
  background: #cce5ff;
}
#product .panel_area .product-right .way .lock {
  background: #f8dcea;
}
#product .panel_area .product-right .anshin-support {
  background: #fff;
  border: 1px solid #020452;
  border-radius: 5px;
  margin-top: 30px;
}
#product .panel_area .detail-area .detail-area-ttl {
  position: relative;
  border: 1px solid #020452;
  background: #fff;
  border-radius: 5px;
  padding: 10px;
}
#product .panel_area .detail-area .detail-area-ttl:active {
  background: #FFFAAC;
}
#product .panel_area .detail-area .detail-area-ttl::after {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  top: 37%;
  right: 20px;
  border-right: 1px solid #020452;
  border-bottom: 1px solid #020452;
  transform: rotate(45deg);
  z-index: 10;
}
@media screen and (min-width: 960px) {
  #product .panel_area .detail-area .detail-area-ttl::after {
    right: 40px;
  }
}
#product .panel_area .detail-area .spec_contents {
  display: none;
}
#product .panel_area .detail-area .detail-cont-ttl {
  background: #7AAED0;
  color: #fff;
  padding: 7px;
}
@media screen and (min-width: 960px) {
  #product {
    background: url(../img/index2/product_bg_left.png) no-repeat bottom left/60vw, url(../img/index2/product_bg_right.png) no-repeat top right/50vw, #add1e8;
    padding: 100px;
  }
  #product .tab_area {
    flex-wrap: nowrap;
  }
  #product .panel_area .product-right {
    margin-top: 30px;
  }
  #product .panel_area .product-right .name {
    font-size: 2rem;
  }
  #product .panel_area .product-right .way {
    margin-top: 20px;
  }
  #product .panel_area .product-right .anshin-support {
    margin-top: 60px;
  }
}

.wator-bg {
  background: url(../img/index2/wator_bg_left.png) no-repeat bottom 120px left -40px/70vw, url(../img/index2/wator_bg_right.png) no-repeat top 70px right -40px/70vw;
}
@media screen and (min-width: 960px) {
  .wator-bg {
    background: url(../img/index2/wator_bg_left.png) no-repeat bottom left -40px/55vw, url(../img/index2/wator_bg_right.png) no-repeat top right -40px/55vw;
  }
}

@media screen and (min-width: 960px) {
  #wator .wator-cont {
    margin-left: 20px;
    margin-right: 20px;
  }
}

#use .use-left {
  position: relative;
  width: 70vw;
  padding: 0 40px 40px 0;
}
#use .use-left::after {
  content: "";
  position: absolute;
  width: 90%;
  height: 90%;
  top: 40px;
  right: -10px;
  background: #fff8d5;
  z-index: -1;
}
#use .use-right {
  position: relative;
  top: 20px;
  width: 70vw;
  padding: 0 0 40px 60px;
}
#use .use-left, #use .use-right {
  line-height: 1.3;
}
#use .use-left span, #use .use-right span {
  display: block;
}
#use .use-right::after {
  content: "";
  position: absolute;
  width: 70vw;
  height: 90%;
  top: 40px;
  right: 50px;
  background: #fff8d5;
  z-index: -1;
}
#use .use-left-text, #use .use-right-text {
  position: absolute;
  background: #fff;
  padding: 10px;
  font-family: "Zen Maru Gothic";
  font-weight: 700;
}
#use .use-left-text {
  bottom: 0;
  right: 0;
  transform: rotate(-5deg);
}
#use .use-right-text {
  left: 30px;
  bottom: -5px;
  transform: rotate(5deg);
}
@media screen and (min-width: 960px) {
  #use .use-left {
    width: 90%;
    padding: 0 40px 40px 0;
  }
  #use .use-left::after {
    top: 60px;
  }
  #use .use-left-text {
    bottom: 20px;
  }
  #use .use-right {
    top: -180px;
    width: 90%;
    padding: 0 0 40px 40px;
  }
  #use .use-right::after {
    width: 90%;
    height: 90%;
    top: 70px;
    right: 70px;
  }
  #use .use-left span, #use .use-right span {
    display: inline-block;
  }
}

#service .service-ttl {
  font-size: 2rem;
}
#service .service-ttl span {
  background: repeating-linear-gradient(-45deg, #ffed85 0, #ffed85 7px, transparent 7px, transparent 11px);
  background-repeat: no-repeat;
  background-position: left bottom;
  background-size: 100% 0.5em; /* ストライプの横幅・縦幅 */
  display: inline-block;
  font-size: 2.5rem;
  line-height: 1.3;
  padding: 0 7px;
  margin-right: 10px;
}
@media screen and (min-width: 960px) {
  #service .service-ttl br {
    display: none;
  }
}
@media screen and (min-width: 640px) {
  #service .service-main {
    margin-top: 40px;
  }
}
#service .service-cont img {
  border-radius: 10px;
}
#service .service-cont-ttl span {
  display: block;
}

.flow-ttl {
  background: #F5D381;
  padding: 20px;
}

#flow {
  background-color: #FFF8E6;
  padding: 50px 0;
}
@media screen and (min-width: 640px) {
  #flow {
    padding: 70px 0;
  }
}
#flow span {
  display: inline-block;
}
#flow .flow-box {
  position: relative;
  margin-bottom: 70px;
}
@media screen and (min-width: 960px) {
  #flow .flow-box {
    margin-bottom: 0;
  }
}
#flow .flow-box::after {
  position: absolute;
  content: url(/clp/inc/kosodate/img/index2/arrow.gif);
  width: 27px;
  height: 44px;
  right: 45%;
  bottom: -60px;
}
@media screen and (min-width: 640px) {
  #flow .flow-box::after {
    right: -70px;
    bottom: 50%;
    transform: rotate(-90deg);
  }
}
@media screen and (max-width: 639px) {
  #flow .toggle {
    display: none;
  }
  #flow .Label {
    display: block;
    background: #eab330;
    border-radius: 30px;
    color: #fff;
    padding: 10px;
  }
  #flow .Label::before {
    content: "";
    width: 6px;
    height: 6px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    -webkit-transform: rotate(45deg);
    position: absolute;
    top: calc(50% - 3px);
    right: 20px;
    transform: rotate(135deg);
  }
  #flow .Label,
  #flow .content {
    backface-visibility: hidden;
    transform: translateZ(0);
    transition: all 0.3s;
  }
  #flow .content {
    height: 0;
    margin-bottom: 10px;
    padding: 0 20px;
    overflow: hidden;
  }
  #flow .toggle:checked + .Label + .content {
    height: auto;
    padding: 20px;
    transition: all 0.3s;
  }
  #flow .toggle:checked + .Label::before {
    transform: rotate(-45deg) !important;
  }
}

.trial-plan-ttl {
  background: #449713;
  color: #fff;
  padding: 15px;
  border-radius: 5px 5px 0 0;
}
.trial-plan-ttl span {
  display: inline-block;
}

.trial-plan-cont {
  background-color: #F7F7F7;
  border-bottom: 10px solid #449713;
  border-radius: 0 0 5px 5px;
  padding: 30px;
}
@media screen and (min-width: 960px) {
  .trial-plan-cont {
    padding: 50px;
  }
}

.ko-campaign {
  background: #fff;
  border: 2px solid #020452;
  border-radius: 5px;
}
.ko-campaign img {
  border-radius: 5px;
}

.ko-plus {
  display: inline-block;
  width: 25px;
  height: 25px;
  border: 2px solid #020452;
  border-radius: 50px;
  padding: 5px;
  font-size: 1.5rem;
  line-height: 1;
  font-weight: bold;
}

.btn-area a {
  text-decoration: none;
}

.order-btn {
  position: relative;
  border-radius: 10px;
  padding: 15px 30px 15px 15px;
  color: #fff;
  font-size: 1.1rem;
  line-height: 1.4;
  letter-spacing: 1px;
  text-align: center;
}
.order-btn .ko-btn-text-small {
  font-size: 0.9rem;
}
.order-btn span {
  display: block;
}
@media screen and (min-width: 960px) {
  .order-btn {
    font-size: 1.5rem;
  }
  .order-btn .ko-btn-text-small {
    font-size: 1.2rem;
  }
}

.order-btn::after {
  position: absolute;
  content: "";
  width: 15px;
  height: 15px;
  top: 37%;
  right: 20px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  z-index: 10;
}

.new-plan-btn {
  background: #60B0E3;
  border-bottom: 4px solid #3c8fc4;
}

.trial-plan-btn {
  background: #f57821;
  border-bottom: 4px solid #e05b12;
}

footer {
  background: #F7F7F7;
}

/*以下後で共通cssに移動させる*/
.caution-ttl {
  position: relative;
  background: #020452; /* ここはページごとに変える*/
  color: #fff; /* ここはページごとに変える*/
  line-height: 1.2;
  padding: 15px 40px 15px 15px;
}

.caution-ttl:after {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  top: 37%;
  right: 20px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
  z-index: 10;
}
@media screen and (min-width: 960px) {
  .caution-ttl:after {
    right: 40px;
  }
}

.caution-main {
  display: none;
  border: 1px solid #020452; /*ここはページごとに変える*/
  padding: 15px;
}

.uk-accordion .uk-accordion-title {
  background: #020452; /* ここはページごとに変える*/
  color: #fff; /* ここはページごとに変える*/
  font-size: 1rem;
  line-height: 1.2;
  padding: 15px;
}
.uk-accordion .uk-accordion-title:before {
  background-color: #fff;
}
.uk-accordion a:hover {
  color: #fff; /* ここはページごとに変える*/
}
.uk-accordion a:visited {
  color: #fff; /* ここはページごとに変える*/
}
.uk-accordion .uk-accordion-content {
  border: 1px solid #020452; /*ここはページごとに変える*/
  padding: 15px;
  margin-top: 0;
}

.flt-btn .flt-btn-sticky {
  position: fixed;
  right: 1%;
  bottom: 1%;
  z-index: 980;
}
.flt-btn a {
  display: inline-block;
  background: #60B0E3; /*ここはページごとに変える*/
  color: #fff; /*ここはページごとに変える*/
  border: 1px solid #fff;
  border-radius: 50px;
}
.flt-btn a .flt-btn-smp {
  width: 80px;
  height: 80px;
}
.flt-btn a .flt-btn-pc {
  width: 100px;
  height: 100px;
}

#award-mother {
  background: #fce6e8;
  padding: 20px 20px 30px;
}
#award-mother .mother-logo img {
  background: #fff;
  padding: 10px;
}