@charset "UTF-8";
/* ======================================================================
 setting
====================================================================== */
/* ======================================================================
 p_price
====================================================================== */
.pc {
    display: block;
}
.sp {
    display: none;
}

.f_pink {
    color: #f95b5b;
}

.f_bold {
    font-weight: 500;
}

.f_tax_s {
    font-size: 13px;
}

.l_main_visual.pt2 > .inner > .drop_wrap > .content {
    display: flex;
}

.l_main_visual .inner .box_1 {
    width: 230px;
    border-right: solid 4px #018fa7;
    padding: 8px 0 0;
}

 .l_main_visual .inner .box_2 {
    width: 870px;
    padding: 0 0 0 70px;
}

.l_main_visual.pt2 > .inner > .drop_wrap > .content .box_1:before {
  content: '';
  background: url(../img/ico_water.png);
  background-size: cover;
  width: 50px;
  height: 39px;
  position: absolute;
  top: 10px;
  left: 0;
}

.l_main_visual.pt2 > .inner > .drop_wrap > .content .box_1 .main_ttl {
  font-size: 3.4em;
  line-height: 1.3;
  letter-spacing: .06em;
  font-weight: 500;
  padding-left: 64px;
  display: inline-block;
  vertical-align: middle;
}

.l_main_visual.pt2 > .inner > .drop_wrap > .content .box_1 .sub_ttl {
  text-transform: uppercase;
}

.l_content .l_main > .inner {
    width: 1100px;
    margin: 0 auto 150px;
}

.l_content .l_main .sec_ttl {
    width: 1100px;
    margin: 50px auto 50px;
    text-align: center;
    position: relative;
}

.l_content .l_main .sec_ttl .ja {
    display: block;
    font-size: 3em;
    font-weight: 400;
    letter-spacing: 0.06em;
    margin: 0 0 30px;
}

.l_content .l_main .sec_ttl .en {
    display: inline-block;
    color: #018fa7;
    font-size: 1.8em;
    letter-spacing: 0.06em;
    padding: 0 30px;
    position: relative;
    background: #fff;
}

.l_content .l_main .sec_ttl:before {
    content: '';
    display: block;
    height: 6px;
    position: absolute;
    bottom: 77px;
    width: 100%;
    background-image: radial-gradient(#018fa7 15%, rgba(0, 0, 0, 0) 25%), radial-gradient(#018fa7 15%, rgba(0, 0, 0, 0) 25%);
    background-size: 20px 20px;
    background-position: 0 0, 0 13px;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.l_content .l_main .sec_ttl:after {
    content: '';
    background: url(../img/drop.png);
    display: block;
    background-size: cover;
    width: 60px;
    height: 50px;
    margin: 20px auto 0;
}

.l_content .l_main .sec_step {
  background: #F8F7F7;
  padding: 40px 40px 40px 50px;
  position: relative;
  display: flex;
  justify-content: space-between;
  width: 100%;
  margin-bottom: 50px;
}

.l_content .l_main .sec_step:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -30px;
  border: 30px solid transparent;
  border-top: 30px solid #F8F7F7;
}

.l_content .l_main .sec_step.last:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: 0;
  border: 0 solid transparent;
  border-top: 0 solid #F8F7F7;
}

.l_content .l_main .sec_step dt {
  font-size: 2.1em;
  margin-bottom: 38px;
}

.l_content .l_main .sec_step dd {
  font-size: 1.6em;
  letter-spacing: -.02em;
  line-height: 200%;
}

/* accordion */
.clk {
    pointer-events: none;
}

.toggle {
    display: block;
}

.toggle_btn {
    display: none;
}


@media screen and (max-width: 768px) {

    .pc {
        display: none;
    }
    .sp {
        display: block;
    }

    .l_main_visual {
        min-height: 460px;
    }

    .l_main_visual.pt2 > .inner {
        min-height: 400px;
        padding-top: 64px;
        background: url(../img/category/sp/bg_water.png) no-repeat;
        background-size: 100%;
    }

    .l_main_visual.pt2 > .inner > .drop_wrap {
        width: 100%;
        background: #cef0f6;
        padding-top: 20px;
        min-height: 400px;
    }

    .l_main_visual.pt2 > .inner > .drop_wrap:before {
        content: '';
        background: url(../img/category/sp/bg_drop.png) no-repeat;
        width: 375px;
        height: 396px;
        right: 0;
        background-size: cover;
        display: block;
    }

    .l_main_visual.pt2 > .inner > .drop_wrap > .content {
        display: block;
        width: 100%;
    }

    .l_main_visual.pt2 > .inner > .drop_wrap > .content .box_1 {
        width:100%;
        border-right: none;
        position: relative;
        top: 0;
        text-align: center;
    }

    .l_main_visual.pt2 > .inner > .drop_wrap > .content .box_2 {
        width:100%;
        padding: 20px 0 0;
    }

    .l_main_visual.pt2 > .inner > .drop_wrap > .content .box_1:before {
      content: '';
      background: url(../img/ico_water.png) no-repeat;
      background-size: 100%;
      width: 35px;
      height: 39px;
      position: relative;
      top: 5px;
    }
    
    .l_main_visual.pt2 > .inner > .drop_wrap > .content .box_1 .main_ttl {
      font-size:2.8em;
      letter-spacing: .06em;
      font-weight: 500;
      padding-left: 0;
      display: inline-block;
      vertical-align: middle;
  
    }
    
    .l_main_visual.pt2 > .inner > .drop_wrap > .content .box_1 .sub_ttl {
      text-transform: uppercase;
      font-size: 1.3em;
      text-align: center;
    }

    .l_content .l_main > .inner {
        width: auto;
        margin: 0 18px 150px;
    }

    .l_content .l_main .sec_ttl {
        width: 100%;
        margin: 20px auto 50px;
        text-align: center;
        position: relative;
    }

    .l_content .l_main .sec_ttl .ja {
        display: block;
        font-size: 2.8em;
        line-height: 1.5;
        font-weight: 400;
        letter-spacing: 0;
        margin: 0 0 10px;
    }
    
    .l_content .l_main .sec_ttl .en {
        display: inline-block;
        color: #018fa7;
        font-size: 1.3em;
        letter-spacing: 0.06em;
        padding: 0 30px;
        position: relative;
        background: #fff;
    }

    .l_content .l_main .sec_ttl:before {
        content: '';
        display: block;
        height: 7px;
        position: absolute;
        bottom: 43px;
        width: 100%;
        background-image: radial-gradient(#018fa7 5%, rgba(0, 0, 0, 0) 15%), radial-gradient(#018fa7 5%, rgba(0, 0, 0, 0) 15%);
        background-size: 10px 10px;
        background-position: 0 0, 0 13px;
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
    }

    .l_content .l_main .sec_ttl:after {
        content: '';
        background: url(../img/drop.png);
        display: block;
        background-size: cover;
        width: 35px;
        height: 29px;
        margin: 10px auto 0;
    }

    .l_content .l_main .sec_step {
      display: block;
      margin-bottom: 50px;
      padding: 20px;
    }

    .l_content .l_main .sec_step dt {
      text-align: center;
      margin-bottom: 20px;
    }

    .l_content .l_main .sec_step dd > .photo {
      margin-bottom: 10px;
    }

    /* accordion */
    .clk {
        pointer-events: all;
    }

    .toggle {
        display: none;
    }

    .toggle_btn {
        position: absolute;
        top: 50%;
        right: 15px;
        transform: translateY(-50%);
        display: block;
        width: 50px;
        height: 50px;
        text-indent: 100%;
        white-space: nowrap;
        overflow: hidden;
        border-radius: 50%;
    }
    .toggle_btn:before, .toggle_btn:after {
        display: block;
        content: '';
        background-color: #fff;
        position: absolute;
        width: 20px;
        height: 2px;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }
    .toggle_btn:before {
        width: 2px;
        height: 20px;
    }
    .clk.selected .toggle_btn:before {
        content: normal;
    }
    .clk.selected {
        border-radius: 6px 6px 0 0 !important;
    }
}
