@charset "UTF-8";

#HEADER, .MEMBER .four .fourClum>li {
  -o-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 5px rgba(0, 0, 0, .15)
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 100
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 200
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 300
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 400
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 500
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Bold");
  font-weight: 700
}

@font-face {
  font-family: Cochin;
  src: url(font/cochin.ttc) format("truetype")
}

@media screen and (min-width:769px) {
  body, h1, h2, h3, h4, h5, h6, .column-fix01 {
    font-weight: 500
  }

  * {
    margin: 0;
    padding: 0;
    zoom: 1
  }

  *, :after, :before {
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box
  }

  html {
    -webkit-text-size-adjust: none
  }

  body {
    color: #151515;
    background: #FFF;
    font-size: 14px;
    line-height: 1.8;
    font-family: 'メイリオ', 'Meiryo', 'ＭＳ ゴシック', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
    font-feature-settings: "palt";
    letter-spacing: .04em
  }

  img {
    -ms-interpolation-mode: bicubic;
    vertical-align: bottom
  }

  i, strong {
    font-style: normal
  }

  a {
    text-decoration: none;
    outline: 0;
    cursor: pointer;
    color: #ED7D31
  }

  a:hover {
    color: #bb2331
  }

  a:hover img {
    opacity: .8
  }

  .clear {
    clear: both
  }

  .MEMBER .addFor .flexClum li .box:after, .clearfix:after {
    content: "";
    display: block;
    clear: both
  }

  .display {
    width: 1280px;
    margin: 0 auto;
    position: relative;
    top: 0;
    left: 0
  }

  input[type=text], input[type=tel], input[type=email], textarea {
    -webkit-appearance: none
  }
}

@media screen and (max-width:768px) {
  body, h1, h2, h3, h4, h5, h6, .column-fix01 {
    font-weight: 500
  }

  * {
    margin: 0;
    padding: 0;
    zoom: 1
  }

  *, :after, :before {
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box
  }

  html {
    -webkit-text-size-adjust: none
  }

  body {
    color: #151515;
    background: #FFF;
    font-size: 12px;
    line-height: 1.8;
    font-family: 'メイリオ', 'Meiryo', 'ＭＳ ゴシック', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
    font-feature-settings: "palt";
    letter-spacing: .04em
  }

  img {
    -ms-interpolation-mode: bicubic;
    vertical-align: bottom
  }

  i, strong {
    font-style: normal
  }

  a {
    text-decoration: none;
    outline: 0;
    cursor: pointer;
    color: #ED7D31
  }

  a:hover {
    color: #bb2331
  }

  a:hover img {
    opacity: .8
  }

  .clear {
    clear: both
  }

  .MEMBER .addFor .flexClum li .box:after, .clearfix:after {
    content: "";
    display: block;
    clear: both
  }

  .display {
    width: auto;
    margin: 0 auto;
    position: relative;
    top: 0;
    left: 0
  }

  input[type=text], input[type=tel], input[type=email], textarea {
    -webkit-appearance: none
  }
}

.INDEX.second dl dd a, .MODULE a.link {
  text-decoration: underline
}

#HEADER {
  box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  transition: all .2s ease-in-out
}

@media screen and (min-width:769px) {
  #HEADER {
    width: 100%;
    height: 140px;
    position: fixed;
    top: 0;
    left: 0;
    padding: 10px 0 0;
    background: #FFF;
    z-index: 10
  }

  #HEADER .logo {
    float: left;
    margin: 0
  }

  #HEADER .logo img {
    width: 322px;
    height: auto
  }

  #HEADER .gnavi {
    float: none;
    margin: 0
  }

  #HEADER .gnavi li {
    list-style: none;
    margin-top: 0;
    float: left;
    margin-left: 0
  }

  #HEADER .gnavi li:first-child {
    margin-left: 0
  }

  #HEADER .gnavi ul {
    display: block
  }
}

@media screen and (max-width:768px) {
  #HEADER {
    width: 100%;
    height: 64px;
    position: fixed;
    top: 0;
    left: 0;
    padding: 0;
    background: #FFF;
    z-index: 10
  }

  #HEADER .logo {
    float: left;
    margin: 9px 0 0 12px
  }

  #HEADER .logo img {
    width: auto;
    height: 23px
  }

  #HEADER .gnavi {
    float: right;
    margin: 14px 0 0;
    background: url(../../images/common/sp_nav_2x.png) 12px 0 no-repeat;
    -ms-background-size: 78px 80px;
    background-size: 78px 80px;
    width: 78px;
    height: 80px;
    cursor: pointer
  }

  #HEADER .gnavi li {
    list-style: none;
    margin-top: 12px;
    float: none
  }

  #HEADER .gnavi.addClose {
    background: url(../../images/common/sp_nav_2x.png) 12px -35px no-repeat;
    -ms-background-size: 78px 80px;
    background-size: 78px 80px
  }

  #HEADER .gnavi ul {
    box-shadow: 0 4px 4px rgba(0, 0, 0, .12);
    position: absolute;
    width: 100%;
    top: 64px;
    left: 0;
    display: none
  }

  #HEADER .gnavi ul li {
    margin: 0;
    border-top: #DDD 1px solid
  }

  #HEADER .gnavi ul li a {
    background: #FFF;
    color: #151515;
    display: block;
    padding: 12px
  }

  #HEADER .gnavi ul li a:hover {
    opacity: .9
  }
}

#HEADER a {
  color: #151515
}

#HEADER .logo:before {
  content: attr(data-text);
  display: block;
  font-size: 13px;
  font-weight: 600;
  text-align: left;
  padding: 0 0 0 55px
}

#HEADER .info {
  float: right
}

#HEADER .info p {
  float: left;
  margin: 24px 20px 0 0;
  font-size: 18px
}

#HEADER .info .click {
  display: inline-block;
  color: #ED7D31;
  font-size: 16px;
  font-weight: 600;
  padding: 13px 30px;
  border: 1px solid #ED7D31;
  border-radius: 8px;
  cursor: pointer
}

@media screen and (max-width:768px) {
  #HEADER {
    box-shadow: 0 2px 8px rgba(0, 0, 0, .24)
  }

  #HEADER:after {
    content: '';
    display: block;
    clear: both
  }

  #HEADER>.display {
    width: 200px;
    float: left;
    margin: 10px 0 0 12px
  }

  #HEADER .logo {
    float: none;
    margin: 0;
    width: 100%
  }

  #HEADER .logo img {
    width: 100%
  }

  #HEADER .logo:before {
    font-size: 10px;
    padding-left: 0
  }

  #HEADER .info {
    display: none
  }
}

#HEADER .gnavi {
  display: block;
  width: 100%;
  height: 56px;
  margin: 17px 0 0;
  border-top: 1px solid #d5d5d5;
  border-bottom: 1px solid #d5d5d5;
  background: #f2f2f2;
  background: linear-gradient(to bottom, #fff 0, #f2f2f2 100%)
}

#HEADER .gnavi>ul>li {
  width: 182px;
  text-align: center;
  padding: 15px 0
}

#HEADER .gnavi>ul>li:last-child {
  padding: 0;
  background: #ED7D31
}

#HEADER .gnavi>ul>li:last-child a {
  border: none;
  color: #fff;
  line-height: 1.5;
  padding: 6px 0
}

#HEADER .gnavi>ul>li .trigger, #HEADER .gnavi>ul>li>a {
  display: block;
  border-left: 1px solid #d5d5d5;
  font-weight: 600;
}

#HEADER .gnavi>ul>li.toggle {
  position: relative;
  top: 0;
  left: 0;
  cursor: pointer
}

#HEADER .gnavi>ul>li.toggle .child {
  display: none
}

@media screen and (min-width:769px) {
  #HEADER .gnavi>ul>li.toggle:hover .child {
    display: block;
    position: absolute;
    top: 55px;
    left: 0;
    width: 100%;
    background: #f2f2f2;
    border: 1px solid #d5d5d5;
    border-top: none
  }

  #HEADER .gnavi>ul>li.toggle:hover .child>li {
    list-style: none;
    float: none;
    border-bottom: #d5d5d5 1px solid
  }

  #HEADER .gnavi>ul>li.toggle:hover .child>li:last-child {
    border: none
  }

  #HEADER .gnavi>ul>li.toggle:hover .child>li a {
    display: block;
    background: #f2f2f2;
    background: linear-gradient(to bottom, #fff 0, #f2f2f2 100%);
    padding: 12px 0
  }
}

@media screen and (max-width:768px) {
  #HEADER .gnavi {
    width: 64px;
    height: 44px;
    background: url(../../images/common/arrow_white.png) #399121;
    background: linear-gradient(to bottom, #33b0bd 0, #288d97 100%);
    border: 1px solid #288d97;
    float: right;
    margin: 10px 12px 0 0;
    border-radius: 6px
  }

  #HEADER .gnavi:before {
    content: '';
    display: block;
    width: 64px;
    height: 44px;
    background: url(../../images/common/sp_nav_2x.png) no-repeat;
    -ms-background-size: 128px;
    background-size: 128px
  }

  #HEADER .gnavi.addClose {
    background: #fff;
    background: linear-gradient(to bottom, #fff 0, #ededed 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#ededed', GradientType=0);
    border: 1px solid #d5d5d5
  }

  #HEADER .gnavi.addClose:before {
    background: url(../../images/common/sp_nav_2x.png) -64px 0 no-repeat;
    -ms-background-size: 128px;
    background-size: 128px
  }

  #HEADER .gnavi>ul {
    overflow: auto;
    top: 64px
  }

  #HEADER .gnavi>ul>li {
    width: 100%;
    float: none;
    padding: 0;
    text-align: left;
    font-size: 15px;
    line-height: 1.5
  }

  #HEADER .gnavi>ul>li a {
    padding: 16px 12px;
    border-left: none;
    background: url(../../images/common/arrow_green.png) right 12px center no-repeat #FFF;
    -ms-background-size: 6px;
    background-size: 6px
  }

  #HEADER .gnavi>ul>li a:hover {
    opacity: 1;
    background: url(../../images/common/arrow_green.png) right 10px center no-repeat #FFF;
    -ms-background-size: 6px;
    background-size: 6px
  }

  #HEADER .gnavi>ul>li:last-child a {
    color: #151515;
    padding: 16px 12px
  }

  #HEADER .gnavi>ul>li:last-child a br {
    display: none
  }

  #HEADER .gnavi>ul>li.toggle .trigger {
    padding: 12px;
    background: url(../../images/common/arrow_green_down.png) right 12px center no-repeat #FFF;
    -ms-background-size: 10px;
    background-size: 10px;
    border-left: none
  }

  #HEADER .gnavi>ul>li.toggle .trigger.addClose {
    background: url(../../images/common/arrow_white_down.png) right 12px center no-repeat #33b0bd;
    -ms-background-size: 10px;
    background-size: 10px;
    color: #FFF
  }

  #HEADER .gnavi>ul>li.toggle .child {
    position: relative;
    top: 0;
    left: 0;
    box-shadow: none
  }

  #HEADER .gnavi>ul>li.toggle .child li a {
    background-color: #f2f2f2
  }
}

#FOOTER {
  text-align: center
}

@media screen and (min-width:769px) {
  #FOOTER {
    width: 100%;
    height: auto;
    position: relative;
    top: 0;
    left: 0;
    padding: 70px 30px 30px;
    background: #deeef3;
    z-index: 1
  }

  #FOOTER .fnav {
    text-align: center;
    padding: 0
  }

  #FOOTER .fnav li {
    list-style: none;
    margin-top: 0;
    display: inline-block;
    margin-left: 0
  }

  #FOOTER .fnav li:after {
    content: "";
    display: inline-block;
    margin-left: 0;
    color: #555
  }

  #FOOTER .fnav li:last-child:after {
    display: none
  }

  #FOOTER .fnav li:first-child {
    margin-left: 0
  }

  #FOOTER .copy {
    display: block;
    font-size: 11px;
    color: #000;
    padding: 0;
    float: none
  }
}

@media screen and (max-width:768px) {
  #FOOTER {
    width: 100%;
    height: auto;
    position: relative;
    top: 0;
    left: 0;
    padding: 30px 12px;
    background: #deeef3;
    ;
    z-index: 1
  }

  #FOOTER .fnav {
    text-align: center;
    padding: 0;
    border: 1px solid #DDD;
    border-radius: 6px;
    overflow: hidden
  }

  #FOOTER .fnav li {
    list-style: none;
    float: none;
    text-align: left;
    display: block;
    margin: 0;
    padding: 0;
    border-bottom: #DDD 1px solid
  }

  #FOOTER .fnav li:first-child {
    margin-left: 0
  }

  #FOOTER .fnav li:last-child {
    border: none
  }

  #FOOTER .fnav li a {
    background: #EEE;
    color: #151515;
    display: block;
    padding: 12px
  }

  #FOOTER .fnav li a:hover {
    opacity: .9
  }

  #FOOTER .copy {
    display: block;
    font-size: 10px;
    color: #000;
    padding: 20px 0 0;
    text-align: center
  }
}

#FOOTER .fnav, .INDEX.second dl dd ul {
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  -o-flex-flow: row wrap
}

#FOOTER .fnav {
  display: flex;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between
}

#FOOTER .fnav li {
  width: 20%
}

#FOOTER .fnav li a {
  display: block;
  text-align: left;
  margin: 0 0 8px;
  font-size: 14px
}

#FOOTER .fnav li a:last-child {
  margin-bottom: 0
}

@media screen and (max-width:768px) {
  #FOOTER .fnav li {
    width: 100%
  }

  #FOOTER .fnav li a {
    margin-bottom: 0;
    border-bottom: 1px solid #d5d5d5;
    background: url(../../images/common/arrow_gray.png) right 12px center no-repeat #FFF;
    -ms-background-size: 6px;
    background-size: 6px
  }

  #FOOTER .fnav li a:last-child {
    border-bottom: none
  }
}

#FOOTER .copy {
  display: inline-block;
  padding-bottom: 30px
}

#FOOTER .copy:before {
  content: "";
  width: 255px;
  height: 30px;
  background: url(../../images/common/logo.png) no-repeat;
  -ms-background-size: 255px;
  background-size: 255px;
  display: block;
  margin: 0 auto 12px
}

@media screen and (max-width:768px) {
  #FOOTER .copy {
    display: block;
    margin: 15px 0 0;
    padding: 10px 0 0
  }
}

#FOOTER a {
  color: #151515
}

#pageup {
  position: absolute;
  top: -58px;
  left: 50%;
  transform: translateX(-50%) translateY(0)
}

#pageup img {
  width: 152px
}

#sp-contact {
  display: none
}

@media screen and (max-width:768px) {
  #sp-contact {
    display: block;
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    background: rgba(255, 255, 255, .88);
    box-shadow: 0 0 8px rgba(0, 0, 0, .32);
    padding: 12px;
    z-index: 5;
    transition: all .3s ease-in-out
  }

  #sp-contact.remove {
    opacity: 0;
    bottom: -80px
  }

  #sp-contact a {
    display: block;
    background: #b5292b;
    background: linear-gradient(to bottom, #b5292b 0, #ED7D31 100%);
    color: #FFF;
    text-align: center;
    padding: 8px 0;
    font-weight: 700;
    font-size: 15px;
    float: left;
    width: 75%;
    border: 1px solid #ED7D31;
    border-radius: 8px
  }

  #sp-contact a.close {
    width: 22%;
    float: right;
    background: #fff;
    background: linear-gradient(to bottom, #fff 0, #e5e5e5 100%);
    border: 1px solid #d5d5d5;
    color: #666
  }
}

@media screen and (min-width:769px) {
  #firstView #slider ul li, #firstView .banner ul li {
    list-style: none
  }

  #firstView .display {
    width: 99vw;
  }

/**  #firstView {
    background: url(../../images/index/slider02.jpg) center repeat-x;
    -ms-background-size: cover;
    background-size: cover;
  }
**/

  #firstView #slider {
    /**float: left; **/
    width: 99vw;
    margin: 0 auto;
  }

  #firstView #slider ul li img {
    max-width: 99vw;
  }

  #firstView #slider .slick-next, #firstView #slider .slick-prev {
    width: 45px;
    height: 45px;
    z-index: 10
  }

  #firstView #slider .slick-prev {
    left: 0
  }

  #firstView #slider .slick-prev:before {
    content: url(../../images/index/prev.png)
  }

  #firstView #slider .slick-next {
    right: 0
  }

  #firstView #slider .slick-next:before {
    content: url(../../images/index/next.png)
  }

  .banner {
    width: 99vw;
    /** float: right **/
    margin: 0 auto;
  }

  .banner ul {
    display: flex;
  }

  .banner ul li {
    width: 33vw;
    /** height: 400px; **/
    list-style: none;
  }

  .banner ul li img {
    width: 100%;
  }

  #firstView .listable {
    background: #f2f2f2;
    background: linear-gradient(to bottom, #fff 0, #f2f2f2 100%);
    border-bottom: rgba(0, 0, 0, .08) 1px solid
  }

  #firstView .listable ul li {
    width: 16.666%;
    float: left;
    list-style: none;
    border-left: rgba(0, 0, 0, .08) 1px solid
  }

  #firstView .listable ul li:last-child {
    border-right: rgba(0, 0, 0, .08) 1px solid
  }

  #firstView .listable ul li a {
    display: block;
    color: #151515;
    font-size: 18px;
    padding: 16px 0;
    text-align: center;
    border-bottom: #1a752e 4px solid
  }

  #firstView .listable ul li:nth-child(2n+2)>a {
    border-bottom: #1f8e38 4px solid
  }
}

@media screen and (max-width:768px) {
  #firstView {
    background: 0 0
  }

  #firstView .banner ul li, #firstView .listable ul li {
    list-style: none;
    background: linear-gradient(to bottom, #33b0bd 0, #288d97 100%);
  }

  #firstView img {
    max-width: 100%;
    height: auto
  }

  #firstView #slider {
    float: none;
    width: 100%
  }

  #firstView .banner {
    width: auto;
    float: none;
    padding: 8px
  }

  #firstView .banner ul {
    display: -moz-flex;
    display: -o-flex;
    display: -ms-flex;
    display: flex;
    -o-flex-flow: row wrap;
    flex-flow: row wrap;
    -o-justify-content: space-between;
    -ms-justify-content: space-between;
    -moz-justify-content: space-between;
    justify-content: space-between
  }

  #firstView .banner ul li {
    border-right: 1px solid #288d97;
  }

  #firstView .banner ul li figure {
    display: none
  }

  #firstView .banner ul li a {
    display: block;
    padding: 13px 0;
    color: #FFF;
    text-align: center
  }

  #firstView .banner ul li a:before {
    font-size: 12px;
    font-weight: 700
  }

  #firstView .banner ul li:first-child, #firstView .banner ul li:last-child {
    width: 31%
  }

  #firstView .banner ul li:nth-child(2) {
    width: 38%
  }

  #firstView .banner ul li:first-child>a:before {
    content: "JA虹の友"
  }

  #firstView .banner ul li:nth-child(2)>a:before {
    content: "供花物のご注文"
  }

  #firstView .banner ul li:nth-child(3)>a {
    border-right: none
  }

  #firstView .banner ul li:nth-child(3)>a:before {
    content: "採用情報"
  }

  #firstView .listable {
    padding: 0 8px 8px
  }

  #firstView .listable.spMes:after {
    content: 'JA葬祭はどなたにもご利用いただけます。';
    display: block;
    font-size: 16px;
    padding: 15px 0 0;
    text-align: center
  }

  #firstView .listable ul {
    display: -moz-flex;
    display: -o-flex;
    display: -ms-flex;
    display: flex;
    -o-flex-flow: row wrap;
    flex-flow: row wrap;
    -o-justify-content: space-between;
    -ms-justify-content: space-between;
    -moz-justify-content: space-between;
    justify-content: space-between
  }

  #firstView .listable ul li {
    float: none;
    border-right: #166427 1px solid;
    width: 50%
  }

  #firstView .listable ul li:nth-child(2n+2) {
    border: none
  }

  #firstView .listable ul li:last-child {
    border-right: none
  }

  #firstView .listable ul li a {
    display: block;
    font-size: 13px;
    padding: 18px 0;
    text-align: center;
    color: #FFF;
    line-height: 1.4;
    -ms-background-size: 7px;
    background-size: 7px
  }
}

.sp-slider-wrapper { display: none; }
@media screen and (max-width: 767px) {
    .sp-slider-wrapper { display: block; }
    #firstView .swiper-wrapper.pc { display: none; }
}

.INDEX.first {
  background: url(../../images/index/1st_bg.jpg) repeat-x;
  -ms-background-size: cover;
  background-size: cover;
  margin-top: -4px;
  position: relative;
  z-index: 2;
}

.INDEX.first.top {
  /** border-top: 10px solid #deeef3; **/
}

.INDEX.first ul li {
  -o-box-shadow: 0 0 10px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 10px rgba(0, 0, 0, .15);
  box-shadow: 0 0 10px rgba(0, 0, 0, .15)
}

@media screen and (min-width:769px) {
  .INDEX.first ul li {
    list-style: none;
    width: 23.5%;
    float: left;
    margin: 0 2% 2% 0
  }

  .INDEX.first ul li:nth-child(4n+1) {
    clear: both
  }

  .INDEX.first ul li:nth-child(4n+4) {
    margin-right: 0
  }

  .INDEX.first ul li:nth-last-child(-n+4) {
    margin-bottom: 0
  }
}

.INDEX.first ul li figure {
  position: relative;
  top: 0;
  left: 0
}

.INDEX.first ul li figure:after {
  content: '※イメージ画像です';
  position: absolute;
  right: 8px;
  bottom: 1px;
  color: #FFF;
  font-weight: 700;
  text-shadow: 0 0 4px rgba(0, 0, 0, .9), 0 0 4px rgba(0, 0, 0, .9);
  font-size: 12px;
}

.INDEX.first ul li dl {
  background: #fff;
  padding: 15px;
  height: 274px
}

@media screen and (max-width:768px) {
  .INDEX.first ul li {
    list-style: none;
    margin: 0 auto 20px auto;
    max-width: 520px;
  }

  .INDEX.first ul li dl {
    height: auto
  }
}

.INDEX.first ul li dl.length {
  position: relative;
  top: 0;
  left: 0
}

.INDEX.first ul li dl.length:before {
  content: attr(data-leng);
  background: #c1b644;
  color: #FFF;
  padding: 0 12px;
  border-radius: 4px;
  position: absolute;
  top: 8px;
  right: 8px;
  font-size: 12px
}

.INDEX.first ul li dl dt {
  text-align: center;
  font-size: 30px;
  font-weight: 600;
  padding: 0 0 5px;
  margin: 0 0 5px;
  border-bottom: 1px solid #d5d5d5;
  color: #ED7D31;
  line-height: 1.5;
}

.INDEX.first ul li.st-c dl dt {
  color: #1f8e38;
}

.INDEX.first ul li.fam-c dl dt {
  color: #3c5099;
}

.INDEX.first ul li.nor-c dl dt {
  color: #7f3bb3;
}

.INDEX.first ul li dl dt span {
  display: block;
  font-size: 13px;
  font-weight: 400;
  color: #000 !important;
}

.INDEX.first ul li dl dd {
  text-align: center;
  font-weight: bold;
  font-size: 7x
}

.INDEX.first ul li dl dd.price {
  color: #ED7D31;
  margin-bottom: 5px;
  line-height: 1.2;
  padding: 9px 0 15px;
}

.INDEX.first ul li dl dd.price i {
  font-style: normal;
  font-size: 34px;
  font-weight: bold;
}

.INDEX.first ul li dl dd.price em {
  font-style: normal;
  font-size: 16px;
  display: inline-block;
  margin-left: 5px;
  font-weight: normal;
}

.INDEX.first ul li dl dd.comment {
  margin: 8px 0 0;
  font-size: 14px;
  font-weight: normal;
}

.INDEX.first ul li dl dd.comment i {
  color: #967121;
  text-decoration: underline
}

.INDEX.first .text {
  margin: 50px 0 0;
  text-align: center;
  font-size: 24px
}

.INDEX.first .text .over {
  margin: 24px 0 0
}

@media screen and (max-width:768px) {
  .INDEX.first .text {
    font-size: 16px;
    margin-top: 20px
  }
}

.INDEX.first .text span {
  color: #901b26;
  background: url(../../images/index/line.png) left bottom repeat-x
}

/**/

.top-area-wrap {
  display: flex;
}


.chiba-left {
  order: 1;
}

.chiba-img {
  padding: 10px 15px;
  max-width: 560px;
}

.chiba-img img {
  height: auto;
  ;
}

.INDEX.second {
  background: url(../../images/index/2nd_bg.jpg) center
}

.INDEX.second dl {
  -o-box-shadow: 0 0 8px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 8px rgba(0, 0, 0, .15);
  box-shadow: 0 0 8px rgba(0, 0, 0, .15);
  border-radius: 8px;
  margin: 0 0 30px;
  max-width: 360px;
  width: 100%;
}



.INDEX.second dl dt {
  border-radius: 8px 8px 0 0;
  background: #f2f2f2;
  background: linear-gradient(to bottom, #fff 0, #f2f2f2 100%);
  font-size: 18px;
  padding: 15px 20px;
  position: relative
}

.INDEX.second dl dt a {
  color: #151515
}

.INDEX.second dl dt i {
  padding-left: 10px;
  font-weight: bold;
}

.INDEX.second dl dt i.red {
  border-left: 4px solid #1AB5A6
}

.INDEX.second dl dt i.green {
  border-left: 4px solid #3383C5
}

.INDEX.second dl dt i.yellow {
  border-left: 4px solid #7CC170
}

.INDEX.second dl dt i.rbrown {
  border-left: 4px solid #F5AB1A
}

.INDEX.second dl dt i.ygreen {
  border-left: 4px solid #EF8255
}

.INDEX.second dl dt i.brown {
  border-left: 4px solid #C3D956
}

@media screen and (max-width:768px) {
  .INDEX.second dl {
    margin-bottom: 15px
  }

  .INDEX.second dl dt {
    font-size: 15px;
    padding: 10px
  }

  .INDEX.second dl dt i {
    display: block;
    line-height: 1.4;
    margin: 0 0 5px
  }
}

.INDEX.second dl dt span {
  color: #ED7D31;
  font-size: 20px;
  font-weight: 700;
  background: url(../../images/common/icn_free_2x.png) left center no-repeat;
  -ms-background-size: 30px 19px;
  background-size: 30px 19px;
  padding-left: 40px;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateX(0) translateY(-50%)
}

.INDEX.second dl dt span a {
  color: #ED7D31
}

@media screen and (max-width:768px) {
  .INDEX.second dl dt span {
    -ms-background-size: 20px 13px;
    background-size: 20px 13px;
    right: 10px;
    padding-left: 28px
  }
}

.INDEX.second dl dd {
  border-radius: 0 0 8px 8px;
  background: #f8f8f8;
  overflow: hidden
}

.INDEX.second dl dd a {
  color: #1b3490;
  font-weight: bold;
}

.INDEX.second dl dd ul {
  overflow: hidden;
  display: flex;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  justify-content: flex-start
}

.INDEX.second dl dd ul li {
  list-style: none;
  padding: 10px 0;
  text-align: center;
  font-size: 14.5px;
  background: #fff;
  border-right: 1px solid #d5d5d5;
  border-bottom: #d5d5d5 1px solid;
}

@media screen and (min-width:769px) {
  .INDEX.second dl dd ul li {
    width: 120px
  }

}

@media screen and (max-width:768px) {

  .top-area-wrap {
    flex-direction: column;
  }

  .INDEX.second dl {
    max-width: none;
    ;
  }

  .chiba-img {
    max-width: none;
    order: 3;
  }

  .INDEX.second dl dd ul li {
    width: 50%;
    padding: 10px 0;
    border-bottom: #d5d5d5 1px solid
  }

  .INDEX.second dl dd ul li:nth-child(2n+2) {
    border-right: none
  }

  .INDEX.second dl dd ul li:nth-child(n+3) {
    border-bottom: none
  }

  .INDEX.second dl dd ul li:nth-child(5) {
    border-top: #d5d5d5 1px solid
  }
}

.INDEX.second dl dd ul.underTrue li {
  border-bottom: #d5d5d5 1px solid
}

.INDEX.third #slick ul li {
  margin: 0 1px 0 0;
  position: relative
}

.INDEX.third #slick ul li figcaption {
  width: 100%;
  padding: 6px 0;
  text-align: center;
  background: rgba(0, 0, 0, .35);
  color: #fff;
  font-size: 16px;
  position: absolute;
  bottom: 0;
  left: 0
}

.INDEX.four {
  background: #f5f5f5;
  overflow: hidden
}

.INDEX.four .msg {
  width: 80%;
  margin: 0 auto;
  font-size: 15px
}

@media screen and (max-width:768px) {
  .INDEX.second dl dd ul.underTrue li {
    border-bottom: #d5d5d5 1px solid
  }

  .INDEX.second dl dd ul.underTrue li:nth-child(n+3) {
    border-top: none
  }

   .INDEX.second dl dd ul li:nth-child(n+3) {
    border-bottom: #d5d5d5 1px solid
  }

  .INDEX.four .msg {
    width: auto
  }
}

.INDEX.four dd.soon {
  position: relative;
  top: 0;
  left: 0
}

.INDEX.four dd.soon:after {
  content: 'coming soon';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  font-weight: 700;
  color: #bbb;
  background: #FFF
}

.INDEX.four .LeftContent, .INDEX.four .RightContent {
  float: left;
  width: 48%;
}

.INDEX.four .LeftContent {
  position: absolute;
}

.questionnaire_banner {
  position: relative;
  text-align: center;
}

@media screen and (max-width:768px) {
  .INDEX.four .LeftContent, .INDEX.four .RightContent {
    float: none !important;
    width: auto;
    margin-bottom: 30px;
    display: contents;
  }

  .questionnaire_banner {
    position: static;
    width: fit-content;
    margin: 0px auto 30px;
    bottom: auto;
  }

  .INDEX.four .RightContent dl:first-of-type {
    margin-top: 30px;
  }

  .INDEX.four .RightContent {
    margin-top: 30px;
  }


}

.INDEX.four .LeftContent dl dt, .INDEX.four .RightContent dl dt {
  font-size: 20px;
  margin: 0 0 10px
}

.INDEX.four .LeftContent dl dt:before, .INDEX.four .RightContent dl dt:before {
  content: "◆";
  color: #ED7D31;
  margin-right: 7px
}

.INDEX.four .LeftContent dl dt a, .INDEX.four .RightContent dl dt a {
  color: #151515
}

.INDEX.four .LeftContent dl dd, .INDEX.four .RightContent dl dd {
  overflow-y: scroll;
  background: #fff;
  height: 175px
}

.INDEX.four .LeftContent dl dd {
  margin-bottom: 30px;
}

.INDEX.four .LeftContent dl dd ul, .INDEX.four .RightContent dl dd ul {
  margin: 15px 0 0
}

.INDEX.four .LeftContent dl dd ul li, .INDEX.four .RightContent dl dd ul li {
  list-style: none;
  padding: 0 0 15px;
  margin: 0 20px 15px;
  border-bottom: 1px solid #d5d5d5;
}

@media screen and (max-width:768px) {
  .INDEX.four .LeftContent dl dt, .INDEX.four .RightContent dl dt {
    font-size: 18px
  }

  .INDEX.four .LeftContent dl dd, .INDEX.four .RightContent dl dd {
    max-height: 175px
  }

  .INDEX.four .LeftContent dl dd ul li, .INDEX.four .RightContent dl dd ul li {
    margin: 0 10px 10px;
    padding-bottom: 10px
  }
}

.INDEX.four .LeftContent dl dd ul li time, .INDEX.four .RightContent dl dd ul li time {
  display: inline-block;
  margin-right: 10px;
  font-size: 12px;
  color: #fff;
  background: #c1b644;
  padding: 5px 8px
}

.INDEX.four .LeftContent dl dd ul li a, .INDEX.four .RightContent dl dd ul li a {
  color: #151515
}

.INDEX.four .RightContent {
  float: right
}

.INDEX.four .RightContent dl:first-of-type {
  margin-bottom: 30px
}

.INDEX.four .RightContent dl dt:before {
  color: #33b0bd
}

.INDEX.four .RightContent dl dd {
  height: 175px
}

.INDEX.four .RightContent dl dd ul li time {
  background: #aaa
}

@media screen and (max-width:768px) {
  .INDEX.four .RightContent {
    float: none;
    width: auto
  }

  .INDEX.tel {
    padding-bottom: 50px
  }
}

.INDEX.tel h3 {
  text-align: left;
  padding: 0 0 10px;
  border-bottom: 1px solid #d5d5d5;
  line-height: 1;
  font-size: 24px;
  position: relative
}

.INDEX.tel h3 img {
  display: inline-block;
  width: 170px;
  margin: 0 20px 5px 0
}

@media screen and (max-width:768px) {
  .INDEX.tel h3 {
    text-align: center;
    font-size: 18px
  }

  .INDEX.tel h3 img {
    display: block;
    margin: 0 auto
  }
}

.INDEX.tel h3 i {
  color: #21963b;
  font-size: 40px
}

@media screen and (max-width:768px) {
  .INDEX.tel h3 i {
    font-size: 30px
  }
}

.INDEX.tel h3 .button {
  display: inline-block;
  font-size: 16px;
  padding: 15px 0;
  width: 260px;
  text-align: center
}

.INDEX.tel h3 .button:first-of-type {
  position: absolute;
  bottom: 10px;
  right: 280px
}

.INDEX.tel h3 .button:last-of-type {
  position: absolute;
  bottom: 10px;
  right: 0
}

@media screen and (max-width:768px) {
  .INDEX.tel h3 .button {
    display: block;
    position: static !important;
    width: auto;
    margin: 5px 0
  }

  .INDEX.tel h3 .button:last-of-type {
    margin-bottom: 0
  }
}

.INDEX.tel .OPEN {
  display: block;
  padding: 0
}

.INDEX.tel .general {
  border: 8px solid #f2f2f2;
  border-radius: 8px;
  text-align: center;
  font-size: 22px;
  margin: 30px 0;
  padding: 20px
}

.INDEX.tel .general span {
  display: inline-block;
  background: url(../../images/common/icn_free_2x.png) left center no-repeat;
  -ms-background-size: 39px 25px;
  background-size: 39px 25px;
  padding-left: 45px;
  margin-left: 15px;
  color: #ED7D31;
  font-size: 30px
}

.INDEX.tel .txtC {
  text-align: center;
  font-size: 18px;
  margin: 32px 0
}

@media screen and (max-width:768px) {
  .INDEX.tel .general {
    padding: 15px
  }

  .INDEX.tel .txtC {
    margin-bottom: 0;
    font-size: 16px
  }
}

.COMPANY .first a.link {
  background: url(../../images/common/icon_data_2x.png) right center no-repeat;
  -ms-background-size: 11px 9px;
  background-size: 11px 9px;
  padding-right: 20px
}

.COMPANY .first .tableStyle {
  font-size: 15px
}

.COMPANY .first .tableStyle th {
  text-align: center
}

.COMPANY .first .right {
  text-align: right;
  margin: 30px 0 0
}

.COMPANY .first .red {
  color: #33b0bd
}

.COMPANY .second {
  background: url(../../images/index/2nd_bg.jpg)
}

.COMPANY .second ul {
  overflow: hidden;
  padding-bottom: 60px
}

.COMPANY .second ul li {
  list-style: none;
  -o-box-shadow: 0 0 8px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 8px rgba(0, 0, 0, .15);
  box-shadow: 0 0 8px rgba(0, 0, 0, .15);
  border: 1px solid #d5d5d5;
  background: #fff;
  padding: 15px;
  margin: 0 0 30px;
  font-size: 17px;
  position: relative
}

.COMPANY .second ul li:after {
  content: "";
  width: 0;
  height: 0;
  border: 21px solid transparent;
  border-top: 12px solid #d5d5d5;
  position: absolute;
  bottom: -34px;
  left: 50%;
  transform: translateX(-50%) translateY(0)
}

.COMPANY .second ul li:last-child {
  margin-bottom: 0
}

.COMPANY .second ul li:last-child:after {
  content: none
}

.COMPANY .second ul li span {
  display: inline-block;
  width: 150px;
  text-align: center;
  color: #fff;
  background: #1e7431;
  margin-right: 20px;
  padding: 3px 0
}

@media screen and (max-width:768px) {
  .COMPANY .first .tableStyle {
    font-size: 12px
  }

  .COMPANY .second ul {
    padding: 0
  }

  .COMPANY .second ul li {
    font-size: 14px;
    margin: 0 0 20px;
    padding: 10px
  }

  .COMPANY .second ul li span {
    display: block;
    width: auto;
    margin: 0 0 5px
  }
}

.MEMBER .first .banner {
  margin: 0 0 60px
}

.MEMBER .first .context {
  font-size: 16px;
  text-align: center
}

.MEMBER .third {
  background: #f5f5f5
}

.MEMBER .third ul {
  overflow: hidden;
  margin: 0 auto 25px
}

.MEMBER .third ul li {
  -o-box-shadow: 0 0 15px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 15px rgba(0, 0, 0, .15);
  box-shadow: 0 0 15px rgba(0, 0, 0, .15);
  border-radius: 8px;
  text-align: center;
  border: 1px solid #d5d5d5;
  padding: 25px 0;
  min-height: 390px;
  background: #fff
}

@media screen and (min-width:769px) {
  .MEMBER .third ul li {
    list-style: none;
    width: 32%;
    float: left;
    margin: 0 2% 2% 0
  }

  .MEMBER .third ul li:nth-child(3n+1) {
    clear: both
  }

  .MEMBER .third ul li:nth-child(3n+3) {
    margin-right: 0
  }

  .MEMBER .third ul li:nth-last-child(-n+3) {
    margin-bottom: 0
  }
}

.MEMBER .third ul li figure {
  width: 250px;
  margin: 0 auto 20px
}

.MEMBER .third ul li dl dt {
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 20px
}

.MEMBER .third ul li dl dt:before {
  content: attr(data-text);
  display: block;
  font-size: 15px;
  color: #fff;
  background: #33b0bd;
  width: 35%;
  border-radius: 13px;
  margin: 0 auto 15px
}

.MEMBER .third ul li dl dd {
  border-top: 1px solid #d5d5d5;
  padding: 20px 20px 0;
  text-align: left;
  min-height: 200px
}

.MEMBER .third p {
  text-align: right;
  font-size: 13px
}

.MEMBER .four .discount {
  border: 5px solid #ccbea5;
  padding: 2px;
  margin: 0 0 35px
}

.MEMBER .four .discount dl {
  border: 1px solid #ccbea5;
  padding: 25px 85px
}

.MEMBER .four .discount dl dt {
  border-bottom: 1px solid #ccbea5;
  text-align: center;
  padding: 0 0 15px;
  margin: 0 0 15px
}

.MEMBER .four .discount dl dt strong {
  display: block;
  color: #ED7D31;
  font-size: 26px;
  line-height: 1.2
}

.MEMBER .four .fourClum>li {
  box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  min-height: 365px
}

@media screen and (min-width:769px) {
  .MEMBER .four .fourClum>li {
    list-style: none;
    width: 23.5%;
    float: left;
    margin: 0 2% 2% 0
  }

  .MEMBER .four .fourClum>li:nth-child(4n+1) {
    clear: both
  }

  .MEMBER .four .fourClum>li:nth-child(4n+4) {
    margin-right: 0
  }

  .MEMBER .four .fourClum>li:nth-last-child(-n+4) {
    margin-bottom: 0
  }
}

.MEMBER .four .fourClum>li dl {
  padding: 15px;
  text-align: center
}

.MEMBER .four .fourClum>li dl dt {
  border-bottom: 1px solid #d5d5d5;
  font-size: 22px;
  padding: 0 0 10px;
  margin: 0 0 15px;
  line-height: 1.4;
  min-height: 71px
}

.MEMBER .four .fourClum>li dl dd {
  font-size: 15px
}

.MEMBER .addFor hr {
  border-width: 2px 0 0;
  border-style: solid;
  margin: -60px 0 50px
}

.MEMBER .addFor .flexClum {
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between
}

.MEMBER .addFor .flexClum li {
  list-style: none;
  width: 48.5%;
  margin: 0 0 20px;
  border: 8px solid #f2f2f2;
  padding: 15px
}

.MEMBER .addFor .flexClum li .box {
  margin: 0 0 12px
}

.MEMBER .addFor .flexClum li .box figure {
  width: 40%;
  float: left
}

.MEMBER .addFor .flexClum li .box dl {
  width: 56%;
  float: right
}

.MEMBER .addFor .flexClum li .box dl dt {
  color: #ED7D31;
  font-size: 23px;
  font-weight: 700;
  margin: 0 0 12px;
  padding: 0 0 8px;
  border-bottom: #d5d5d5 1px solid
}

.MEMBER .addFor .flexClum li .box dl dd {
  font-size: 16px
}

.MEMBER .addFor .flexClum dl.ptn {
  margin: 0 0 8px
}

.MEMBER .addFor .flexClum dl.ptn:last-of-type {
  margin: 0
}

.MEMBER .addFor .flexClum dl.ptn dt {
  font-size: 20px;
  /*font-weight: 700;*/
  color: #ED7D31;
  line-height: 1.5;
  margin: 0 0 4px
}

.MEMBER .addFor .flexClum dl.ptn dd {
  line-height: 1.5
}

.MEMBER .addFor .flexClum dl.ptn.str dt {
  margin: 0
}

.MEMBER .addFor .flexClum dl.ptn.str dd {
  font-size: 20px;
  /*font-weight: 700;*/
  color: #ED7D31;
  line-height: 1.5
}

.MEMBER .addFor .flexClum dl.ptn.squere {
  padding-left: 20px;
  position: relative;
  top: 0;
  left: 0
}

.MEMBER .addFor .flexClum dl.ptn.squere:before {
  content: '';
  width: 10px;
  height: 10px;
  position: absolute;
  top: 8px;
  left: 0;
  background: #ED7D31;
  transform: rotate(45deg)
}

.MEMBER .addFor .flexClum p.str {
  font-size: 20px;
  /*font-weight: 700;*/
  color: #ED7D31;
  line-height: 1.5
}

.MEMBER .addFor .description {
  border: 8px solid #f2f2f2;
  padding: 20px
}

.MEMBER .addFor .description dl {
  margin: 0 0 20px
}

.MEMBER .addFor .description dl:last-of-type {
  margin: 0
}

.MEMBER .addFor .description dl dt {
  font-size: 20px;
  font-weight: 700;
  position: relative;
  top: 0;
  left: 0;
  padding: 0 0 0 24px
}

.MEMBER .addFor .description dl dt:before {
  content: '';
  width: 14px;
  height: 14px;
  background: #33b0bd;
  position: absolute;
  top: 9px;
  left: 0;
  transform: rotate(45deg)
}

.SERCHDETAIL .detail>dt span, .SERCHDETAIL .detail>dt:before {
  transform: translateX(0) translateY(-50%);
  top: 50%;
  position: absolute
}

.MEMBER .addFor .description dl dd {
  margin: 4px 0 0
}

.MEMBER .second {
  background: #f5f5f5
}

.MEMBER .second h3 span {
  display: block;
  margin: 10px 0 0;
  font-size: 15px
}

.MEMBER .second h4 span {
  display: inline-block;
  margin: 0 0 0 10px;
  font-size: 14px
}

.MEMBER .second .context {
  font-size: 15px;
  margin: 0 0 30px
}

.MEMBER .second .tenpo {
  overflow: hidden;
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  -o-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  box-shadow: 0 0 5px rgba(0, 0, 0, .15)
}

.MEMBER .second .tenpo li {
  list-style: none;
  width: 20%;
  background: #fff;
  color: #624040;
  text-align: center;
  padding: 15px;
  border-bottom: 1px solid #d5d5d5;
  border-right: 1px solid #d5d5d5
}

.MEMBER .second .tenpo li strong {
  display: block;
  font-size: 18px
}

.MEMBER .second .OPEN {
  padding: 40px 0 0;
  display: block;
  overflow: hidden
}

.MEMBER .second .OPEN dl dt {
  font-size: 18px;
  text-align: center
}

.MEMBER .second .OPEN dl dd {
  background: #fff
}

@media screen and (max-width:768px) {
  .MEMBER .first .banner {
    margin: 0 0 30px
  }

  .MEMBER .first .context {
    font-size: 15px
  }

  .MEMBER .third ul {
    margin-bottom: 0
  }

  .MEMBER .third ul>li {
    list-style: none;
    min-height: inherit;
    padding: 15px 0;
    margin: 0 0 4%
  }

  .MEMBER .third ul>li figure {
    width: 40%;
    margin: 0 auto
  }

  .MEMBER .third ul>li dl {
    margin: 10px 0 0
  }

  .MEMBER .third ul>li dl dt {
    font-size: 16px;
    margin: 0 0 4%
  }

  .MEMBER .third ul>li dl dt:before {
    font-size: 13px;
    margin: 0 auto 5px
  }

  .MEMBER .third ul>li dl dd {
    min-height: inherit
  }

  .MEMBER .four .discount dl {
    padding: 15px
  }

  .MEMBER .four .discount dl dt {
    padding: 0 0 2%;
    margin: 0 0 4%
  }

  .MEMBER .four .discount dl dt strong {
    font-size: 24px
  }

  .MEMBER .four .fourClum>li {
    list-style: none;
    margin: 0 0 4%;
    overflow: hidden;
    min-height: inherit
  }

  .MEMBER .four .fourClum>li:last-child {
    margin-bottom: 0
  }

  .MEMBER .four .fourClum>li dl dt {
    min-height: inherit;
    font-size: 15px;
    padding: 0 0 2%;
    margin: 0 0 2%
  }

  .MEMBER .four .fourClum>li dl dd {
    font-size: 12px
  }

  .MEMBER .addFor .flexClum>li {
    width: 100%;
    margin: 0 0 4%
  }

  .MEMBER .addFor .flexClum>li .box {
    margin: 0 0 4%
  }

  .MEMBER .addFor .flexClum>li .box figure {
    float: none;
    width: 100%;
    margin: 0 0 4%
  }

  .MEMBER .addFor .flexClum>li .box dl {
    float: none;
    width: auto
  }

  .MEMBER .addFor .flexClum>li .box dl dt {
    font-size: 18px;
    line-height: 1.4;
    padding: 0 0 5px;
    margin: 0 0 5px
  }

  .MEMBER .addFor .flexClum>li .box dl dd {
    font-size: 12px
  }

  .MEMBER .addFor .flexClum dl.ptn dt, .MEMBER .addFor .flexClum dl.ptn.str dd {
    font-size: 14px
  }

  .MEMBER .addFor .flexClum dl.ptn.squere:before {
    top: 5px
  }

  .MEMBER .addFor .flexClum p.str {
    font-size: 14px;
    font-size: 16px
  }

  .MEMBER .addFor .description {
    padding: 15px
  }

  .MEMBER .addFor .description dl dt {
    font-size: 16px
  }
}

.FAQ .faq {
  border: 1px solid #d5d5d5;
  -o-box-shadow: 0 0 15px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 15px rgba(0, 0, 0, .15);
  box-shadow: 0 0 15px rgba(0, 0, 0, .15);
  margin: 0 0 20px
}

.OFFERINGS .second .threeClum>li, .RELIEF dl {
  -o-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 5px rgba(0, 0, 0, .15)
}

.FAQ .faq dt {
  background: #f5f5f5;
  padding: 20px;
  font-size: 18px
}

.FAQ .faq dt:before {
  content: "Q";
  font-size: 24px;
  color: #fff;
  background: #33b0bd;
  padding: 0 12px;
  display: inline-block;
  margin-right: 18px
}

.FAQ .faq dd {
  padding: 20px
}

.FAQ .faq dd ul {
  margin: 20px 0 0
}

.FAQ .faq dd ul li {
  list-style: disc;
  margin: 0 0 0 20px
}

@media screen and (max-width:768px) {
  .FAQ .faq {
    margin: 0 0 4%
  }

  .FAQ .faq dt {
    font-size: 15px;
    padding: 15px
  }

  .FAQ .faq dt:before {
    font-size: 15px;
    padding: 0 8px;
    margin-right: 8px
  }
}

.OFFERINGS .bg {
  background: url(../../images/offerings/bg.png)
}

.OFFERINGS .btnArea {
  margin: 30px 0 40px;
  text-align: center
}

.OFFERINGS .btnArea .button {
  padding: 10px 20px;
  font-size: 24px
}

.OFFERINGS .btnArea span.fax {
  font-size: 20px;
  margin: 0 20px 0 0;
  display: inline-block
}

.OFFERINGS p.center {
  font-size: 16px;
  text-align: center;
  margin: 20px 0
}

.OFFERINGS .first p.top {
  font-size: 20px;
  text-align: center;
  font-weight: 600
}

.OFFERINGS .first .btnArea {
  margin-bottom: 0 !important
}

.OFFERINGS .second h3:after {
  font-size: 15px
}

.OFFERINGS .second .threeClum>li {
  box-shadow: 0 0 5px rgba(0, 0, 0, .15)
}

@media screen and (min-width:769px) {
  .OFFERINGS .second .threeClum>li {
    list-style: none;
    width: 30%;
    float: left;
    margin: 0 5% 5% 0
  }

  .OFFERINGS .second .threeClum>li:nth-child(3n+1) {
    clear: both
  }

  .OFFERINGS .second .threeClum>li:nth-child(3n+3) {
    margin-right: 0
  }

  .OFFERINGS .second .threeClum>li:nth-last-child(-n+3) {
    margin-bottom: 0
  }
}

.OFFERINGS .second .threeClum>li dl {
  background: #fff;
  padding: 20px;
  text-align: center
}

.OFFERINGS .second .threeClum>li dl dt {
  border-bottom: 1px solid #d5d5d5;
  font-size: 22px;
  color: #33b0bd;
  margin: 0 0 12px
}

.OFFERINGS .second .threeClum>li dl dd {
  font-size: 18px
}

.OFFERINGS .third.wrap {
  padding-bottom: 0
}

.OFFERINGS .third .btnArea {
  margin-bottom: 15px;
  margin-top: 0
}

.OFFERINGS .OPEN {
  display: block
}

.OFFERINGS .OPEN dl dd {
  line-height: 1.4
}

.OFFERINGS .OPEN dl dd.fax {
  display: block;
  padding-bottom: 0
}

.OFFERINGS .OPEN dl dd.fax span {
  font-size: 32px;
  background: 0 0;
  padding: 0
}

.OFFERINGS .OPEN dl dd.fax span:before {
  content: "FAX.";
  font-size: 26px
}

.OFFERINGS .OPEN dl dd span {
  font-size: 22px
}

@media screen and (max-width:768px) {
  .OFFERINGS .btnArea .button {
    font-size: 16px;
    display: block
  }

  .OFFERINGS .btnArea span.fax {
    display: block;
    margin: 0 0 2%
  }

  .OFFERINGS p.center {
    font-size: 14px;
    margin: 0 0 4%
  }

  .OFFERINGS .first p.top {
    font-size: 15px
  }

  .OFFERINGS .second h3:after {
    font-size: 13px
  }

  .OFFERINGS .second .threeClum>li {
    list-style: none;
    margin: 0 0 4%
  }

  .OFFERINGS .second .threeClum>li dl {
    padding: 8px 15px
  }

  .OFFERINGS .second .threeClum>li dl dt {
    font-size: 16px;
    margin: 0 0 2%
  }

  .OFFERINGS .second .threeClum>li dl dd {
    font-size: 14px
  }
}

.RELIEF dl {
  width: 90%;
  margin: 0 auto 45px;
  box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  border-radius: 4px;
  padding: 25px
}

.COLUMN .list>li, .PLAN.DETAIL .first .flex {
  -o-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 5px rgba(0, 0, 0, .15)
}

.RELIEF dl dt {
  font-size: 20px;
  color: #33b0bd;
  padding: 0 0 8px;
  margin: 0 0 20px;
  border-bottom: 1px solid #d5d5d5
}

.RELIEF dl dt:before {
  content: "◆";
  margin-right: 5px
}

.RELIEF .oneClum li {
  list-style: disc;
  font-size: 16px;
  margin: 0 0 8px 20px
}

@media screen and (max-width:768px) {
  .RELIEF dl {
    width: 100%;
    margin: 0 0 4%;
    padding: 15px
  }

  .RELIEF dl dt {
    font-size: 18px;
    padding: 0 0 2%;
    margin: 0 0 2%
  }

  .RELIEF .oneClum li {
    font-size: 14px
  }
}

.COLUMN .list>li {
  border: 1px solid #d5d5d5;
  box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  position: relative
}

@media screen and (min-width:769px) {
  .COLUMN .list>li {
    list-style: none;
    width: 49%;
    float: left;
    margin: 0 2% 2% 0
  }

  .COLUMN .list>li:nth-child(2n+1) {
    clear: both
  }

  .COLUMN .list>li:nth-child(2n+2) {
    margin-right: 0
  }

  .COLUMN .list>li:nth-last-child(-n+2) {
    margin-bottom: 0
  }
}

.COLUMN .list>li a {
  display: block;
  padding: 17px
}

.COLUMN .list>li a:after {
  content: "";
  background: url(../../images/common/arrow_gray.png) right 10px center no-repeat #f5f5f5;
  -ms-background-size: 9px 15px;
  background-size: 9px 15px;
  position: absolute;
  top: 0;
  right: 0;
  width: 32px;
  height: 100%
}

.COLUMN .list>li dl dt time, .COLUMN .pagenavi span {
  display: inline-block;
  background: #33b0bd;
  color: #fff
}

.COLUMN .list>li dl {
  padding-right: 30px;
  overflow: hidden
}

.COLUMN .list>li dl dt {
  clear: both;
  float: left;
  width: 60px
}

.COLUMN .list>li dl dt time {
  width: 60px;
  text-align: center;
  padding: 10px 0;
  line-height: 1.2
}

.COLUMN .list>li dl dd {
  margin-left: 80px
}

.COLUMN .pagenavi {
  margin: 60px 0;
  text-align: center
}

.COLUMN .pagenavi span {
  margin: 0 10px;
  padding: 5px 12px
}

.COLUMN .detail {
  width: 90%;
  margin: 0 auto
}

@media screen and (max-width:768px) {
  .COLUMN .list>li {
    list-style: none;
    margin: 0 0 4%
  }

  .COLUMN .list>li a {
    padding: 10px
  }

  .COLUMN .list>li dl dd {
    margin: 0 20px 0 70px
  }

  .COLUMN .detail {
    width: auto
  }

  .COLUMN .detail table {
    width: 100% !important;
    border: 1px solid #d5d5d5;
    border-collapse: collapse
  }
}

.VOICE h4:before {
  color: #ED7D31 !important
}

.VOICE .detail h4 time, .VOICE .list>li time, .VOICE .pagenavi span {
  background: #ED7D31 !important
}

.EVENT .list>li, .VOICE .list>li {
  list-style: none;
  padding: 20px 0;
  border-bottom: 1px solid #d5d5d5;
  background: url(../../images/common/arrow_gray.png) right center no-repeat;
  -ms-background-size: 9px 15px;
  background-size: 9px 15px
}

.EVENT .list>li a, .VOICE .list>li a {
  display: block;
  color: #151515
}

.EVENT .list>li time, .VOICE .list>li time {
  display: inline-block;
  font-size: 12px;
  color: #fff;
  background: #33b0bd;
  padding: 5px 15px;
  margin-right: 20px
}

.EVENT .pagenavi, .VOICE .pagenavi {
  margin: 60px 0;
  text-align: center
}

.EVENT .pagenavi span, .VOICE .pagenavi span {
  display: inline-block;
  margin: 0 10px;
  background: #33b0bd;
  color: #fff;
  padding: 5px 12px
}

.EVENT .detail .red, .VOICE .detail .red {
  color: #ED7D31
}

.EVENT .detail .strong, .VOICE .detail .strong {
  font-size: 16px;
  font-weight: 700
}

.EVENT .detail .tableStyle, .VOICE .detail .tableStyle {
  margin: 24px 0
}

.EVENT .detail dl.listable, .VOICE .detail dl.listable {
  border: 8px solid #f2f2f2;
  padding: 24px
}

.EVENT .detail dl.listable dt, .VOICE .detail dl.listable dt {
  background: #33b0bd;
  color: #FFF;
  font-size: 20px;
  font-weight: 700;
  padding: 2px 16px;
  margin: 0 0 20px
}

.EVENT .detail dl.listable dd, .VOICE .detail dl.listable dd {
  padding: 0 0 12px;
  margin: 0 0 12px;
  border-bottom: #d5d5d5 1px dashed;
  font-size: 16px
}

.EVENT .detail dl.listable dd:last-of-type, .VOICE .detail dl.listable dd:last-of-type {
  padding: 0;
  margin: 0;
  border: none
}

.EVENT .detail dl.listable dd:before, .VOICE .detail dl.listable dd:before {
  content: '■';
  color: #33b0bd;
  display: inline-block;
  padding: 0 8px 0 0
}

@media screen and (max-width:768px) {
  .EVENT .list>li, .VOICE .list>li {
    padding: 8px 20px 8px 0
  }

  .EVENT .list>li time, .VOICE .list>li time {
    font-size: 10px;
    margin-right: 10px
  }

  .EVENT .pagenavi, .VOICE .pagenavi {
    margin: 30px 0
  }
}

.SERCH .serch {
  overflow: hidden
}

.SERCH .serch .Left {
  width: 60%;
  float: left;
  padding: 1px
}

.SERCH .serch .Left dl {
  -o-box-shadow: 0 0 6px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 6px rgba(0, 0, 0, .15);
  box-shadow: 0 0 6px rgba(0, 0, 0, .15);
  border-radius: 8px;
  margin: 0 0 24px
}

.SERCH .serch .Left dl:last-of-type {
  margin: 0
}

.SERCH .serch .Left dl dt {
  border-radius: 8px 8px 0 0;
  background: #f2f2f2;
  background: linear-gradient(to bottom, #fff 0, #f2f2f2 100%);
  font-size: 18px;
  padding: 5px 20px;
  position: relative
}

.SERCH .serch .Left dl dt a {
  color: #151515
}

.SERCH .serch .Left dl dt i {
  padding-left: 10px
}

.SERCH .serch .Left dl dt i.red {
  border-left: 4px solid #1AB5A6
}

.SERCH .serch .Left dl dt i.green {
  border-left: 4px solid #3383C5
}

.SERCH .serch .Left dl dt i.yellow {
  border-left: 4px solid #7CC170
}

.SERCH .serch .Left dl dt i.rbrown {
  border-left: 4px solid #F5AB1A
}

.SERCH .serch .Left dl dt i.ygreen {
  border-left: 4px solid #EF8255
}

.SERCH .serch .Left dl dt i.brown {
  border-left: 4px solid #C3D956
}

@media screen and (max-width:768px) {
  .SERCH .serch .Left dl dt i {
    display: block;
    line-height: 1.4;
    margin: 0 0 5px
  }
}

.SERCH .serch .Left dl dd {
  border-radius: 0 0 8px 8px;
  background: #f8f8f8;
  overflow: hidden
}

.SERCH .serch .Left dl dd ul {
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  justify-content: flex-start
}

.SERCH .serch .Left dl dd ul li {
  width: 25%;
  list-style: none;
  text-align: center;
  font-size: 15px;
  background: #fff;
  border-right: 1px solid #d5d5d5
}

.SERCH .serch .Left dl dd ul li:nth-child(4n+4) {
  border-right: none
}

.SERCH .serch .Left dl dd ul li a {
  display: block;
  padding: 12px 0;
  color: #151515
}

.SERCH .serch .Left dl dd ul.underTrue li {
  border-bottom: #d5d5d5 1px solid
}

.SERCH .serch .Left dl dd ul.underTrue li:nth-child(n+5) {
  border-bottom: #d5d5d5 1px solid
}

.SERCH .serch .Left dl dd ul.underTrue li:nth-child(n+9) {
  border-top: none
}

.SERCH .serch .Right {
  width: 35%;
  float: right
}

.SERCH .serch .Right figure {
  display: block;
  margin: 30px 0 0
}

@media screen and (max-width:768px) {
  .SERCH .serch .Left {
    float: none;
    width: auto;
    margin: 0 0 20px
  }

  .SERCH .serch .Left dl {
    margin-bottom: 15px
  }

  .SERCH .serch .Left dl dt {
    font-size: 15px;
    padding: 10px
  }

  .SERCH .serch .Left dl dd ul li {
    list-style: none;
    width: 50%;
    padding: 0;
    text-align: center;
    font-size: 15px;
    background: #fff;
    border-bottom: 1px solid #d5d5d5
  }

  .SERCH .serch .Left dl dd ul li:nth-child(2n+2) {
    border-right: none
  }

  .SERCH .serch .Left dl dd ul li:nth-child(n+3), .SERCH .serch .Left dl dd ul.underTrue li {
    border-bottom: #d5d5d5 1px solid
  }

  .SERCH .serch .Left dl dd ul.underTrue li:nth-child(n+3) {
    border-top: none
  }

  .SERCH .serch .Right {
    float: none;
    width: auto
  }
}

.TEMPLE .first .context {
  font-size: 17px;
  text-align: center
}

.TEMPLE .first .context.large {
  font-size: 24px;
  line-height: 1
}

.TEMPLE .second .price {
  margin: 0 0 24px
}

.TEMPLE .second .price dt {
  font-size: 16px;
  margin: 0 0 7px
}

.TEMPLE .second .price dt .large {
  font-size: 26px
}

.TEMPLE .second .price dt strong {
  color: #ED7D31
}

.TEMPLE .second .price dd {
  font-size: 12px
}

.TEMPLE .second .tableStyle td, .TEMPLE .second .tableStyle th, .TEMPLE .third .fourClum li {
  font-size: 18px;
  text-align: center
}

.TEMPLE .second .figures {
  margin: 0 0 40px;
  border: 8px solid #f2f2f2;
  padding: 24px
}

.TEMPLE .second .figures li {
  list-style: none;
  width: 48.5%;
  float: left;
  margin: 0 3% 3% 0
}

.TEMPLE .second .figures li:nth-child(2n+1) {
  clear: both
}

.TEMPLE .second .figures li:nth-child(2n+2) {
  margin-right: 0
}

.TEMPLE .second .figures li:nth-last-child(-n+2) {
  margin-bottom: 0
}

.TEMPLE .second .oneClum li {
  list-style: none
}

.TEMPLE .second .oneClum li:before {
  content: "※";
  margin-right: 3px
}

.TEMPLE .second .oneClum li.red {
  color: #a40000;
  font-weight: 700
}

.TEMPLE .third h4.red:before {
  color: #ae5da1
}

.TEMPLE .third .mb {
  margin-bottom: 60px !important
}

.TEMPLE .third .fourClum {
  margin-bottom: 15px
}

.TEMPLE .third .fourClum.green>li {
  background: url(../../images/common/arrow_green.png) 20px center no-repeat #c7e5ce;
  -ms-background-size: 8px 14px;
  background-size: 8px 14px;
  color: #33b0bd
}

.TEMPLE .third .fourClum.red li {
  background: url(../../images/common/arrow_purple.png) 20px center no-repeat #ebd6e8;
  -ms-background-size: 8px 14px;
  background-size: 8px 14px;
  color: #ae5ca1
}

.TEMPLE .third .fourClum li {
  padding: 10px;
  height: 70px;
  display: table
}

@media screen and (min-width:769px) {
  .TEMPLE .third .fourClum li {
    list-style: none;
    width: 23.5%;
    float: left;
    margin: 0 2% 2% 0
  }

  .TEMPLE .third .fourClum li:nth-child(4n+1) {
    clear: both
  }

  .TEMPLE .third .fourClum li:nth-child(4n+4) {
    margin-right: 0
  }

  .TEMPLE .third .fourClum li:nth-last-child(-n+4) {
    margin-bottom: 0
  }
}

.TEMPLE .third .fourClum li span {
  display: table-cell;
  text-align: center;
  vertical-align: middle;
  line-height: 1.4
}

@media screen and (max-width:768px) {
  .TEMPLE .first .context.large {
    font-size: 16px
  }

  .TEMPLE .second .price {
    margin: 0 0 15px
  }

  .TEMPLE .second .price dt {
    font-size: 14px
  }

  .TEMPLE .second .price dt .large {
    font-size: 26px
  }

  .TEMPLE .second .figures {
    margin: 0 0 30px;
    padding: 15px
  }

  .TEMPLE .second .tableStyle {
    margin: 0 0 15px
  }

  .TEMPLE .second .tableStyle td, .TEMPLE .second .tableStyle th {
    display: table-cell;
    font-size: 14px;
    padding: 8px
  }

  .TEMPLE .third .mb {
    margin-bottom: 20px !important
  }

  .TEMPLE .third .fourClum.green>li, .TEMPLE .third .fourClum.red>li {
    background-position: 10px center
  }

  .TEMPLE .third .fourClum>li {
    list-style: none;
    width: 49%;
    float: left;
    margin: 0 2% 2% 0;
    font-size: 14px;
    padding: 5px;
    height: 50px
  }

  .TEMPLE .third .fourClum>li:nth-child(2n+1) {
    clear: both
  }

  .TEMPLE .third .fourClum>li:nth-child(2n+2) {
    margin-right: 0
  }

  .TEMPLE .third .fourClum>li:nth-last-child(-n+2) {
    margin-bottom: 0
  }
}

.RECRUIT {
  margin: 0 0 40px
}

.RECRUIT figure.bnr {
  border: 8px solid #f2f2f2;
  padding: 32px 0;
  text-align: center;
  font-size: 16px
}

.RECRUIT figure.bnr figcaption {
  margin: 0 0 20px;
  color: #ED7D31
}

.RECRUIT figure.bnr figcaption:first-of-type {
  margin-bottom: 50px
}

.RECRUIT figure.bnr figcaption strong {
  display: block
}

.RECRUIT figure.bnr figcaption strong i {
  color: #ED7D31;
  font-size: 28px;
  font-weight: 700
}

.RECRUIT figure.bnr figcaption strong i:before {
  content: "：";
  font-size: 14px;
  color: #151515;
  display: inline-block;
  margin: 0 10px
}

.RECRUIT figure.bnr.part figcaption:first-of-type {
  margin-bottom: 0
}

.RECRUIT figure.bnr.part figcaption strong i.fax {
  font-size: 18px
}

@media screen and (max-width:768px) {
  .RECRUIT {
    margin: 0
  }

  .RECRUIT figure.bnr {
    padding: 20px;
    font-size: 14px
  }
}

.PLAN .localNavi {
  margin: 60px 0 0
}

.PLAN .localNavi ul {
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  width: 100%
}

.PLAN .localNavi ul li {
  list-style: none;
  width: 15%;
  flex-grow: 1;
  margin: 0 0 0 2%
}

.PLAN .localNavi ul li:first-child {
  margin-left: 0
}

.PLAN .localNavi ul li:last-child {
  margin-right: 0
}

.PLAN .localNavi ul li a {
  display: block;
  font-size: 19px;
  padding: 5px 0;
  text-align: center;
  color: #151515;
  border: 1px solid #d5d5d5;
  border-radius: 8px;
  line-height: 1.5;
}

.PLAN .localNavi ul li a .zeikomi {
  display: block;
  font-size: 14px;
}

.PLAN .localNavi ul li.visit>a {
  background: #33b0bd;
  color: #fff;
  border: none
}

.PLAN.DETAIL .first .context {
  text-align: center;
  font-size: 17px
}

.PLAN.DETAIL .first .context small {
  font-size: 12px
}

.PLAN.DETAIL .first .flex {
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  margin: 30px 0 0;
  padding: 20px;
  box-shadow: 0 0 5px rgba(0, 0, 0, .15)
}

.PLAN.DETAIL .second .detail, .PLANFOOD .food {
  -o-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 5px rgba(0, 0, 0, .15)
}

.PLAN.DETAIL .first .flex>li {
  list-style: none;
  width: 49%
}

@media screen and (min-width:769px) {
  .PLAN.DETAIL .first .flex>li {
    margin: 0 2% 30px 0
  }

  .PLAN.DETAIL .first .flex>li:nth-child(2n+2) {
    margin-right: 0
  }

  .PLAN.DETAIL .first .flex>li:nth-last-child(-n+2) {
    margin-bottom: 0
  }
}

.PLAN.DETAIL .first .flex>li>dl dt {
  background-color: #eef8f0;
  font-size: 20px;
  text-align: center;
  margin: 0 0 15px;
  padding: 5px
}

.PLAN.DETAIL .first .flex>li>dl dt .zeikomi {
  font-size: 14px;
  margin-left: 10px;
}

.PLAN.DETAIL .first .flex>li>dl dd {
  text-align: center
}

.PLAN.DETAIL .second .detail {
  box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  padding: 40px
}

.PLAN.DETAIL .second .detail .mb {
  margin-bottom: 30px
}

.PLAN.DETAIL .second .detail .plan {
  margin: 0 0 40px
}

.PLAN.DETAIL .second .detail .plan>dt {
  background: #edf6ee;
  font-size: 30px;
  padding: 15px 30px;
  margin: 0 0 25px;
  position: relative
}

.PLAN.DETAIL .second .detail .plan>dt span {
  display: inline-block;
  color: #ED7D31;
  font-size: 25px;
  position: absolute;
  right: 10px;
  padding-right: 120px
}

.PLAN.DETAIL .second .detail .plan>dt span i {
  font-size: 50px;
  line-height: 1.2
}

.PLAN.DETAIL .second .detail .plan>dt span:after {
  content: "(税込)";
  font-size: 18px
}

.PLAN.DETAIL .second .detail .plan>dt.length {
  position: relative
}

.PLAN.DETAIL .second .detail .plan>dt.length:before {
  content: attr(data-leng);
  background: #33b0bd;
  color: #FFF;
  padding: 0 12px;
  border-radius: 4px;
  position: absolute;
  font-size: 18px;
  top: 30px;
  right: 30px
}

.PLAN.DETAIL .second .detail .plan>dd li {
  list-style: none
}

.PLAN.DETAIL .second .detail .left {
  clear: both;
  float: left;
  width: 58%
}

.PLAN.DETAIL .second .detail .left .twoClum>li {
  list-style: none;
  width: 48%;
  border-bottom: 1px dotted #d5d5d5;
  padding: 0 0 20px;
  margin: 0 4% 20px 0
}

.PLAN.DETAIL .second .detail .left .twoClum>li dl {
  font-size: 16px
}

.PLAN.DETAIL .second .detail .right {
  float: right;
  width: 40%
}

.PLAN.DETAIL .second .detail .right .twoClum>li {
  width: 48%;
  margin: 0 4% 12px 0
}

.PLAN.DETAIL .second .detail .twoClum {
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between
}

.PLAN.DETAIL .second .detail .twoClum>li {
  list-style: none;
  width: 49%;
  margin: 0 2% 2% 0
}

.PLAN.DETAIL .second .detail .twoClum>li:nth-child(2n+2) {
  margin-right: 0
}

.PLAN.DETAIL .second .detail .twoClum>li dl {
  font-size: 18px
}

.PLAN.DETAIL .second .detail .twoClum>li dl dt {
  border-left: 4px solid #33b0bd;
  padding: 0 0 0 10px;
  margin: 0 0 5px
}

.PLAN.DETAIL .second .detail .twoClum>li dl dd {
  padding: 0 0 0 20px
}

.PLAN.DETAIL .second .detail .twoClum>li dl dd:before {
  content: "└"
}

.PLAN.DETAIL .option .inBox {
  -o-box-shadow: 0 0 15px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 15px rgba(0, 0, 0, .15);
  box-shadow: 0 0 15px rgba(0, 0, 0, .15);
  padding: 40px 20px 20px
}

.PLAN.DETAIL .option .inBox .flex {
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between
}

.PLAN.DETAIL .option .inBox .flex>li {
  list-style: none;
  width: 32%;
  margin: 0 2% 0 0;
  border: 1px solid #d5d5d5;
  padding: 15px
}

.PLAN.DETAIL .option .inBox .flex>li:last-child {
  margin-right: 0
}

.PLAN.DETAIL .option .inBox .flex>li dl {
  clear: both;
  float: left;
  width: 53%
}

.PLAN.DETAIL .option .inBox .flex>li dl dt {
  color: #ae5da1;
  font-size: 18px;
  border-left: 4px solid #ae5da1;
  padding: 0 0 0 10px;
  line-height: 1.2;
  margin: 0 0 15px
}

.PLAN.DETAIL .option .inBox .flex>li dl dd:before {
  content: "・";
  margin-right: 3px
}

.PLAN.DETAIL .option .inBox .flex>li figure {
  width: 45%;
  float: right
}

@media screen and (max-width:768px) {
  .PLAN.DETAIL .first .flex, .PLAN.DETAIL .second .detail {
    padding: 15px
  }

  .PLAN .localNavi {
    margin: 30px 0 0
  }

  .PLAN .localNavi ul li {
    width: 49%;
    margin: 0 0 2%;
    flex-grow: unset
  }

  .PLAN .localNavi ul li a, .PLAN.DETAIL .first .context {
    font-size: 15px
  }

  .PLAN.DETAIL .first .flex>li {
    width: 100%;
    margin: 0 0 4%
  }

  .PLAN.DETAIL .first .flex>li:last-child {
    margin-bottom: 0
  }

  .PLAN.DETAIL .first .flex>li>dl dt {
    font-size: 18px
  }

  .PLAN.DETAIL .second .detail .plan {
    margin: 0 0 20px
  }

  .PLAN.DETAIL .second .detail .plan>dt {
    font-size: 18px;
    padding: 8px;
    margin: 0 0 10px
  }

  .PLAN.DETAIL .second .detail .plan>dt.length:before {
    font-size: 13px;
    padding: 0 6px;
    top: 12px;
    right: 8px
  }

  .PLAN.DETAIL .second .detail .plan>dt span {
    display: block;
    position: static;
    padding: 5px 0 0;
    border-top: 1px solid #b7cdc3;
    font-size: 14px
  }

  .PLAN.DETAIL .second .detail .plan>dt span i {
    font-size: 26px
  }

  .PLAN.DETAIL .second .detail .plan>dt span:after {
    font-size: 12px
  }

  .PLAN.DETAIL .second .detail .left {
    float: none;
    width: auto
  }

  .PLAN.DETAIL .second .detail .left .twoClum>li {
    width: 100%;
    margin: 0 0 4%;
    padding: 0 0 2%
  }

  .PLAN.DETAIL .second .detail .left .twoClum>li dl {
    font-size: 14px
  }

  .PLAN.DETAIL .second .detail .left .twoClum>li dl dt {
    margin-bottom: 0
  }

  .PLAN.DETAIL .second .detail .right {
    float: none;
    width: auto;
    margin: 4% 0 0
  }

  .PLAN.DETAIL .option .inBox {
    padding: 15px
  }

  .PLAN.DETAIL .option .inBox h3 {
    margin-bottom: 5px
  }

  .PLAN.DETAIL .option .inBox .flex>li {
    width: 100%;
    margin: 0 0 2%
  }

  .PLAN.DETAIL .option .inBox .flex>li:last-child {
    margin-bottom: 0
  }
}

.PLANFOOD.bg {
  background: url(../../images/offerings/bg.png)
}

.PLANFOOD .context {
  font-size: 18px;
  text-align: center;
  margin: 0 0 30px
}

.PLANFOOD .food {
  border: 1px solid #d5d5d5;
  background: #fff;
  padding: 25px;
  box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  border-radius: 5px
}

.PLANFOOD .threeClum>li, .PLANRETURN .refund {
  -o-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 5px rgba(0, 0, 0, .15)
}

.PLANFOOD .food>dl {
  margin: 0 0 42px
}

.PLANFOOD .food>dl:last-of-type {
  margin-bottom: 0
}

.PLANFOOD .food>dl dt {
  font-size: 22px;
  text-align: center;
  margin: 20px 0
}

.PLANFOOD .threeClum>li {
  box-shadow: 0 0 5px rgba(0, 0, 0, .15)
}

@media screen and (min-width:769px) {
  .PLANFOOD .threeClum>li {
    list-style: none;
    width: 32%;
    float: left;
    margin: 0 2% 2% 0
  }

  .PLANFOOD .threeClum>li:nth-child(3n+1) {
    clear: both
  }

  .PLANFOOD .threeClum>li:nth-child(3n+3) {
    margin-right: 0
  }

  .PLANFOOD .threeClum>li:nth-last-child(-n+3) {
    margin-bottom: 0
  }
}

.PLANFOOD .threeClum>li dl {
  padding: 25px;
  text-align: center
}

.PLANFOOD .threeClum>li dl dt {
  font-size: 22px;
  color: #33b0bd;
  border-bottom: 1px solid #d5d5d5;
  margin: 0 0 15px
}

@media screen and (max-width:768px) {
  .PLANFOOD .context {
    font-size: 15px;
    margin: 0 0 10px
  }

  .PLANFOOD .food {
    padding: 15px
  }

  .PLANFOOD .food>dl {
    margin: 0 0 20px
  }

  .PLANFOOD .food>dl dt {
    margin: 0 0 2%;
    font-size: 18px
  }

  .PLANFOOD .threeClum>li {
    list-style: none;
    margin: 0 0 2%
  }
}

.PLANRETURN.bg {
  background: url(../../images/offerings/bg.png)
}

.PLANRETURN .context {
  font-size: 18px;
  text-align: center;
  margin: 0 0 30px
}

.PLANRETURN .refund {
  border: 1px solid #d5d5d5;
  background: #fff;
  padding: 25px;
  box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  border-radius: 5px
}

.PLANRETURN .refund .main {
  width: 60%;
  margin: 0 auto 30px
}

.PLANRETURN .refund .flex {
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between
}

.PLANRETURN .refund .flex>li {
  list-style: none;
  width: 23.5%;
  margin: 0 2% 0 0
}

.PLANRETURN .refund .flex>li:nth-child(4n+4) {
  margin-right: 0
}

@media screen and (max-width:768px) {
  .PLANRETURN .context {
    font-size: 15px;
    margin: 0 0 10px
  }

  .PLANRETURN .refund {
    padding: 15px
  }

  .PLANRETURN .refund .main {
    width: 100%;
    margin-bottom: 2%
  }

  .PLANRETURN .refund .flex>li {
    width: 49%;
    margin: 0 2% 2% 0
  }

  .PLANRETURN .refund .flex>li:nth-child(2n+2) {
    margin-right: 0
  }
}

.AFTEROTHER .first, .AFTERTOMB .first {
  background: url(../../images/offerings/bg.png);
  padding-bottom: 120px !important
}

.AFTEROTHER .first .context, .AFTERTOMB .first .context {
  font-size: 18px;
  text-align: center
}

.AFTEROTHER .first h4.red, .AFTERTOMB .first h4.red {
  font-size: 24px;
  border-bottom: none;
  padding: 0 0 0 20px
}

.AFTEROTHER .first h4.red:before, .AFTERTOMB .first h4.red:before {
  content: "";
  border-left: 6px solid #ED7D31;
  width: 6px;
  height: 43px;
  position: absolute;
  top: 0;
  left: 0
}

.AFTEROTHER .first h4.red span, .AFTERTOMB .first h4.red span {
  display: inline-block;
  background-color: #967121;
  color: #fff;
  font-size: 20px;
  font-weight: 400;
  line-height: 1.2;
  margin-left: 40px;
  padding: 4px 30px;
  border-radius: 22px
}

.AFTEROTHER .first h4.red span i, .AFTERTOMB .first h4.red span i {
  display: inline-block;
  font-size: 30px;
  margin: 0 0 0 8px
}

.AFTEROTHER .first .flex, .AFTERTOMB .first .flex {
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  margin: 30px 0 60px
}

.AFTEROTHER .first .flex>li, .AFTERTOMB .first .flex>li {
  list-style: none;
  padding: 15px;
  background: #fff;
  border-radius: 5px;
  -o-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  box-shadow: 0 0 5px rgba(0, 0, 0, .15)
}

.support_list {
  border: #f2f2f2 solid 7px;
  list-style: none;
  padding: 15px 17px;
  box-sizing: border-box;
  margin-bottom: 30px;
}

.support_list li {
  font-weight: bold;
  padding: 5px 0;
  font-size: 15px;
}

.support_list li:before {
  content: '◆';
  color: #ED7D31;
  margin-right: 10px;
}

.support_list li.support_list_title:before,
.support_list li.support_list_title h4:before {
  display: none;
}

.support_list li.support_list_title h4 {
  padding: 5px 0;
  text-align: center;
  border-bottom: none;
  font-size: 22px;
  background: #edf6ee;
  margin-bottom: 12px;
}

.support_list1,
.support_list2 {
  width: 31%;
  float: left;
  margin-right: 3.5%;
  min-height: 780px;
}

.support_list3 {
  width: 31%;
  float: right;
  min-height: 780px;
}

.support_list4,
.support_list5 {
  overflow: hidden;
  clear: both;
}

.support_list4 li {
  width: 33.333%;
  float: left;
}

.support_list5 li {
  width: 25%;
  float: left;
}

.support_list4 {
  margin-bottom: 0;
}

.support_list4 li.support_list_title {
  width: 100%;
}

.procedure_support .caption_r {
  text-align: right;
  display: block;
  margin-bottom: 30px;
}

.procedure_support .title_green_main {
  font-size: 30px;
  margin-top: 20px;
}

.procedure_support .title_green_main span {
  display: inline-block;
  font-size: 50px;
  margin-left: 20px;
}

.procedure_support .title_green_main span.en {
  font-size: 26px;
}

.procedure_support .title_green_main span span {
  font-size: 35px;
}

.other_p {
  text-align: center;
  font-size: 20px;
  margin-bottom: 20px;
  padding: 20px;
}

.other_p_end {
  text-align: center;
  font-size: 30px;
  font-weight: bold;
  padding-top: 50px;
}

.procedure_support .alliance dd {
  letter-spacing: -0.5px;
}

@media screen and (min-width:769px) {
  .AFTEROTHER .first .flex>li, .AFTERTOMB .first .flex>li {
    width: 49%;
    margin: 0 2% 2% 0
  }

  .AFTEROTHER .first .flex>li:nth-child(2n+2), .AFTERTOMB .first .flex>li:nth-child(2n+2) {
    margin-right: 0
  }

  .AFTEROTHER .first .flex>li:nth-last-child(-n+3), .AFTERTOMB .first .flex>li:nth-last-child(-n+3) {
    margin-bottom: 0
  }
}

@media screen and (max-width:768px) {
  .support_list1, .support_list2, .support_list3 {
    width: 100%;
    float: none;
    min-height: auto;
  }

  .support_list4 li,
  .support_list5 li {
    width: 100%;
    float: none;
  }

  .procedure_support .title_green_main {
    font-size: 25px;
    margin-top: 0;
    margin-bottom: 15px;
  }

  .title_green_sub i {
    display: block;
  }

  .other_p {
    font-size: 16px;
  }

  .other_p_end {
    font-size: 18px;
  }
}

.AFTEROTHER .first .flex>li figure, .AFTERTOMB .first .flex>li figure {
  width: 23%;
  clear: both;
  float: left;
  text-align: center
}

.AFTEROTHER .first .flex>li figure img, .AFTERTOMB .first .flex>li figure img {
  max-height: 130px
}

.AFTEROTHER .first .flex>li dl, .AFTERTOMB .first .flex>li dl {
  width: 75%;
  float: right
}

.AFTEROTHER .first .flex>li dl dt, .AFTERTOMB .first .flex>li dl dt {
  color: #33b0bd;
  font-size: 19px;
  font-weight: 600;
  border-bottom: 1px solid #d5d5d5;
  padding: 0 0 5px;
  margin: 0 0 10px
}

.AFTEROTHER .first .flex>li dl dd, .AFTERTOMB .first .flex>li dl dd {
  font-size: 15px;
  font-weight: 600
}

.AFTEROTHER .first .fourClum, .AFTERTOMB .first .fourClum {
  width: 96%;
  margin: auto
}

.AFTEROTHER .first .fourClum>li, .AFTERTOMB .first .fourClum>li {
  text-align: center
}

@media screen and (min-width:769px) {
  .AFTEROTHER .first .fourClum>li, .AFTERTOMB .first .fourClum>li {
    list-style: none;
    width: 20.5%;
    float: left;
    margin: 0 6% 6% 0
  }

  .AFTEROTHER .first .fourClum>li:nth-child(4n+1), .AFTERTOMB .first .fourClum>li:nth-child(4n+1) {
    clear: both
  }

  .AFTEROTHER .first .fourClum>li:nth-child(4n+4), .AFTERTOMB .first .fourClum>li:nth-child(4n+4) {
    margin-right: 0
  }

  .AFTEROTHER .first .fourClum>li:nth-last-child(-n+4), .AFTERTOMB .first .fourClum>li:nth-last-child(-n+4) {
    margin-bottom: 0
  }
}

.AFTEROTHER .first .fourClum>li dl dt, .AFTERTOMB .first .fourClum>li dl dt {
  background-color: #707070;
  color: #fff;
  font-size: 16px
}

.AFTEROTHER .first .message, .AFTERTOMB .first .message {
  font-size: 24px;
  text-align: center;
  margin: 24px 0 0
}

@media screen and (max-width:768px) {
  .AFTEROTHER .first, .AFTERTOMB .first {
    padding-bottom: 30px !important
  }

  .AFTEROTHER .first .context, .AFTERTOMB .first .context {
    font-size: 15px
  }

  .AFTEROTHER .first h4.red, .AFTERTOMB .first h4.red {
    font-size: 18px;
    padding-left: 12px
  }

  .AFTEROTHER .first h4.red:before, .AFTERTOMB .first h4.red:before {
    height: 26px;
    top: 2px
  }

  .AFTEROTHER .first .flex, .AFTERTOMB .first .flex {
    margin-bottom: 30px
  }

  .AFTEROTHER .first .flex>li, .AFTERTOMB .first .flex>li {
    width: 100%;
    margin: 0 0 4%
  }

  .AFTEROTHER .first .flex>li figure, .AFTERTOMB .first .flex>li figure {
    display: none
  }

  .AFTEROTHER .first .flex>li dl, .AFTERTOMB .first .flex>li dl {
    float: none;
    width: auto
  }

  .AFTEROTHER .first .flex>li dl dt, .AFTERTOMB .first .flex>li dl dt {
    font-size: 16px
  }

  .AFTEROTHER .first .flex>li dl dd, .AFTERTOMB .first .flex>li dl dd {
    font-size: 14px
  }

  .AFTEROTHER .first .fourClum>li, .AFTERTOMB .first .fourClum>li {
    list-style: none;
    width: 49%;
    float: left;
    margin: 0 2% 2% 0
  }

  .AFTEROTHER .first .fourClum>li:nth-child(2n+1), .AFTERTOMB .first .fourClum>li:nth-child(2n+1) {
    clear: both
  }

  .AFTEROTHER .first .fourClum>li:nth-child(2n+2), .AFTERTOMB .first .fourClum>li:nth-child(2n+2) {
    margin-right: 0
  }

  .AFTEROTHER .first .fourClum>li:nth-last-child(-n+2), .AFTERTOMB .first .fourClum>li:nth-last-child(-n+2) {
    margin-bottom: 0
  }

  .AFTEROTHER .first .message, .AFTERTOMB .first .message {
    font-size: 16px
  }
}

p.text_ease {
  line-height: 2.3;
  letter-spacing: 1.6px;
  margin-bottom: 20px
}

.contnent_shadow {
  box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  padding: 40px;
  margin-bottom: 50px
}

.contnent_shadow p {
  font-size: 17px
}

.LETTER .Right p.caption_r {
  font-size: 13px;
  text-align: right;
  margin-bottom: 0
}

.contnent_shadow hr {
  margin: 25px 0
}

.contnent_shadow .display {
  width: 100%;
  padding: 15px 0 5px;
  margin: 0
}

.MODULE h3.title_green {
  padding: 20px 0;
  color: #fff;
  background: #33b0bd;
  font-weight: 700;
  display: block;
  text-align: center;
  position: relative
}

.procedure_support h3.title_green {
  margin-top: 80px;
}

.AFTERFIRE .detail .twoClum li .tableStyle td:first-of-type, .AFTERPROCEDURE .first .tableStyle tr:nth-child(even) td {
  background: #fafafa
}

.title_green_main {
  width: 50%;
  float: left;
  font-size: 26px;
  line-height: 1.3
}

.title_green_main em {
  font-style: normal;
  font-size: 38px;
}

.title_green_main span {
  display: block;
  font-size: 50px
}

.title_green_sub i {
  font-size: 120%;
  line-height: 1.4;
}

.title_green_main span span {
  display: inline;
  font-size: 22px
}

.title_green_sub {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 15px;
  margin: auto 0;
  width: 48%;
  float: right;
  height: 115px;
  border: 1px solid #fff;
  padding: 15px 0;
  display: block;
  font-size: 16px
}

.title_green_sub.line2 {
  padding: 30px 0
}

.MODULE h4.title_hishi {
  font-size: 22px;
  padding: 5px 0;
  border-bottom: none
}

.title_hishi:before {
  content: "◆";
  color: #33b0bd;
  display: inline-block;
  margin-right: 10px
}

.list_note {
  list-style: none;
  padding: 20px 0
}

.list_note li {
  font-size: 14px;
  float: left;
  width: 50%
}

.flow_after_sea {
  list-style: none;
  font-size: 16px
}

.flow_after_sea li {
  padding: 10px 0
}

.flow_after_sea li span {
  display: none
}

.alliance dt {
  font-size: 18px
}

.alliance dd {
  font-size: 16px
}

@media screen and (max-width:769px) {
  .contents_after_sea .Left {
    margin-bottom: 0
  }

  .contnent_shadow {
    padding: 8px
  }

  .title_green_main {
    width: 100%;
    font-size: 20px;
    margin-bottom: 15px
  }

  .title_green_sub {
    position: relative;
    top: auto;
    bottom: auto;
    right: auto;
    width: 92%;
    margin: 0 4%;
    padding: 4px;
    height: auto;
    font-size: 12px
  }

  .title_green_sub br {
    display: none
  }

  .title_green_sub.line2 {
    padding: 4px
  }

  .contnent_shadow p {
    font-size: 15px
  }

  .list_note li {
    float: none;
    width: 100%;
    font-size: 13px
  }

  .flow_after_sea li {
    padding: 5px 0;
    font-size: 14px
  }

  .flow_after_sea li span {
    display: inline
  }

  hr {
    margin: 15px 0
  }

  .title_green_main span span {
    display: block;
  }
}

.AFTERFIRE .before {
  font-size: 17px;
  margin: 0 0 32px;
  text-align: center
}

.AFTERFIRE .figList {
  margin: 0 0 56px;
  border: 8px solid #f2f2f2;
  padding: 24px
}

@media screen and (min-width:769px) {
  .AFTERFIRE .figList li {
    list-style: none;
    width: 32%;
    float: left;
    margin: 0 2% 2% 0
  }

  .AFTERFIRE .figList li:nth-child(3n+1) {
    clear: both
  }

  .AFTERFIRE .figList li:nth-child(3n+3) {
    margin-right: 0
  }

  .AFTERFIRE .figList li:nth-last-child(-n+3) {
    margin-bottom: 0
  }
}

.AFTERFIRE .detail {
  padding-bottom: 42px
}

.AFTERFIRE .detail h4 span {
  font-size: 15px;
  display: inline-block;
  position: absolute;
  top: 10px;
  right: 0
}

.AFTERFIRE .detail h4 i {
  display: inline-block;
  font-size: 14px;
  margin-right: 10px
}

.AFTERFIRE .detail .mb {
  margin-bottom: 20px
}

@media screen and (min-width:769px) {
  .AFTERFIRE .detail .twoClum li {
    list-style: none;
    width: 49%;
    float: left;
    margin: 0 2% 2% 0
  }

  .AFTERFIRE .detail .twoClum li:nth-child(2n+1) {
    clear: both
  }

  .AFTERFIRE .detail .twoClum li:nth-child(2n+2) {
    margin-right: 0
  }

  .AFTERFIRE .detail .twoClum li:nth-last-child(-n+2) {
    margin-bottom: 0
  }
}

.AFTERFIRE .detail .tableStyle th {
  text-align: center;
  font-size: 16px;
  font-weight: 600
}

.AFTERFIRE .detail .tableStyle td {
  text-align: center
}

.AFTERFIRE .detail .tableStyle td:first-child {
  text-align: left
}

.AFTERFIRE .detail .handling {
  margin: 0 2%
}

.AFTERFIRE .detail .handling>dt {
  font-size: 15px
}

.AFTERFIRE .detail .handling>dt:before {
  content: "※"
}

.AFTERFIRE .detail .handling>dt.right {
  text-align: right
}

.AFTERFIRE .detail .handling>dd {
  margin-left: 1em
}

.AFTERFIRE .context {
  text-align: center;
  font-size: 15px
}

@media screen and (max-width:768px) {
  .AFTERFIRE .before {
    font-size: 15px
  }

  .AFTERFIRE .figList {
    margin: 0 0 30px;
    padding: 15px
  }

  .AFTERFIRE .figList>li {
    list-style: none;
    margin: 0 0 4%
  }

  .AFTERFIRE .figList>li:last-child {
    margin-bottom: 0
  }

  .AFTERFIRE .detail {
    padding-bottom: 20px
  }

  .AFTERFIRE .detail h4 span {
    display: block;
    position: static;
    font-size: 12px
  }

  .AFTERFIRE .detail .twoClum>li {
    list-style: none;
    margin: 0 0 4%
  }

  .AFTERFIRE .detail .twoClum>li:last-child {
    margin-bottom: 0
  }

  .AFTERFIRE .detail .tableStyle td, .AFTERFIRE .detail .tableStyle th {
    display: table-cell
  }

  .AFTERFIRE .detail .tableStyle th {
    font-size: 14px
  }

  .AFTERFIRE .detail .handling {
    margin: 0
  }

  .AFTERFIRE .detail .handling>dt {
    font-size: 13px
  }

  .AFTERFIRE .detail .handling>dt.right {
    text-align: left
  }
}

.AFTERTOMB .first.wrap {
  padding-bottom: 65px !important
}

.AFTERTOMB .first .context {
  margin: 0 0 32px
}

.AFTERTOMB .first .flex {
  margin-bottom: 0
}

.AFTERTOMB .first .flex li {
  margin-bottom: 20px !important
}

.AFTERTOMB .first .flex li dl {
  width: 100%;
  float: none
}

@media screen and (min-width:769px) {
  .AFTERTOMB .first .flex li:nth-last-child(-n+2) {
    margin-bottom: 0 !important
  }
}

@media screen and (max-width:768px) {
  .AFTERTOMB .first.wrap {
    padding-bottom: 30px !important
  }
}

.AFTERPROCEDURE .first .context {
  text-align: center;
  font-size: 18px;
  margin: 0 0 30px
}

.AFTERPROCEDURE .first .tableStyle td, .AFTERPROCEDURE .first .tableStyle th {
  padding: 3px;
  text-align: center;
  vertical-align: middle;
  font-size: 15px
}

.AFTERPROCEDURE .first .tableStyle td i, .AFTERPROCEDURE .first .tableStyle th i {
  color: #ED7D31
}

.AFTERPROCEDURE .first .tableStyle th.bg {
  background: #d0d0d0;
  border: 1px solid #fff
}

.AFTERPROCEDURE .first .tableStyle td.bg {
  background: #f5f5f5
}

@media screen and (min-width:769px) {
  .AFTERPROCEDURE .first .twoClum>li {
    list-style: none;
    width: 49%;
    float: left;
    margin: 0 2% 2% 0
  }

  .AFTERPROCEDURE .first .twoClum>li:nth-child(2n+1) {
    clear: both
  }

  .AFTERPROCEDURE .first .twoClum>li:nth-child(2n+2) {
    margin-right: 0
  }

  .AFTERPROCEDURE .first .twoClum>li:nth-last-child(-n+2) {
    margin-bottom: 0
  }
}

.AFTERPROCEDURE .first .twoClum>li dl {
  border-radius: 4px;
  -o-box-shadow: 0 0 4px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 4px rgba(0, 0, 0, .15);
  box-shadow: 0 0 4px rgba(0, 0, 0, .15);
  padding: 20px;
  min-height: 235px
}

.AFTERPROCEDURE .first .twoClum>li dl dt {
  font-size: 19px;
  font-weight: 600;
  margin: 0 0 10px;
  color: #33b0bd
}

.AFTERPROCEDURE .first .point>li {
  list-style: disc;
  margin: 0 0 0 20px
}

@media screen and (max-width:768px) {
  .AFTERPROCEDURE .first .context {
    font-size: 15px
  }

  .AFTERPROCEDURE .first .twoClum>li {
    list-style: none;
    margin: 0 0 4%
  }

  .AFTERPROCEDURE .first .twoClum>li dl {
    padding: 15px;
    min-height: inherit
  }

  .AFTERPROCEDURE .first .twoClum>li dl dt {
    font-size: 16px;
    margin-bottom: 5px
  }

  .AFTERPROCEDURE .first .scroll {
    overflow-x: scroll
  }

  .AFTERPROCEDURE .first .scroll:before {
    content: "横にスクロールして下さい。";
    color: #fff;
    font-weight: 700;
    font-size: 14px;
    display: inline-block;
    padding: 0 15px;
    margin: 0 0 3px;
    border-radius: 5px;
    background: #ED7D31
  }

  .AFTERPROCEDURE .first .tableStyle {
    width: 100%
  }

  .AFTERPROCEDURE .first .tableStyle td, .AFTERPROCEDURE .first .tableStyle th {
    display: table-cell !important;
    font-size: 13px;
    padding: 8px
  }
}

.AFTERCE0pxONY .context {
  font-size: 20px;
  text-align: center
}

.AFTERCE0pxONY .line {
  position: relative
}

.AFTERCE0pxONY .line:after, .AFTERCE0pxONY .line:before {
  content: "";
  border-bottom: 1px solid #000;
  width: 26%;
  position: absolute;
  bottom: 20px;
  left: 0
}

.AFTERCE0pxONY .line:after {
  right: 0;
  left: auto
}

.AFTERCE0pxONY .first .twoClum {
  margin: 42px 0
}

@media screen and (min-width:769px) {
  .AFTERCE0pxONY .first .twoClum>li {
    list-style: none;
    width: 49%;
    float: left;
    margin: 0 2% 2% 0
  }

  .AFTERCE0pxONY .first .twoClum>li:nth-child(2n+1) {
    clear: both
  }

  .AFTERCE0pxONY .first .twoClum>li:nth-child(2n+2) {
    margin-right: 0
  }

  .AFTERCE0pxONY .first .twoClum>li:nth-last-child(-n+2) {
    margin-bottom: 0
  }
}

.AFTERCE0pxONY .first .threeClum {
  margin: 42px 0 0
}

@media screen and (min-width:769px) {
  .AFTERCE0pxONY .first .threeClum>li {
    list-style: none;
    width: 32%;
    float: left;
    margin: 0 2% 2% 0
  }

  .AFTERCE0pxONY .first .threeClum>li:nth-child(3n+1) {
    clear: both
  }

  .AFTERCE0pxONY .first .threeClum>li:nth-child(3n+3) {
    margin-right: 0
  }

  .AFTERCE0pxONY .first .threeClum>li:nth-last-child(-n+3) {
    margin-bottom: 0
  }
}

.AFTERCE0pxONY .first .tableStyle th {
  width: 30%
}

.AFTERCE0pxONY .first .tableStyle th.purple {
  background: #92658f;
  color: #fff;
  text-align: center;
  line-height: 1;
  font-size: 26px
}

.AFTERCE0pxONY .first .tableStyle th.lightpurple {
  background: #e5e0f0;
  text-align: center;
  line-height: 1;
  font-size: 26px
}

.AFTERCE0pxONY .first .tableStyle th.ocher {
  background: #c2b875;
  color: #fff;
  text-align: center;
  line-height: 1;
  font-size: 26px
}

.AFTERCE0pxONY .first .tableStyle th.lightocher {
  background: #ebe6d5;
  font-size: 26px;
  text-align: center;
  line-height: 1
}

.AFTERCE0pxONY .first .tableStyle td, .AFTERCE0pxONY .first .tableStyle th {
  padding: 10px;
  font-size: 15px
}

@media screen and (max-width:768px) {
  .AFTERCE0pxONY .context {
    font-size: 15px
  }

  .AFTERCE0pxONY .line:after, .AFTERCE0pxONY .line:before {
    content: none
  }

  .AFTERCE0pxONY .first .twoClum>li {
    list-style: none;
    margin: 0 0 4%
  }

  .AFTERCE0pxONY .first .threeClum {
    margin: 12px 0 0
  }

  .AFTERCE0pxONY .first .threeClum>li {
    list-style: none;
    margin: 0 0 4%
  }

  .AFTERCE0pxONY .first .tableStyle th {
    font-size: 14px !important
  }

  .AFTERCE0pxONY .first .tableStyle td {
    font-size: 12px
  }

  .AFTERCE0pxONY .first .tableStyle td, .AFTERCE0pxONY .first .tableStyle th {
    display: table-cell
  }
}

.MEMORIAL .context {
  font-size: 20px;
  text-align: center
}

.MEMORIAL .first>.flex {
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between
}

.MEMORIAL .first>.flex>li {
  list-style: none;
  width: 30%;
  margin: 0 5% 0 0
}

.MEMORIAL .first>.flex>li:nth-child(3n+3) {
  margin-right: 0
}

.MEMORIAL .first>.flex>li>dl dt {
  color: #fff;
  font-size: 15px;
  text-align: center;
  padding: 20px 0 15px;
  margin: 0 0 25px
}

.MEMORIAL .first>.flex>li>dl dt:before {
  content: attr(data-text);
  display: block;
  font-size: 30px;
  line-height: 1.3
}

.MEMORIAL .first>.flex>li>dl dt.red {
  background: #fe7074
}

.MEMORIAL .first>.flex>li>dl dt.blue {
  background: #8195d5
}

.MEMORIAL .first>.flex>li>dl dt.yellow {
  background: #f4b655
}

.MEMORIAL .first>.flex>li>dl dd {
  margin: 0 0 25px
}

.MEMORIAL .first>.flex>li>dl dd:last-child {
  margin-bottom: 0
}

@media screen and (max-width:768px) {
  .MEMORIAL .context {
    font-size: 15px
  }

  .MEMORIAL .first .flex>li {
    width: 100%;
    margin: 0 0 4% !important
  }

  .MEMORIAL .first .flex>li>dl dt {
    font-size: 14px;
    padding: 5px;
    margin: 0 0 2%
  }

  .MEMORIAL .first .flex>li>dl dt:before {
    font-size: 20px
  }

  .MEMORIAL .first .flex>li>dl dd {
    margin: 0 0 2%
  }
}

.AFTERALTAR .bg {
  background: url(../../images/offerings/bg.png)
}

.AFTERALTAR .box {
  background: #FFF;
  padding: 24px;
  -o-box-shadow: 0 0 8px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 8px rgba(0, 0, 0, .15);
  box-shadow: 0 0 8px rgba(0, 0, 0, .15)
}

.AFTERALTAR .box figure {
  width: 30%;
  float: left
}

.AFTERALTAR .box dl {
  width: 67%;
  float: right
}

.AFTERALTAR .box dl dt {
  line-height: 1.5;
  font-size: 24px;
  font-weight: 700;
  margin: 12px 0 16px;
  padding: 0 0 12px;
  color: #33b0bd;
  border-bottom: #d5d5d5 1px dashed
}

.AFTERALTAR .box dl dd {
  font-size: 18px
}

.AFTERALTAR .contexter {
  font-size: 16px;
  margin: 0 0 20px
}

.AFTERALTAR .three {
  border: 16px solid #f2f2f2;
  padding: 24px;
  margin: 0 0 56px
}

.AFTERALTAR .three li {
  border-right: #d5d5d5 1px dashed;
  text-align: center
}

@media screen and (min-width:769px) {
  .AFTERALTAR .three li {
    list-style: none;
    width: 32%;
    float: left;
    margin: 0 2% 2% 0
  }

  .AFTERALTAR .three li:nth-child(3n+1) {
    clear: both
  }

  .AFTERALTAR .three li:nth-child(3n+3) {
    margin-right: 0
  }

  .AFTERALTAR .three li:nth-last-child(-n+3) {
    margin-bottom: 0
  }
}

.AFTERALTAR .three li:nth-child(3n+3) {
  border: none
}

.AFTERALTAR .three li figure img {
  width: 100%
}

.AFTERALTAR .three li figure figcaption {
  margin: 24px 0 0;
  font-size: 22px;
  color: #33b0bd;
  font-weight: 700
}

.AFTERALTAR .question {
  background: #f5f5f5;
  padding: 24px;
  margin: 0 0 24px
}

.AFTERALTAR .question li {
  list-style: none;
  padding: 0 0 12px;
  margin: 0 0 12px;
  border-bottom: #d5d5d5 1px dashed;
  width: 48.5%;
  float: left
}

.AFTERALTAR .question li:nth-child(2n+2) {
  float: right
}

.AFTERALTAR .question li:last-child {
  margin: 0;
  padding: 0;
  border: none
}

.AFTERALTAR .question li .icon {
  background: url(../../images/common/arrow_r.png) left center no-repeat;
  -ms-background-size: 20px;
  background-size: 20px;
  padding-left: 28px;
  font-size: 20px
}

.AFTERALTAR .context {
  text-align: center;
  font-size: 20px
}

@media screen and (max-width:768px) {
  .AFTERALTAR .box {
    padding: 15px
  }

  .AFTERALTAR .box figure {
    float: none;
    width: 100%
  }

  .AFTERALTAR .box dl {
    float: none;
    width: auto
  }

  .AFTERALTAR .box dl dt {
    font-size: 18px;
    padding: 0 0 8px;
    margin: 8px 0
  }

  .AFTERALTAR .box dl dd {
    font-size: 14px
  }

  .AFTERALTAR .box dl dd br {
    display: none
  }

  .AFTERALTAR .contexter {
    font-size: 15px
  }

  .AFTERALTAR .three {
    border: 8px solid #f2f2f2;
    padding: 15px;
    margin: 0 0 30px
  }

  .AFTERALTAR .three>li {
    list-style: none;
    border-right: none;
    border-bottom: #d5d5d5 1px dashed;
    padding: 0 0 4%;
    margin: 0 0 4%
  }

  .AFTERALTAR .three>li figure figcaption {
    font-size: 16px;
    margin: 4% 0 0
  }

  .AFTERALTAR .question {
    padding: 15px
  }

  .AFTERALTAR .question>li {
    list-style: none;
    float: none !important;
    width: auto
  }

  .AFTERALTAR .question>li .icon {
    font-size: 16px
  }

  .AFTERALTAR .context {
    font-size: 15px
  }
}

.ADVANCE .bg, .PREPARATION .bg, .FAMILY .bg {
  background: url(../../images/offerings/bg.png)
}

.ADVANCE .context, .PREPARATION .context, .FAMILY .context {
  text-align: center;
  font-size: 17px
}

.ADVANCE .first .context, .PREPARATION .first .context, .FAMILY  .first .context {
  font-size: 20px;
  font-weight: 600
}

.FAMILY .family_first_bg .wrap {
  background-image: url(../../images/family/family_bg_middle.png);
  background-repeat: no-repeat;
  background-position: 80% center;
}

.FAMILY img {
  height: auto;
}

.FAMILY .family_sp_bg {
  display: none
}

.FAMILY .family_first_bg {
  background-color: #FFFCFA
}

.FAMILY .first.display {
  width: fit-content;
  margin: 0 auto;
}

.FAMILY .context1 {
  margin-bottom: 40px;
  font-family: "Yu Mincho", "YuMincho", "游明朝体", "YuMincho", "MS PMincho", serif;
  font-size: 24px;
  font-weight: 600;
  line-height: 2rem;
  color: #33b0bd
}

.FAMILY .context2 {
  margin-top: 10px;
  font-family: "Yu Mincho", "YuMincho", "游明朝体", "YuMincho", "MS PMincho", serif;
  font-size: 18px;
  font-weight: 600;
}

.FAMILY .context3 {
  width: fit-content;
  margin: 9px 0 9px 20px;
  font-family: "Yu Mincho", "YuMincho", "游明朝体", "YuMincho", "MS PMincho", serif;
  font-weight: 600;
  line-height: 26px;
}

.FAMILY .context4 {
  margin-top: 70px;
  text-align: center;
  font-family: "Yu Mincho", "YuMincho", "游明朝体", "YuMincho", "MS PMincho", serif;
  font-size: 20px;
  font-weight: 600;
}

.FAMILY .context5 {
  margin-top: 10px;
  text-align: center;
  font-family: "Yu Mincho", "YuMincho", "游明朝体", "YuMincho", "MS PMincho", serif;
  font-size: 30px;
  font-weight: 600;
  line-height: 2.1rem;
  color: #33b0bd;
}

.FAMILY .context5 br {
  display: none;
}

@media screen and (max-width:768px) {
  .FAMILY .first.display.wrap {
    width: 100%;
    margin: 0 10px
  }

  .FAMILY .family_sp_bg {
    display: block;
    margin-top: 10px
  }

  .FAMILY .context2 {
  line-height: 1.7rem;
  }

  .FAMILY .context3 {
    font-size: 14px;
  }

  .FAMILY .context4 {
    font-size: 16px;
  }

  .FAMILY .context5 br {
    display: block;
  }
}

.FAMILY .recommend {
  max-width: 940px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr); 
  gap: 10px;
}

.FAMILY .recommend li {
  list-style: none;
  padding: 0 0 12px;
  margin: 0 0 12px;
  border-bottom: #d5d5d5 1px dashed;
}

.FAMILY .recommend li .icon {
  background: url(../../images/common/kouei_checkbox_icon.png) left center no-repeat;
  -ms-background-size: 20px;
  background-size: 20px;
  padding-left: 28px;
  font-size: 20px
}

@media screen and (max-width:768px) {
.FAMILY .recommend {
  display: block;
  width: 96%;
  margin: 0 auto;
  padding: 0
}
}

.FAMILY .plan {
  max-width: 940px;
  margin: 0 auto;
  padding: 0
}

.FAMILY .plan_wrap {
  margin-bottom: 100px
}

.FAMILY .plan img {
  width: 100%;
  height: auto
}

@media screen and (max-width:768px) {
.FAMILY .plan {
  width: 96%;
  margin: 0 auto;
  padding: 0
}

.FAMILY .plan_wrap {
  margin-bottom: 100px;
}

.FAMILY .plan img {
  width: 100%;
  height: auto
}
}

.FAMILY .question {
  background: #f5f5f5;
  padding: 24px;
  margin: 0 0 24px
}

.FAMILY .question li {
  list-style: none;
  padding: 0 0 12px;
  margin: 0 0 12px;
  border-bottom: #d5d5d5 1px dashed;
  width: 48.5%;
  float: left
}

.FAMILY .question li:nth-child(2n+2) {
  float: right
}

.FAMILY .question li:nth-last-child(-n+2) {
  margin: 0;
  padding: 0;
  border: none
}

.FAMILY .no-bottom {
  padding-bottom: 0 !important
}

.FAMILY .serch.display.wrap {
  display: flex;
  padding: 0;
  margin: 0 auto;
}

.FAMILY .serch.display.wrap .Middle{
  order: 1
}

.FAMILY .serch.display.wrap .Right{
  order: 2
}

@media screen and (max-width:768px) {
.FAMILY .serch.display.wrap {
  display: block
}
}

.FAMILY .SERCH .serch {
  overflow: hidden
}

.FAMILY .SERCH .serch .blue {
  color: #0075c2;
}

.FAMILY .SERCH .serch .Left,
.FAMILY .SERCH .serch .Right {
  width: 25%;
  padding: 1px
}

.FAMILY .SERCH .serch .Left dl,
.FAMILY .SERCH .serch .Right dl {
  -o-box-shadow: 0 0 6px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 6px rgba(0, 0, 0, .15);
  box-shadow: 0 0 6px rgba(0, 0, 0, .15);
  border-radius: 8px;
  margin: 0 0 24px
}

.FAMILY .SERCH .serch .Left dl:last-of-type,
.FAMILY .SERCH .serch .Right dl:last-of-type {
  margin: 0
}

.FAMILY .SERCH .serch .Left dl dt,
.FAMILY .SERCH .serch .Right dl dt {
  border-radius: 8px 8px 0 0;
  background: #f2f2f2;
  background: linear-gradient(to bottom, #fff 0, #f2f2f2 100%);
  font-size: 18px;
  padding: 5px 20px;
  position: relative
}

.FAMILY .SERCH .serch .Left dl dt a,
.FAMILY .SERCH .serch .Right dl dt a {
  color: #151515
}

.FAMILY .SERCH .serch .Left dl dt i,
.FAMILY .SERCH .serch .Right dl dt i {
  padding-left: 10px
}

.FAMILY .SERCH .serch .Left dl dt i .tel,
.FAMILY .SERCH .serch .Right dl dt i .tel {
  font-size: 14px;
}

.FAMILY .SERCH .serch .Left dl dt i.red,
.FAMILY .SERCH .serch .Right dl dt i.red {
  border-left: 4px solid #09524a
}

.FAMILY .SERCH .serch .Left dl dt i.green,
.FAMILY .SERCH .serch .Right dl dt i.green {
  border-left: 4px solid #3383C5
}

.FAMILY .SERCH .serch .Left dl dt i.yellow,
.FAMILY .SERCH .serch .Right dl dt i.yellow {
  border-left: 4px solid #7CC170
}

.FAMILY .SERCH .serch .Left dl dt i.rbrown,
.FAMILY .SERCH .serch .Right dl dt i.rbrown {
  border-left: 4px solid #F5AB1A
}

.FAMILY .SERCH .serch .Left dl dt i.ygreen,
.FAMILY .SERCH .serch .Right dl dt i.ygreen {
  border-left: 4px solid #EF8255
}

.FAMILY .SERCH .serch .Left dl dt i.brown,
.FAMILY .SERCH .serch .Right dl dt i.brown {
  border-left: 4px solid #C3D956
}

.FAMILY .SERCH .serch .Left dl dd ul li.red,
.FAMILY .SERCH .serch .Right dl dd ul li.red {
  border-bottom: #1AB5A64D 1px solid;
}

.FAMILY .SERCH .serch .Left dl dd ul li.green,
.FAMILY .SERCH .serch .Right dl dd ul li.green {
  border-bottom: #3383C54D 1px solid;
}

.FAMILY .SERCH .serch .Left dl dd ul li.yellow,
.FAMILY .SERCH .serch .Right dl dd ul li.yellow {
  border-bottom: #7CC1704D 1px solid;
}

.FAMILY .SERCH .serch .Left dl dd ul li.rbrown,
.FAMILY .SERCH .serch .Right dl dd ul li.rbrown {
  border-bottom: #F5AB1A4D 1px solid;
}

.FAMILY .SERCH .serch .Left dl dd ul li.ygreen,
.FAMILY .SERCH .serch .Right dl dd ul li.ygreen {
  border-bottom: #EF82554D 1px solid;
}

.FAMILY .SERCH .serch .Left dl dd ul li.brown,
.FAMILY .SERCH .serch .Right dl dd ul li.brown {
  border-bottom: #C3D9564D 1px solid;
}

@media screen and (max-width:768px) {
  .FAMILY .SERCH .serch .Left dl dt i,
  .FAMILY .SERCH .serch .Right dl dt i {
    display: block;
    line-height: 1.4;
    margin: 0 0 5px
  }
}

.FAMILY .SERCH .serch .Left dl dd,
.FAMILY .SERCH .serch .Right dl dd {
  border-radius: 0 0 8px 8px;
  background: #f8f8f8;
  overflow: hidden
}

.FAMILY .SERCH .serch .Left dl dd ul {
  display: block
}

.FAMILY .SERCH .serch .Left dl dd ul li,
.FAMILY .SERCH .serch .Right dl dd ul li {
  width: 100%;
  list-style: none;
  text-align: left;
  font-size: 15px;
  background: #fff;
  border-right: none;
  border-bottom: #d5d5d5 1px solid;
  padding-left: 20px
}

.FAMILY .SERCH .serch .Left dl dd ul li a,
.FAMILY .SERCH .serch .Right dl dd ul li a {
  padding: 12px 0;
  color: #151515
}

.FAMILY .SERCH .serch .Left dl dd ul.underTrue li,
.FAMILY .SERCH .serch .Right dl dd ul.underTrue li {
  border-bottom: #d5d5d5 1px solid
}

.FAMILY .SERCH .serch .Left dl dd ul li:last-child,
.FAMILY .SERCH .serch .Right dl dd ul li:last-child {
  border-bottom: none
}

.FAMILY .SERCH .serch .Left dl dd ul.underTrue li:nth-child(n+5),
.FAMILY .SERCH .serch .Right dl dd ul.underTrue li:nth-child(n+5) {
  border-bottom: none
}

.FAMILY .SERCH .serch .Left dl dd ul.underTrue li:nth-child(n+9),
.FAMILY .SERCH .serch .Right dl dd ul.underTrue li:nth-child(n+9) {
  border-top: #d5d5d5 1px solid
}

.FAMILY .SERCH .serch .Middle {
  width: 50%;
}

@media screen and (max-width:768px) {
  .FAMILY .SERCH .serch .Left,
  .FAMILY .SERCH .serch .Right {
    width: auto;
    margin: 0 0 20px
  }

  .FAMILY .SERCH .serch .Left dl,
  .FAMILY .SERCH .serch .Right dl {
    margin-bottom: 15px
  }

  .FAMILY .SERCH .serch .Left dl dt,
  .FAMILY .SERCH .serch .Right dl dt {
    font-size: 15px;
    padding: 10px
  }

  .FAMILY .SERCH .serch .Left dl dd ul li,
  .FAMILY .SERCH .serch .Right dl dd ul li {
    list-style: none;
    padding: 0 0 0 20px;
    text-align: left;
    font-size: 15px;
    background: #fff;
    border-bottom: 1px solid #d5d5d5
  }

  .FAMILY .SERCH .serch .Left dl dd ul li:nth-child(2n+2),
  .FAMILY .SERCH .serch .Right dl dd ul li:nth-child(2n+2) {
    border-right: none
  }

  .FAMILY .SERCH .serch .Middle {
    width: auto
  }
}

.FAMILY .faq_wrapper {
  padding: 0;
  margin: 0;
  margin-bottom: 40px;
}

.FAMILY .aco-wrapper {
  max-width: 1280px;
  margin: 0 auto;
}

.FAMILY .aco-content {
  padding-bottom: 1.5rem;
}

.FAMILY .aco-content .marker {
  display: inline-block;
  font-weight: bold;
  background: linear-gradient(transparent 30%, #ffdfef 30%);
  line-height: 1;
}


@media (max-width: 767px) {
  .FAMILY .aco-content {
    display: block;
  }
}

.FAMILY .aco-btn.aco-wrapper {
  min-height: 40px;
  padding: 6px 60px 6px 10px;
  align-items: center;
  display: flex;
  position: relative;
  cursor: pointer;
  background-color: #F2F2F2;
}

.FAMILY .box_question {
  width: 100%;
  display: flex;
  font-size: 24px;
  font-weight: 500;
  position: relative;
  counter-increment: quest;
}

.FAMILY .box_question::before {
  content: "Q" counter(quest);
  display: block;
  width: 6.5%;
  text-align: center;
  font-size: 28px;
  line-height: 1.3;
  color: #ED7D31;
}

@media (max-width: 767px) {
  .FAMILY .box_question::before {
    width: 50px;
    font-size: 24px;
  }
}
.FAMILY .box_question p {
  margin-bottom: 0;
  font-size: 24px;
}

@media (max-width: 767px) {
  .FAMILY .box_question p {
    margin-top: 2px;
    font-size: 18px;
}
}

.FAMILY .aco-text.aco-wrapper {
  padding-top: 1.2em;
  font-size: 18px;
  position: relative;
}

.FAMILY .aco-text.aco-wrapper .box_answer li {
  margin-left: 80px;
}

.FAMILY .aco-text.aco-wrapper .box_answer li p {
  padding: 0 0 20px 0;
}

@media (max-width: 767px) {
  .FAMILY .aco-text.aco-wrapper {
    font-size: 16px;
  }

  .FAMILY .aco-text.aco-wrapper .box_answer li {
    margin-left: 80px;
}
}

.FAMILY .aco-text.aco-wrapper .box_answer {
  width: 88.5964%;
  margin-left: 0;
}

.FAMILY .aco-text.aco-wrapper .box_answer p:nth-last-of-type(1) {
  margin-bottom: 0;
}

.FAMILY .tbl-aco {
  border-collapse: collapse;
  width: 100%;
  counter-reset: quest;
  margin-bottom: 20px;
}

.FAMILY .tbl-aco thead, .tbl-aco tbody {
  -webkit-text-size-adjust: 100%;
}

.FAMILY .txtC {
  text-align: center;
  font-size: 18px;
  margin: 32px 0
}

@media (max-width: 767px) {
  .FAMILY .tbl-aco {
    display: block;
  }
  .FAMILY .tbl-aco tbody {
    display: block;
  }
  .FAMILY .tbl-aco tbody tr {
    display: block;
  }
}


.ADVANCE .second .twoClum, .PREPARATION .second .twoClum {
  margin-top: 30px
}

.ADVANCE .second .twoClum>li, .PREPARATION .second .twoClum>li {
  overflow: hidden;
  background: #fff;
  padding: 15px;
  -o-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  display: table
}

@media screen and (min-width:769px) {
  .ADVANCE .second .twoClum>li, .PREPARATION .second .twoClum>li {
    list-style: none;
    width: 49%;
    float: left;
    margin: 0 2% 2% 0
  }

  .ADVANCE .second .twoClum>li:nth-child(2n+1), .PREPARATION .second .twoClum>li:nth-child(2n+1) {
    clear: both
  }

  .ADVANCE .second .twoClum>li:nth-child(2n+2), .PREPARATION .second .twoClum>li:nth-child(2n+2) {
    margin-right: 0
  }

  .ADVANCE .second .twoClum>li:nth-last-child(-n+2), .PREPARATION .second .twoClum>li:nth-last-child(-n+2) {
    margin-bottom: 0
  }
}

.ADVANCE .second .twoClum>li figure, .PREPARATION .second .twoClum>li figure {
  display: table-cell;
  width: 20%;
  vertical-align: middle
}

.ADVANCE .second .twoClum>li figure img, .PREPARATION .second .twoClum>li figure img {
  max-height: 90px;
  max-width: 90px
}

.ADVANCE .second .twoClum>li dl, .PREPARATION .second .twoClum>li dl {
  display: table-cell;
  width: 75%
}

.ADVANCE .second .twoClum>li dl dt, .PREPARATION .second .twoClum>li dl dt {
  font-size: 18px;
  color: #33b0bd;
  font-weight: 600;
  margin: 0 0 7px
}

.ADVANCE .second .twoClum>li dl dd, .PREPARATION .second .twoClum>li dl dd {
  min-height: 130px
}

.ADVANCE .third .fourClum, .PREPARATION .third .fourClum {
  margin: 30px 0
}

.ADVANCE .third .fourClum>li, .PREPARATION .third .fourClum>li {
  -o-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  box-shadow: 0 0 5px rgba(0, 0, 0, .15)
}

@media screen and (min-width:769px) {
  .ADVANCE .third .fourClum>li, .PREPARATION .third .fourClum>li {
    list-style: none;
    width: 23.5%;
    float: left;
    margin: 0 2% 2% 0
  }

  .ADVANCE .third .fourClum>li:nth-child(4n+1), .PREPARATION .third .fourClum>li:nth-child(4n+1) {
    clear: both
  }

  .ADVANCE .third .fourClum>li:nth-child(4n+4), .PREPARATION .third .fourClum>li:nth-child(4n+4) {
    margin-right: 0
  }

  .ADVANCE .third .fourClum>li:nth-last-child(-n+4), .PREPARATION .third .fourClum>li:nth-last-child(-n+4) {
    margin-bottom: 0
  }
}

.ADVANCE .third .fourClum>li figure, .PREPARATION .third .fourClum>li figure {
  position: relative;
  top: 0;
  left: 0
}

.ADVANCE .third .fourClum>li figure:before, .PREPARATION .third .fourClum>li figure:before {
  content: "※イメージ画像です";
  color: #FFF;
  text-shadow: 1px 1px 1px #000;
  position: absolute;
  bottom: 2px;
  right: 8px;
  font-size: 12px
}

.ADVANCE .third .fourClum>li dl, .PREPARATION .third .fourClum>li dl {
  padding: 20px
}

.ADVANCE .third .fourClum>li dl dt, .PREPARATION .third .fourClum>li dl dt {
  font-size: 22px;
  color: #33b0bd;
  text-align: center;
  padding: 0 0 5px;
  margin: 0 0 15px;
  border-bottom: 1px solid #d5d5d5
}

.ADVANCE .third .fourClum>li dl dd, .PREPARATION .third .fourClum>li dl dd {
  min-height: 280px
}

.ADVANCE .four>dl dt, .PREPARATION .four>dl dt {
  font-size: 19px;
  color: #33b0bd
}

.ADVANCE .four .flow, .PREPARATION .four .flow {
  margin: 40px auto;
  counter-reset: num;
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between
}

.ADVANCE .four .flow:before, .PREPARATION .four .flow:before {
  content: "";
  width: 100%;
  border-bottom: 5px solid #33b0bd;
  position: absolute;
  bottom: 47px;
  left: 0;
  z-index: 1
}

.ADVANCE .four .flow li, .PREPARATION .four .flow li {
  list-style: none;
  width: 11%;
  height: 110px;
  padding: 5px;
  margin: 0 .5%;
  background: #fff;
  text-align: center;
  border-radius: 20px;
  -o-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  z-index: 2;
  display: table;
  position: relative
}

.ADVANCE .four .flow li:before, .PREPARATION .four .flow li:before {
  content: counter(num);
  counter-increment: num;
  font-size: 22px;
  color: #fff;
  background: #33b0bd;
  width: 35px;
  height: 35px;
  border-radius: 50%;
  position: absolute;
  top: -14px;
  left: 10px
}

.ADVANCE .four .flow li.green, .PREPARATION .four .flow li.green {
  background: #e3f5e7
}

.ADVANCE .four .flow li span, .PREPARATION .four .flow li span {
  display: table-cell;
  vertical-align: middle;
  width: 100%;
  height: 100%;
  font-size: 19px;
  line-height: 1.4
}

.ADVANCE .five .inBox, .PREPARATION .five .inBox {
  margin: 0 0 30px;
  padding: 110px 30px 30px;
  -o-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  border-radius: 4px;
  position: relative
}

.ADVANCE .five .inBox:before, .PREPARATION .five .inBox:before {
  content: attr(data-text);
  font-size: 20px;
  color: #fff;
  background: #33b0bd;
  padding: 5px 50px 5px 30px;
  border-radius: 0 23px 23px 0;
  position: absolute;
  top: 40px;
  left: 0
}

.ADVANCE .five .inBox dl, .PREPARATION .five .inBox dl {
  margin: 0 0 20px
}

.ADVANCE .five .inBox dl:last-child, .PREPARATION .five .inBox dl:last-child {
  margin-bottom: 0
}

.ADVANCE .five .inBox dl dt, .PREPARATION .five .inBox dl dt {
  font-size: 18px;
  padding: 0 0 10px;
  margin: 0 0 15px;
  border-bottom: 1px solid #d5d5d5
}

.ADVANCE .five .inBox dl dt:before, .PREPARATION .five .inBox dl dt:before {
  content: "◆";
  color: #33b0bd;
  margin-right: 10px
}

.ADVANCE .five .inBox dl dd strong, .PREPARATION .five .inBox dl dd strong {
  display: block;
  font-size: 16px;
  color: #33b0bd
}

.ADVANCE .five .inBox dl dd p, .PREPARATION .five .inBox dl dd p {
  margin-bottom: 15px
}

.ADVANCE .five .inBox dl dd p:last-of-type, .PREPARATION .five .inBox dl dd p:last-of-type {
  margin-bottom: 0
}

@media screen and (max-width:768px) {
  .ADVANCE .context br, .ADVANCE .second .twoClum>li figure, .PREPARATION .context br, .PREPARATION .second .twoClum>li figure {
    display: none
  }

  .ADVANCE .second .twoClum>li dl dd, .ADVANCE .third .fourClum>li dl dd, .PREPARATION .second .twoClum>li dl dd, .PREPARATION .third .fourClum>li dl dd {
    min-height: inherit
  }

  .ADVANCE .context, .PREPARATION .context {
    font-size: 15px !important
  }

  .ADVANCE .second .twoClum>li, .PREPARATION .second .twoClum>li {
    list-style: none;
    margin: 0 0 4%
  }

  .ADVANCE .second .twoClum>li dl, .PREPARATION .second .twoClum>li dl {
    width: 100%
  }

  .ADVANCE .second .twoClum>li dl dt, .PREPARATION .second .twoClum>li dl dt {
    border-bottom: 1px solid #d5d5d5;
    line-height: 1.4;
    padding: 0 0 5px;
    font-size: 15px
  }

  .ADVANCE .third .fourClum, .PREPARATION .third .fourClum {
    margin-bottom: 0
  }

  .ADVANCE .third .fourClum>li, .PREPARATION .third .fourClum>li {
    list-style: none;
    margin: 0 0 4%
  }

  .ADVANCE .third .fourClum>li:last-child, .PREPARATION .third .fourClum>li:last-child {
    margin-bottom: 0
  }

  .ADVANCE .third .fourClum>li dl, .PREPARATION .third .fourClum>li dl {
    padding: 15px
  }

  .ADVANCE .third .fourClum>li dl dt, .PREPARATION .third .fourClum>li dl dt {
    font-size: 18px
  }

  .ADVANCE .five .inBox, .PREPARATION .five .inBox {
    padding: 65px 15px 15px
  }

  .ADVANCE .five .inBox:before, .PREPARATION .five .inBox:before {
    font-size: 16px;
    top: 15px
  }

  .ADVANCE .five .inBox dl dt, .PREPARATION .five .inBox dl dt {
    font-size: 16px;
    line-height: 1.4
  }
}

.SERCHDETAIL h3 {
  margin-bottom: 60px !important
}

.SERCHDETAIL h3 span {
  display: inline-block;
  border-bottom: 4px solid #84921e
}

.SERCHDETAIL h3:after {
  content: none !important
}

.SERCHDETAIL .mb {
  margin-bottom: 30px
}

.SERCHDETAIL .detail {
  -o-box-shadow: 0 0 8px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 8px rgba(0, 0, 0, .15);
  box-shadow: 0 0 8px rgba(0, 0, 0, .15);
  border-radius: 8px;
  margin: 0 0 30px;
  border: 1px solid #d5d5d5;
  position: relative
}

.SERCHDETAIL .detail:first-of-type {
  margin-top: 30px
}

.SERCHDETAIL .detail>dt {
  border-radius: 8px 8px 0 0;
  font-size: 18px;
  padding: 12px 20px 12px 40px;
  border-bottom: 1px solid #d5d5d5;
  background: linear-gradient(180deg, #fff, #f2f2f2);
  position: relative
}

.SERCHDETAIL .detail>dt:before {
  content: "";
  border-left: 4px solid #84921e;
  width: 4px;
  height: 25px;
  left: 20px
}

.SERCHDETAIL .detail>dt span {
  color: #ED7D31;
  font-size: 26px;
  right: 20px
}

.SERCHDETAIL .detail>dt span:before {
  content: "tel."
}

.SERCHDETAIL .detail>dd {
  padding: 20px;
  overflow: hidden
}

.SERCHDETAIL .detail>dd .Left {
  float: left;
  width: 580px
}

.SERCHDETAIL .detail>dd .Left .oneClum.mb {
  margin-bottom: 120px
}

.SERCHDETAIL .detail>dd .Left .oneClum li {
  list-style: none;
  overflow: hidden;
  padding: 10px;
  font-size: 15px
}

.SERCHDETAIL .detail>dd .Left .oneClum li:nth-child(odd) {
  background-color: #fafafa
}

.SERCHDETAIL .detail>dd .Left .oneClum li dl>dt {
  width: 20%;
  clear: both;
  float: left
}

.SERCHDETAIL .detail>dd .Left .oneClum li dl>dd {
  width: 78%;
  float: right
}

.SERCHDETAIL .detail>dd .Left .oneClum li dl>dd p {
  margin-bottom: 20px
}

.SERCHDETAIL .detail>dd .Right {
  float: right;
  width: 480px
}

.SERCHDETAIL .detail>dd .Right ul>li {
  list-style: none
}

.SERCHDETAIL .detail>dd .Right iframe {
  display: block;
  margin: 20px 0 0
}

.SERCHDETAIL .detail>dd .btnArea {
  width: 580px;
  text-align: center;
  position: absolute;
  bottom: 40px;
  left: 0
}

.SERCHDETAIL .detail>dd .btnArea a {
  display: inline-block;
  background: #33b0bd;
  font-size: 24px;
  color: #fff;
  padding: 10px 90px;
  border-radius: 10px;
  box-shadow: 4px 7px 13px 0 rgba(0, 0, 0, .75)
}

@media screen and (max-width:768px) {
  .SERCHDETAIL h3 {
    margin-bottom: 35px !important
  }

  .SERCHDETAIL .detail:first-of-type {
    margin-top: 0
  }

  .SERCHDETAIL .detail>dt {
    font-size: 15px;
    padding: 7px 7px 7px 20px
  }

  .SERCHDETAIL .detail>dt:before {
    left: 10px;
    top: 20px
  }

  .SERCHDETAIL .detail>dt span {
    display: block;
    font-size: 18px;
    position: static;
    transform: translateX(0) translateY(0);
    text-align: right;
    line-height: 1
  }

  .SERCHDETAIL .detail>dd {
    padding: 15px
  }

  .SERCHDETAIL .detail>dd .Left {
    float: none;
    width: auto;
    margin: 0 0 20px
  }

  .SERCHDETAIL .detail>dd .Left .oneClum li {
    font-size: 12px
  }

  .SERCHDETAIL .detail>dd .Left .oneClum li dl>dt {
    width: 23%
  }

  .SERCHDETAIL .detail>dd .Left .oneClum li dl>dd {
    width: 75%
  }

  .SERCHDETAIL .detail>dd .Right {
    float: none;
    width: auto
  }

  .SERCHDETAIL .detail>dd .Right iframe {
    height: 250px
  }

  .SERCHDETAIL .detail>dd .btnArea {
    position: static;
    width: auto;
    margin: 15px 0 0
  }

  .SERCHDETAIL .detail>dd .btnArea a {
    display: block;
    font-size: 16px;
    padding: 10px 0;
    text-align: center
  }
}

.bx-wrapper {
  box-shadow: none !important;
  border: none !important;
  background: 0 0 !important
}

.bx-wrapper .bx-controls-direction a.disabled {
  display: block !important
}

.HURRY.bg {
  background: url(../../images/offerings/bg.png)
}

.HURRY .context {
  font-size: 18px;
  text-align: center
}

.HURRY .context strong {
  display: block;
  font-size: 30px;
  color: #ED7D31;
  line-height: 1.5;
  margin: 8px 0 0
}

.HURRY .two {
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  -o-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  background: #FFF
}

.HURRY .two>dt {
  width: 45%
}

.HURRY .two>dt figure figcaption {
  margin: 24px 0 0
}

.HURRY .two>dd {
  width: 55%;
  padding: 40px;
  background: #fff
}

.HURRY .oneClum>li {
  list-style: none;
  margin: 0 0 16px;
  padding: 0 0 16px;
  border-bottom: #d5d5d5 1px dashed
}

.HURRY .oneClum>li:last-child {
  margin: 0;
  padding: 0;
  border: none
}

.HURRY .oneClum>li dl dd, .HURRY .oneClum>li dl dt {
  width: auto
}

.HURRY .oneClum>li dl dt {
  font-size: 22px;
  background: url(../../images/common/arrow_r.png) left center no-repeat;
  -ms-background-size: 20px;
  background-size: 20px;
  padding: 0 0 0 30px
}

.HURRY .oneClum>li dl dd {
  padding: 8px 0 0
}

.HURRY .oneClum>li dl dd small {
  text-align: right;
  display: block;
  font-size: 10px
}

@media screen and (max-width:768px) {
  .HURRY .context {
    font-size: 15px
  }

  .HURRY .context strong {
    font-size: 20px
  }

  .HURRY .two>dt {
    width: 100%
  }

  .HURRY .two>dt figure figcaption {
    margin: 4% 0 0
  }

  .HURRY .two>dd {
    width: 100%;
    padding: 15px
  }

  .HURRY .oneClum>li {
    margin: 0 0 4%;
    padding: 0 0 4%
  }

  .HURRY .oneClum>li dl dt {
    background-position: left 4px;
    font-size: 16px;
    line-height: 1.4
  }

  .HURRY .oneClum>li dl dd {
    padding-top: 3px
  }
}

.RECOMMEND .branch {
  margin: 0 0 48px
}

.RECOMMEND .branch figure {
  width: 35%;
  float: left
}

.RECOMMEND .branch dl {
  width: 62%;
  float: right
}

.RECOMMEND .branch dl dt {
  font-size: 26px;
  font-weight: 700;
  line-height: 1.6;
  margin: 0 0 16px
}

.RECOMMEND .branch dl dd {
  font-size: 15px
}

.RECOMMEND .listable li {
  border: 8px solid #f2f2f2;
  padding: 24px;
  margin: 0 0 24px;
  list-style: none
}

.RECOMMEND .listable li:last-child {
  margin: 0
}

.RECOMMEND .listable li dl dt {
  color: #1e7431;
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 12px;
  padding: 0 0 8px 24px;
  border-bottom: #d5d5d5 1px dashed;
  background: url(../../images/common/arrow_r.png) left 7px no-repeat;
  -ms-background-size: 18px;
  background-size: 18px
}

.RECOMMEND .listable li dl dd {
  font-size: 15px;
  text-align: justify
}

@media screen and (max-width:768px) {
  .RECOMMEND .branch dl, .RECOMMEND .branch figure {
    float: none;
    width: auto
  }

  .RECOMMEND .branch {
    margin: 0 0 20px
  }

  .RECOMMEND .branch dl dt {
    font-size: 18px;
    margin: 10px 0
  }

  .RECOMMEND .branch dl dd {
    font-size: 12px
  }

  .RECOMMEND .listable li {
    padding: 15px;
    margin: 0 0 4%
  }

  .RECOMMEND .listable li dl dt {
    font-size: 16px
  }

  .RECOMMEND .listable li dl dd {
    font-size: 14px
  }
}

.MISSION .basic {
  margin: 0 0 56px
}

.MISSION .basic li {
  list-style: none;
  border: 8px solid #f2f2f2;
  text-align: center;
  font-size: 17px;
  margin: 0 0 16px;
  padding: 24px 0;
  font-weight: 700
}

.MISSION .basic li:last-child {
  margin: 0
}

.MISSION .activity {
  border: 8px solid #f2f2f2;
  padding: 24px;
  margin: 0 0 30px
}

.MISSION .activity:last-of-type {
  margin-bottom: 0
}

.MISSION .activity:after {
  content: attr(data-small);
  display: block;
  text-align: right
}

.MISSION .activity li {
  font-size: 16px;
  list-style: none;
  padding: 0 0 24px 20px;
  margin: 0 0 24px;
  border-bottom: #d5d5d5 1px dashed;
  position: relative;
  top: 0;
  left: 0
}

.MISSION .activity li:before {
  content: '';
  width: 10px;
  height: 10px;
  background: #ED7D31;
  position: absolute;
  top: 9px;
  left: 0;
  transform: rotate(45deg)
}

@media screen and (max-width:768px) {
  .MISSION .basic {
    margin: 0 0 36px
  }

  .MISSION .basic li {
    padding: 15px;
    font-size: 15px
  }

  .MISSION .activity {
    padding: 15px
  }

  .MISSION .activity:after {
    text-align: center;
    font-size: 10px
  }

  .MISSION .activity li {
    padding-bottom: 15px;
    margin-bottom: 15px;
    font-size: 15px
  }
}

.LETTER .context {
  font-size: 20px;
  text-align: center;
  margin: 0 0 30px
}

.LETTER .context strong {
  display: block;
  font-size: 24px
}

.LETTER .Left {
  width: 46%;
  float: left
}

.LETTER .Left figure img {
  -o-box-shadow: 0 0 15px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 15px rgba(0, 0, 0, .15);
  box-shadow: 0 0 15px rgba(0, 0, 0, .15)
}

.LETTER .Left figure p {
  color: #151515;
  font-size: 12px;
  margin: 5px 0 0
}

.LETTER .Right {
  width: 50%;
  float: right
}

.LETTER .Right p {
  margin: 0 0 20px
}

.LETTER .Right dl {
  margin-bottom: 50px
}

.LETTER .Right dl dt {
  font-size: 20px;
  color: #33b0bd;
  border-bottom: 1px solid #d5d5d5;
  margin: 0 0 12px;
  padding: 0 0 5px
}

.LETTER .Right dl dt:before {
  content: "";
  color: #fff;
  background: #ED7D31;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  display: inline-block;
  margin-right: 12px;
  padding: 9px 0 0 8px;
  font-size: 18px
}

.LETTER .Right dl dt:first-of-type:before {
  content: "簡単"
}

.LETTER .Right dl dt:nth-of-type(2):before {
  content: "満足"
}

.LETTER .Right dl dd {
  margin-bottom: 30px
}

.LETTER .Right figure {
  width: 40%;
  float: right
}

.LETTER .Right .list {
  width: 58%;
  float: left
}

.LETTER .Right .list dt {
  padding-bottom: 0;
  border: none;
  margin-bottom: 10px;
  text-align: center
}

.LETTER .Right .list dt:before {
  content: none !important
}

.LETTER .Right .list dd ul>li {
  list-style: none;
  width: 32%;
  float: left;
  margin: 0 2% 2% 0;
  font-size: 18px;
  color: #ae5ca1;
  background: #ebd6e8;
  text-align: center;
  border-radius: 8px;
  padding: 10px
}

.LETTER .Right .list dd ul>li:nth-child(3n+1) {
  clear: both
}

.LETTER .Right .list dd ul>li:nth-child(3n+3) {
  margin-right: 0
}

.LETTER .Right .list dd ul>li:nth-last-child(-n+3) {
  margin-bottom: 0
}

.LETTER .Right .list dd ul>li:last-child {
  width: 100%;
  margin-right: 0
}

@media screen and (max-width:768px) {
  .LETTER .Left, .LETTER .Right {
    width: auto;
    float: none
  }

  .LETTER .context {
    font-size: 14px;
    margin: 0 0 10px
  }

  .LETTER .context strong {
    font-size: 18px
  }

  .LETTER .context strong span {
    display: block
  }

  .LETTER .Left {
    margin: 0 0 30px
  }

  .LETTER .Right p {
    margin: 0 0 10px
  }

  .LETTER .Right dl dt {
    font-size: 20px;
    line-height: 1.4;
    text-align: center;
    padding: 0 0 8px
  }

  .LETTER .Right dl dt:before {
    display: block;
    margin: 0 0 8px;
    width: 100%;
    height: auto;
    border-radius: 0;
    padding: 3px 10px;
    text-align: center
  }

  .LETTER .Right .list, .LETTER .Right figure {
    width: auto;
    float: none
  }

  .LETTER .Right figure {
    margin: 0 0 12px
  }
}

.CLEANUP .h3_after {
  font-size: 32px;
  font-weight: 700;
  margin: 0 0 32px;
  text-align: center
}

@media screen and (max-width:768px) {
  .CLEANUP .h3_after {
    font-size: 18px;
    margin: 0 0 24px
  }

  .CLEANUP .second .twoClum>li {
    width: 100%
  }
}

.CLEANUP h3 {
  margin: 0 0 12px !important
}

.CLEANUP .second .twoClum>li dl dt {
  margin: 0;
  color: #151515;
  font-size: 16px;
  background: url(../../images/common/circle_arrow.png) left center no-repeat;
  -ms-background-size: 16px;
  background-size: 16px;
  padding-left: 26px
}

.CLEANUP .third .flowList {
  width: 100%;
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  justify-content: flex-start;
  counter-reset: num
}

.CLEANUP .third .flowList>li {
  list-style: none;
  width: 22%;
  margin: 0 4% 4% 0;
  padding-bottom: 60px;
  -o-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  box-shadow: 0 0 5px rgba(0, 0, 0, .15);
  position: relative
}

@media screen and (min-width:769px) {
  .CLEANUP .third .flowList>li:nth-child(4n+4) {
    margin-right: 0
  }
}

@media screen and (max-width:768px) {
  .CLEANUP .third .flowList>li {
    width: 100%;
    margin: 0 0 25px
  }
}

.CLEANUP .third .flowList>li:before {
  counter-increment: num;
  content: counter(num);
  font-size: 42px;
  color: #d5d5d5;
  display: block;
  width: 100%;
  text-align: center;
  position: absolute;
  bottom: 0;
  left: 0
}

.CLEANUP .third .flowList>li:after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 30px 0 30px 20px;
  border-color: transparent transparent transparent #d5d5d5;
  position: absolute;
  top: 50%;
  right: -20px;
  transform: translateX(0) translateY(-50%)
}

@media screen and (max-width:768px) {
  .CLEANUP .third .flowList>li:after {
    border-width: 20px 30px 0;
    border-color: #d5d5d5 transparent transparent;
    top: auto;
    bottom: -20px;
    right: 50%;
    transform: translateX(50%) translateY(0)
  }
}

.CLEANUP .third .flowList>li:last-child:after {
  content: none
}

.CLEANUP .third .flowList>li dl {
  padding: 20px
}

.CLEANUP .third .flowList>li dl dt {
  font-size: 22px;
  font-weight: 700;
  color: #33b0bd;
  text-align: center;
  padding: 0 0 5px;
  margin: 0 0 15px;
  border-bottom: 1px solid #d5d5d5
}

.CLEANUP .third .btnArea {
  text-align: center
}

.CLEANUP .third .btnArea .button {
  display: inline-block;
  padding: 15px 80px;
  font-size: 18px
}

.CLEANUP .five .three {
  border: 10px solid rgba(0, 0, 0, .1);
  width: 100%;
  background: #FFF;
  box-shadow: 0 0 8px rgba(0, 0, 0, .16);
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between
}

.CLEANUP .five .three>li {
  list-style: none;
  width: 33.3%;
  padding: 25px;
  border-right: 1px dotted #d5d5d5
}

.CLEANUP .five .three>li:last-child {
  border-right: none
}

@media screen and (max-width:768px) {
  .CLEANUP .five .three>li {
    padding: 10px
  }
}

.CLEANUP .five .three>li figure figcaption {
  display: block;
  padding-top: 12px;
  font-size: 18px;
  font-weight: 700;
  color: #151515;
  text-align: center
}

.OTAKIAGE.first .context, .OTAKIAGE.first h3 {
  font-weight: 700 !important;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-feature-settings: "palt";
  letter-spacing: .04em
}

.OTAKIAGE.first .LOCALNAV {
  padding: 65px 0
}

.OTAKIAGE.first .center {
  text-align: center;
  font-size: 18px;
  margin: 0 0 30px;
  font-weight: 400
}

.OTAKIAGE.first .tableStyle td, .OTAKIAGE.first .tableStyle th {
  padding: 6px;
  text-align: center;
  vertical-align: middle;
  font-size: 15px;
  font-weight: 700 !important;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-feature-settings: "palt";
  letter-spacing: .04em
}

.OTAKIAGE.first .tableStyle td i, .OTAKIAGE.first .tableStyle th i {
  color: #ED7D31
}

.OTAKIAGE.first .tableStyle .one {
  width: 50%
}

.OTAKIAGE.first .tableStyle .two {
  width: 25% !important
}

.OTAKIAGE.first .tableStyle th.bg {
  background: #d0d0d0;
  width: 18%
}

.OTAKIAGE.first .tableStyle td.bg {
  background: #f5f5f5
}

@media screen and (min-width:769px) {
  .OTAKIAGE.first .twoClum>li {
    list-style: none;
    width: 49%;
    float: left;
    margin: 0 2% 2% 0
  }

  .OTAKIAGE.first .twoClum>li:nth-child(2n+1) {
    clear: both
  }

  .OTAKIAGE.first .twoClum>li:nth-child(2n+2) {
    margin-right: 0
  }

  .OTAKIAGE.first .twoClum>li:nth-last-child(-n+2) {
    margin-bottom: 0
  }
}

.OTAKIAGE.first .twoClum>li dl {
  border-radius: 4px;
  -o-box-shadow: 0 0 4px rgba(0, 0, 0, .15);
  -ms-box-shadow: 0 0 4px rgba(0, 0, 0, .15);
  box-shadow: 0 0 4px rgba(0, 0, 0, .15);
  padding: 20px;
  min-height: 235px
}

.OTAKIAGE.first .twoClum>li dl dt {
  font-size: 19px;
  font-weight: 600;
  margin: 0 0 10px;
  color: #33b0bd
}

.OTAKIAGE.first .text {
  margin-bottom: 30px
}

.OTAKIAGE.first .flex {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 40px
}

.OTAKIAGE.first .flex figure {
  box-shadow: 0 0 4px rgba(0, 0, 0, .15)
}

.OTAKIAGE.first .flex .flexChild {
  display: flex;
  flex-wrap: wrap;
  width: 49%;
  margin-left: 1%
}

@media screen and (max-width:768px) {
  .OTAKIAGE.first .flex .flexChild {
    justify-content: center;
    width: 100%;
    margin-top: 30px;
    margin-left: 0
  }
}

.OTAKIAGE.first .flex .flexChild dl {
  margin-top: 57px
}

@media screen and (max-width:768px) {
  .OTAKIAGE.first .flex .flexChild dl {
    margin-top: 20px
  }
}

.OTAKIAGE.first .flex .flexChild dl dt {
  font-size: 20px;
  border-bottom: 1px solid #D0D0D0;
  padding-right: 60px;
  color: #4C9347
}

.OTAKIAGE.first .flex .flexChild dl dd {
  margin: 10px 0 0 10px;
  font-weight: 700;
  font-size: 16px
}

.OTAKIAGE.first .flex .flexChild dl dd:last-child {
  margin: 0 7px 0 16px;
  font-size: 15px
}

.OTAKIAGE.first .center1 {
  text-align: center;
  padding-top: 40px;
  font-size: 20px;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-weight: 500;
  font-feature-settings: "palt";
  letter-spacing: .04em
}

@media screen and (max-width:768px) {
  .OTAKIAGE .scroll {
    overflow-x: scroll
  }

  .OTAKIAGE .scroll:before {
    content: "横にスクロールして下さい。";
    color: #fff;
    font-weight: 700;
    font-size: 14px;
    display: inline-block;
    padding: 0 15px;
    margin: 0 0 3px;
    border-radius: 5px;
    background: #ED7D31
  }

  .OTAKIAGE .tableStyle {
    width: 180% !important
  }

  .OTAKIAGE .tableStyle td, .OTAKIAGE .tableStyle th {
    display: table-cell !important;
    font-size: 13px;
    padding: 8px
  }

  .OTAKIAGE figure {
    width: 90%
  }

  .OTAKIAGE .flexChild {
    width: 90%;
    margin-left: 0
  }

  .OTAKIAGE .flexChild img {
    box-shadow: 0 1px 5px -3px rgba(0, 0, 0, .1), 0 1px 5px -3px rgba(0, 0, 0, .1)
  }

  .OTAKIAGE .center1 {
    width: 90%;
    font-size: 16px !important;
    margin: auto
  }
}

#WRAPPER {
  padding: 140px 0 0
}

#MAIN {
  background: url(../images/common/h2.jpg) center no-repeat;
  -ms-background-size: cover;
  background-size: cover
}

#MAIN .display {
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  align-items: center;
  height: 260px
}

#MAIN .display h2, #MAIN .display .column-fix01 {
  text-align: center;
  margin: 0 auto;
  line-height: 1;
  font-size: 12px;
  font-weight: 700
}

#MAIN .display h2:before, #MAIN .display .column-fix01:before {
  content: attr(data-text);
  display: block;
  font-size: 36px;
  margin: 0 0 18px;
  letter-spacing: .095em
}

#MAIN .display #bread {
  position: absolute;
  top: 25px;
  left: 0
}

@media screen and (max-width:768px) {
  #WRAPPER {
    padding: 64px 0 0
  }

  #MAIN .display {
    height: 150px;
    width: 100%
  }

  #MAIN .display h2, #MAIN .display .column-fix01 {
    font-size: 10px
  }

  #MAIN .display h2:before, #MAIN .display .column-fix01:before {
    font-size: 20px;
    margin: 0 0 10px
  }

  #MAIN .display #bread {
    top: 10px;
    left: 12px
  }
}

#MAIN .display #bread ol {
  background: url(../images/common/home_arrow_2x.png) left 3px no-repeat;
  -ms-background-size: 13px;
  background-size: 13px;
  padding: 0 0 0 20px
}

#MAIN .display #bread ol li {
  list-style: none;
  float: left;
  font-size: 11px;
  background: url(../images/common/bread_arrow_2x.png) right center no-repeat;
  -ms-background-size: 4px 7px;
  background-size: 4px 7px;
  padding: 0 15px 0 0;
  margin: 0 10px 0 0
}

#MAIN .display #bread ol li:last-child {
  margin: 0;
  padding: 0;
  background: 0 0
}

#MAIN .display #bread ol li a {
  color: #151515
}

.MODULE .wrap {
  padding: 65px 0
}

@media screen and (max-width:768px) {
  .MODULE .wrap {
    padding: 30px 12px
  }
}

.MODULE .no-top {
  padding-top: 0 !important
}

.MODULE .no-bottom {
  padding-bottom: 0 !important
}

.MODULE h3 {
  font-size: 28px;
  font-weight: 700;
  text-align: center;
  margin: 0 0 30px
}

.MODULE h3:after {
  content: attr(data-text);
  display: block;
  font-size: 12px;
  font-weight: 400
}

@media screen and (max-width:768px) {
  .MODULE h3 {
    font-size: 22px;
    margin: 0 0 20px
  }

  .MODULE h3:after {
    font-size: 10px
  }
}

.MODULE h4, .MODULE .column-fix02 {
  font-size: 20px;
  font-weight: 600;
  border-bottom: 1px solid #d5d5d5;
  padding: 0 0 7px;
  margin: 0 0 20px;
  position: relative
}

.MODULE h4:before, .MODULE .column-fix02:before {
  content: "◆";
  color: #33b0bd;
  display: inline-block;
  margin-right: 10px
}

.MODULE h4 time {
  font-size: 12px;
  color: #fff;
  background: #33b0bd;
  display: inline-block;
  padding: 5px 12px;
  position: absolute;
  top: auto;
  right: 0
}

@media screen and (max-width:768px) {
  .MODULE h4, .MODULE .column-fix02 {
    font-size: 15px;
    margin: 0 0 12px
  }
}

.MODULE img {
  max-width: 100%
}

.MODULE .exp {
  text-align: center;
  color: #FFF;
  padding: 7px 5px;
  background: #ED7D31;
  font-size: 19px;

}

.MODULE a.button {
  background: #ED7D31;
  color: #fff
}

.INDEX.first ul .st-c dl dd.price {
  color: #1f8e38;
}


.MODULE .st-c a.button, .st-c .exp {
  background-color: #1f8e38;
}

.INDEX.first ul .fam-c dl dd.price {
  color: #3c5099;
}

.MODULE .fam-c a.button, .fam-c .exp {
  background-color: #3c5099;
}

.INDEX.first ul .nor-c dl dd.price {
  color: #7f3bb3;
}

.MODULE .nor-c a.button, .nor-c .exp {
  background-color: #7f3bb3;
}

.MODULE a.c_btn {
  font-size: 15px;
  border-radius: 18px;
  padding: 8px 50px
}

.MODULE .tableStyle {
  width: 100%;
  margin-bottom: 30px;
  border: 1px solid #d5d5d5;
  border-collapse: collapse
}

.MODULE .tableStyle th {
  border: 1px solid #d5d5d5;
  padding: 15px;
  vertical-align: middle;
  text-align: left;
  background: #f5f5f5
}

.MODULE .tableStyle td {
  border: 1px solid #d5d5d5;
  padding: 15px;
  background: #fff
}

@media screen and (max-width:768px) {
  .MODULE .tableStyle {
    border: none;
    border-bottom: 1px solid #d5d5d5
  }

  .MODULE .tableStyle td, .MODULE .tableStyle th {
    padding: 8px 10px;
    display: block;
    border-bottom: none
  }
}

.absOpen, .fixOpen {
  position: fixed;
  top: 0;
  left: 0;
  display: none;
  background: #FFF;
  width: 100%;
  z-index: 100
}

.absOpen .OPEN, .fixOpen .OPEN {
  display: block !important
}

.absOpen {
  height: 100%;
  overflow: auto
}

.DEMO .BLOCK, .LOCALNAV nav.twodown ul {
  overflow: hidden
}

.absOpen .close {
  background: #fff;
  background: linear-gradient(to bottom, #fff 0, #ededed 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#ededed', GradientType=0);
  border: 1px solid #d5d5d5;
  padding: 8px 0;
  text-align: center;
  font-size: 15px;
  border-radius: 6px;
  margin: 0 0 16px
}

.OPEN {
  display: none;
  padding: 40px
}

.OPEN strong {
  display: block;
  text-align: center;
  line-height: 1.4;
  color: #ED7D31;
  font-size: 32px
}

.OPEN strong i {
  font-size: 56px
}

@media screen and (min-width:769px) {
  .OPEN ul li {
    list-style: none;
    width: 49%;
    float: left;
    margin: 0 2% 2% 0
  }

  .OPEN ul li:nth-child(2n+1) {
    clear: both
  }

  .OPEN ul li:nth-child(2n+2) {
    margin-right: 0
  }

  .OPEN ul li:nth-last-child(-n+2) {
    margin-bottom: 0
  }
}

@media screen and (max-width:768px) {
  .OPEN strong {
    font-size: 18px
  }

  .OPEN strong i {
    font-size: 30px
  }

  .OPEN {
    padding: 12px
  }

  .OPEN ul li {
    list-style: none;
    margin: 0 0 12px
  }
}

.OPEN dl {
  border: 1px solid #d5d5d5;
  width: 100%
}

.OPEN dl dt {
  background: #33b0bd;
  color: #fff;
  width: 100%;
  padding: 8px 10px;
  font-size: 20px;
  font-weight: 600;
  position: relative
}

@media screen and (max-width:768px) {
  .OPEN dl dt {
    font-size: 16px
  }
}

.OPEN dl dt em {
  font-style: normal;
  font-size: 14px;
  line-height: 1.3;
  text-align: right;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateX(0) translateY(-50%)
}

@media screen and (max-width:768px) {
  .OPEN dl dt em {
    font-size: 12px;
    display: block;
    position: static;
    transform: translateX(0) translateY(0);
    text-align: left
  }
}

.INDEX .OPEN>strong, .OPEN dl dd.fax {
  display: none
}

.OPEN dl dd {
  text-align: center;
  padding: 8px 10px
}

@media screen and (max-width:768px) {
  .OPEN dl dd {
    padding: 0 10px
  }
}

.OPEN dl dd span {
  color: #ED7D31;
  font-size: 32px;
  background: url(../images/common/icn_free_2x.png) left center no-repeat;
  -ms-background-size: 41px 27px;
  background-size: 41px 27px;
  padding-left: 50px
}

@media screen and (max-width:768px) {
  .OPEN dl dd span {
    font-size: 26px
  }
}

.INDEX .OPEN .faxView dl dd {
  background: #f8f8f8
}

.INDEX .OPEN .faxView dl dd span {
  font-size: 20px;
  background: url(../images/common/icn_free_2x.png) left center no-repeat;
  -ms-background-size: 24px;
  background-size: 24px;
  padding-left: 32px
}

.INDEX .OPEN .faxView dl dd.fax {
  display: block;
  border-bottom: #d5d5d5 1px solid;
  background: #FFF
}

.INDEX .OPEN .faxView dl dd.fax span {
  background: url(../images/common/icn_fax_2x.png) left center no-repeat;
  -ms-background-size: 41px 27px;
  background-size: 41px 27px;
  padding-left: 50px;
  font-size: 32px
}

.LOCALNAV .context {
  font-size: 20px;
  font-weight: 600;
  text-align: center
}

.LOCALNAV nav {
  display: block;
  margin: 43px 0 0
}

@media screen and (min-width:769px) {
  .LOCALNAV nav.twodown ul li {
    width: 33%
  }

  .LOCALNAV nav.twodown ul li:nth-child(1), .LOCALNAV nav.twodown ul li:nth-child(2), .LOCALNAV nav.twodown ul li:nth-child(3) {
    border-bottom: #d5d5d5 1px solid
  }

  .LOCALNAV nav.twodown ul li:nth-child(3) {
    border-right: none
  }
}

.LOCALNAV nav ul {
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  display: flex;
  -o-flex-flow: row wrap;
  flex-flow: row wrap;
  -o-justify-content: space-between;
  -ms-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  width: 100%;
  border: 1px solid #d5d5d5;
  border-radius: 8px
}

.LOCALNAV nav ul li {
  background: linear-gradient(180deg, #fff, #f2f2f2);
  width: 14.2%;
  flex-grow: 1;
  -webkit-box-flex: 1;
  text-align: center;
  border-right: 1px solid #d5d5d5
}

.LOCALNAV nav ul li:last-child {
  border-right: none
}

.LOCALNAV nav ul li a {
  display: block;
  color: #151515;
  font-size: 15px;
  padding: 12px 0
}

@media screen and (max-width:768px) {
  .LOCALNAV .context {
    font-size: 15px
  }

  .LOCALNAV nav {
    margin: 20px 0 0
  }

  .LOCALNAV nav ul li {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid #d5d5d5
  }

  .LOCALNAV nav ul li:first-child {
    border-radius: 8px 8px 0 0
  }

  .LOCALNAV nav ul li:last-child {
    border-radius: 0 0 8px 8px;
    border-bottom: none
  }

  .LOCALNAV nav ul li a {
    font-size: 14px !important;
    padding: 8px 0 !important
  }
}

.DEMO {
  background-repeat: no-repeat;
  background-position: top center;
  margin: 0 0 60px
}

.DEMO .BLOCK {
  width: 1280px;
  margin: 0 auto
}

.DEMO .BLOCK img {
  opacity: 0;
  position: relative;
  top: 0;
  left: -190px
}

img.centered {
  display: block;
  margin-left: auto;
  margin-right: auto
}

img.alignright {
  padding: 4px;
  margin: 0 0 2px 10px;
  display: inline
}

img.alignleft {
  padding: 4px;
  margin: 0 10px 2px 0;
  display: inline
}

.alignleft {
  float: left;
  margin: .5em 1em .5em 0
}

.alignright {
  float: right;
  margin: .5em 0 .5em 1em
}

/* 2020.11.16 追記 */
.bannar-a {
  width: 900px;
  margin: 0 auto 60px;
  text-align: center;
}

.bannar-a a {
  width: 100%;
}

.bannar-a a img {
  max-width: 100%;
  box-shadow: 0 0 10px rgba(0, 0, 0, .15);
}

.hall-content h2 {
  color: black;
  border-left: 4px solid #33b0bd;
  padding: 0 0 0 10px;
  margin: 0 0 5px;
}

.hall-content h2 span {
  color: black;
}

.th-a {
  color: white;
  background-color: #33b0bd;
  vertical-align: middle;
  padding: 10px;
  line-height: 1.2;
}

.th-b {
  background-color: #f5f5f5;
  vertical-align: middle;
  padding: 10px;
  line-height: 1.2;
}

.hall-content table td {
  vertical-align: middle;
  padding: 10px;
  line-height: 1.2;
}

@media screen and (max-width:768px) {
  .bannar-a {
    width: 94%;
  }

}

/*  */
p {
  position: relative;
}

.text-adj {
  position: absolute;
  top: 0;
  left: 385px;
}

.text-adj-02 {
  margin-top: 30px !important;
}

.text-adj-03 {
  margin-bottom: 30px !important;
}

/*採用追記*/


/*******************************/
/*タブ切り替え*/
/*******************************/

/* 先輩社員紹介：タブ */
.rec_staff_tab {
  display: flex;
  width: 100%;
  overflow-x: auto;
  padding: 0 20px;
  list-style: none;
}

.rec_staff_job_column p {
  line-height: 1.6;
  margin-bottom: 20px;
}

.rec_staff_job_column .sec3-wrapper {
  max-width: inherit;
}

.rec_staff_tab li {
  border: solid 1px #D9D9D9;
  border-bottom: none;
  cursor: pointer;
  padding: 20px;
  min-width: 200px;
  text-align: center;
}

.rec_staff_tab li:nth-of-type(1) {
  border: solid 1px #7F7F7F;
  border-bottom: 1px solid #ffffff;
  z-index: 2;
}

.rec_staff_tab li:nth-of-type(1).nonactive {
  z-index: 0;
  border: solid 1px #D9D9D9;
  border-bottom: none;

}

.rec_staff_tab li.active {
  border: solid 1px #7F7F7F;
  border-bottom: solid 1px #fff;
  z-index: 2;
  background: #fff;
}

.rec_staff_tab li img {
  aspect-ratio: 11 / 9;
  width: 100%;
  object-fit: cover;
}

/* 先輩社員紹介：コンテンツ部分 */
.staff_info-cnt01,
.staff_info-cnt02,
.staff_info-cnt03,
.staff_info-cnt04,
.staff_info-cnt05 {
  display: none;
}

.rec_staff_job.job-box {
  border-top: 1px solid #7F7F7F;
  z-index: 5;
  background: #fff;
  border-bottom: 1px solid #7F7F7F;

}

.rec_staff_job .job-enclose {
  padding: 50px 0 40px 0;
}

.rec_staff_job_column .essential p:nth-of-type(1) {
  margin-top: -1.50px;
}

.rec-sec {
  display: flex;
  justify-content: space-between;
}

.rec-img {
  width: 39.6%;
}

.rec-img img {
  aspect-ratio: 65 / 48;
  object-fit: cover;
  width: 100%;
}

.rec-text {
  width: 57.4%;
}

.rec-text h3 {
  font-size: 2.40px;
}

@media only screen and (max-width: 768px) {
  .rec_staff_job_column {
    flex-wrap: wrap;
  }

  .rec_staff_job_column>div:nth-of-type(1),
  .rec_staff_job_column>div:nth-of-type(2) {
    width: 100%;
    padding-left: 0;
  }

  .rec_sikaku_wrap.column2>div {
    width: 100%;
  }

  .rec_staff_job_column .sec3-wrapper .afs18 {
    font-size: 18px;
  }

  .rec-sec {
    flex-direction: column;
    align-items: center;
  }

  .rec-img {
    width: 100%;
    max-width: 520px;
    margin-bottom: 20px;
  }


  .rec-text {
    width: 100%;
  }

  .rec-text h3 {
    font-size: 2.40px;
  }
}

/* 募集要項 */
.rec_app_wrap#job-parent {
  margin: 0;
  padding-top: 10px;
}

.rec_app_wrap .column2>div {
  width: 49%;
}

.rec_app_tab {
  margin-top: -10px;
}

.rec_app_tab ul#job-select li {
  background: #fff;
  padding: 43px 0;
  font-size: 20px;
}

.rec_app_job.job-box {
  border-top: 1px solid #7F7F7F;
}

.rec_app_job .job-enclose {
  padding: 40px 0 30px 0;
  border-bottom: 1px solid #A6A6A6;
}

.rec_app_contents {
  width: 100%;
}

.rec_app_contents tr:first-child {
  border-top: solid 1px #BFBFBF;
}

.rec_app_contents tr {
  border-bottom: solid 1px #BFBFBF;
}

.rec_app_contents th,
.rec_app_contents td {
  padding: 10px 0;
}

.rec_app_contents th {
  padding-left: 10px;
  padding-right: 20px;
  vertical-align: top;
  width: 17%;
}

@media only screen and (max-width: 768px) {

  .rec_app_contents th,
  .rec_app_contents td {
    width: 100%;
    display: block;
    padding: 10px 0 0 10px;
  }

  .rec_app_wrap .column2>div {
    width: 100%;
  }

  .rec_app_tab ul#job-select li {
    font-size: 13px;
    text-align: center;
    padding: 22px 2px;
  }
}

.recruitment-list {
  width: 100%;
  border-top: solid 1px #BFBFBF;
}

.recruitment-list .recruitment-detail {
  display: flex;
  border-bottom: solid 1px #BFBFBF;
}

@media screen and (max-width: 768px) {
  .recruitment-list .recruitment-detail {
    display: block;
  }
}

@media screen and (max-width: 768px) {
  .stan {
    overflow-y: scroll;
    height: 160px;
  }
}


.recruitment-list .recruitment_head {
  width: 15%;
  max-width: 140px;
  padding: 10px 0;
}

@media screen and (max-width: 768px) {
  .recruitment-list .recruitment_head {
    width: 100%;
    padding: 10px 0 10px 10px;
    font-weight: bold;
  }
}

.recruitment-list .recruitment_data {
  width: 85%;
  padding: 10px 0 10px 20px;
}

@media screen and (max-width: 768px) {
  .recruitment-list .recruitment_data {
    width: 100%;
  }
}

.member-info {
  display: flex;
}

@media screen and (max-width: 1280px) {
  .member-info {
    display: block;
  }
}

.member-info .member-img {
  width: 32%;
  max-width: 520px;
}

@media screen and (max-width: 1280px) {
  .member-info .member-img {
    width: 100%;
    margin: 0 auto 40px;
  }
}

.member-info .member-text {
  width: 68%;
  max-width: 1110px;
  padding-left: 30px;
}

@media screen and (max-width: 1280px) {
  .member-info .member-text {
    width: 100%;
    padding: 0;
  }
}

#job-parent {
  width: 100%;
  margin: 0 auto 35px;
}

@media only screen and (max-width: 599px) {
  #job-parent {
    margin-bottom: 40px;
  }
}

.job-box {
  width: 100%;
  margin: -1px auto 0;
  background: rgba(255, 255, 255, 0.5);
  overflow-y: auto;
}

.job-box .info-cnt01,
.job-box .info-cnt02,
.job-box .info-cnt03,
.job-box .info-cnt04 {
  display: none;
}

.job-select-parent {
  position: relative;
  width: 98%;
  margin: 0 auto;
  z-index: 5;
}

#job-select {
  display: flex;
}

#job-select li {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 70px;
  border: solid 1px #bfbfbf;
  border-bottom: 1px solid #7f7f7f;
  background: #f2f2f2;
  cursor: pointer;
}

#job-select li p {
  width: 100%;
  line-height: 1.3;
  text-align: center;
  font-family: "游明朝", "Yu Mincho", "HGP明朝B", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", "HiraMinProN-W6", serif;
}

#job-select li:nth-last-of-type(1) {
  border-right: solid 1px #bfbfbf;
}

#job-select li:nth-of-type(1) {
  color: #000;
  border: solid 1px #7f7f7f;
  border-bottom: solid 1px #ffffff;
  background: #fff;
  z-index: 5;
}

#job-select {
  width: 100%;
  margin: 0 auto;
}

#job-select li.active {
  background: #fff;
  border: solid 1px #7f7f7f;
  border-bottom: solid 1px #fff;
  z-index: 5;
}

#job-select li.nonactive {
  background: #f2f2f2;
  border: solid 1px #bfbfbf;
  border-bottom: solid 1px #7f7f7f;
}

.job-enclose {
  width: 100%;
  margin: 0 auto;
  padding: 40px 10px 10px;
}

.job-enclose section>p {
  margin-bottom: 20px;
}

.rec-wrapper .afs18 {
  font-size: 21px;
  font-weight: 600;
  padding-bottom: 10px
}

.rec-wrapper .afs12 {
  font-size: 14.7px;
}

@media screen and (max-width: 768px) {
  .job-description {
    margin-bottom: 80px;
  }

  .rec_app_job .job-enclose {
    padding-bottom: 100px;
  }
}

/*******************************************/
/*プライバシーポリシーのページ*/
/*******************************************/
.privacy section li {
  padding-bottom: 20px;
  list-style: decimal inside;
  text-align: left;
}

.privacy section .inner {
  max-width: 980px;
}

/*******************************************/
/*メールフォーム*/
/*******************************************/
.mailform {
  width: 100%;
  max-width: 1080px;
  border: 1px solid #BFBFBF;
  padding: 60px 40px 60px;
  margin: 0 auto;
}

.mailform iframe {
  width: 100%;
  height: 100%;
}

.mailform-recruit {
  width: 100%;
  margin: 30px auto 0;
  max-width: 1200px;
}

.mailform-recruit iframe {
  width: 100%;
  height: 100%;
}

.tbl_form_box:first-of-type {
  border-bottom: 1px solid #D9D9D9;
}

.tbl_form_box dl {
  border-top: 1px solid #D9D9D9;
  margin: 0;
  display: flex;
  padding: 10px 10px;
}

.tbl_form_box dt {
  width: 30%;
  padding-right: 5px;
  padding-left: 40px;
  font-size: 1.70px;
  font-weight: normal;
}

.txt_req::after {
  content: "(必須)";
  display: inline-block;
  margin-left: 5px;
  color: #E71300;
}

.tbl_form_box dd {
  width: 63%;
}

dd input[type=radio] {
  width: 1em;
}

dd input[type=checkbox] {
  width: 1em;
}

dd input[type=file] {
  border: none;
  padding: 0;
  font-size: 16px;
}

dd input,
dd textarea {
  width: 100%;
  background: none;
  border: solid 1px #D9D9D9;
  border-radius: 2px;
  padding: 4px;
  font-size: 16px;
}

input[type=submit] {
  width: 200px;
  height: 40px;
  font-size: 16px;
}

.form_submit {
  text-align: center;
  margin-top: 40px;
}

.tbl_form_box .first {
  margin-left: 0;
}

.wid-s {
  width: 60px;
}

.wpcf7-spinner {
  display: none !important;
}

.block span.wpcf7-list-item {
  display: block;
}

.wpcf7-list-item {
  padding-right: 10px;
  margin: 0 !important;
}

p.tenpu {
  color: #c00000;
}

@media screen and (max-width:768px) {
  .tbl_form_box dl {
    flex-direction: column;
  }

  .tbl_form_box dt,
  .tbl_form_box dd {
    width: 100%;
    padding: 0;
    margin: 0;
  }

  .mailform {
    border: none;
    padding: 0;
  }

  .rec-wrapper .mailform-recruit p {
    font-size: 14px;
  }


}


/*******************************************/
/*個人情報の取り扱いについて*/
/*******************************************/
.privacy-check-box {
  border: solid 1px #D9D9D9;
  margin-top: 20px;
  padding: 20px;
}

.box-bor-gry-in {
  width: 100%;
  padding: 8px;
  border-bottom: 1px solid #D9D9D9
}

.mb20 {
  margin-bottom: 20px;
}

.rec-wrapper .box-bor-gry-in p,
.rec-wrapper .box-bor-gry-in li {
  font-size: 14px;
  margin-bottom: 10px;
}

.list-non-mark {
  list-style: none;
}

/*mailform*/
.contact-check {
  text-align: center;
}

.contact-check a {
  display: inline;
  text-decoration: underline;
}

@media screen and (max-width: 1280px) {
  .privacy-check-box {
    margin-top: 20px;
    padding: 10px;
  }

  .privacy-check-box .afs12,
  .privacy-check-box .afs11 {
    font-size: 13px;
  }

  .rec-wrapper .box-bor-gry-in p, .rec-wrapper .box-bor-gry-in li {
    font-size: 12px;
  }
}



/*******************************************/

.rec-wrapper {
  max-width: 1310px;
  width: 95%;
  margin: 0 auto 150px;
}

.rec-wrapper:first-of-type {
  margin-top: 80px;
}

.rec-wrapper h3 {
  font-size: 26.7px;
  font-weight: bold;
  padding-bottom: 20px;
  position: relative;
  margin-bottom: 30px;
  text-align: center;
}

.rec-wrapper h3::after {
  content: '';
  display: block;
  width: 100px;
  height: 5px;
  background-color: #21963b;
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
}

.mb40 {
  margin-bottom: 40px;
}

.rec-wrapper .rec-yum {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-size: 32px;
  font-weight: 600;
  margin-bottom: 25px;
}

.tac {
  text-align: center;
}

.rec-wrapper p {
  font-size: 18.7px;
  line-height: 1.8;
}

@media screen and (max-width: 768px) {
  .rec-wrapper {
    margin-bottom: 40px;
  }

  .rec-wrapper:first-of-type {
    margin-top: 30px;
  }

  .rec-wrapper p {
    font-size: 15px;
    line-height: 1.8;
  }

  .rec-wrapper h3 {
    font-size: 22px;
    padding-bottom: 10px;
    margin-bottom: 20px;
  }

  .rec-wrapper h3::after {
    height: 3px;
  }

  .rec-wrapper .rec-yum {
    font-size: 18px;
    margin-bottom: 10px;
  }

  .rec-wrapper .afs18 {
    font-size: 18px;
    padding-bottom: 0;
  }

  .rec-wrapper .afs12 {
    font-size: 12px;
  }

  .rec_staff_tab li {
    padding: 10px;
  }

  .rec_staff_job .job-enclose {
    padding: 20px 0 30px 0;
  }
}

/**/

.rec-wrapper._tab {
  max-width: 1600px;
}

.rec-text h4 {
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 15px;
}

.rec-text h4::before {
  content: '';
  display: inline-block;
  width: 17px;
  height: 17px;
  transform: rotate(45deg);
  background-color: #21963b;
  margin-left: 5px;
}

.rec-text p {
  margin-bottom: 0;
  font-size: 16px;
}

@media screen and (max-width: 768px) {
  .rec-text h4 {
    font-size: 16px;
  }

  .rec-text h4::before {
    width: 12px;
    height: 12px;
  }

  .rec-text p {
    font-size: 12px;
  }
}

/**/

.column2 {
  display: flex;
  justify-content: space-between;
}

.column2 .rec-text {
  width: 48%;
}

.rec-table {
  width: 100%;
  border-top: solid 1px #BFBFBF;
  table-layout: fixed;
}

.rec-table tr {
  border-bottom: solid 1px #BFBFBF;
}

.rec-table th {
  width: 18.7%;
  padding: 10px 0 10px 00px;
  vertical-align: top;
  font-weight: normal;
  font-size: 16px;
  text-align: left;
}

.rec-table td {
  width: 81.3%;
  padding: 10px 0 10px 10px;
  font-size: 16px
}

.rec-table th p, .rec-table td p {
  font-size: 16px;
}

@media screen and (max-width: 1024px) {

  .rec-table th p,
  .rec-table th {
    font-size: 14px;
  }

  .rec-table td p,
  .rec-table td,
  .rec-table dt,
  .rec-table dd {
    font-size: 14px !important;
  }
}

@media screen and (max-width: 768px) {
  .rec-table th {
    display: block;
    width: 100%;
    padding: 5px 0 0 5px;
    font-weight: bold;
  }

  .rec-table td {
    display: block;
    width: 100%;
    padding: 5px 0 5px 5px
  }

  .rec-table td p,
  .rec-table td {
    font-size: 14px !important;
  }

  .column2 {
    flex-direction: column;
  }

  .column2 .rec-text {
    width: 100%;
  }

}

#WRAPPER > article > div.second.display.wrap > div > dl > dd > figure > img {
width:100%}

.MEMBER ul li strong {
font-weight:normal;
}



.aco-wrapper {
    width: 100%;
}

.aco-content {
    cursor: pointer;
    border-top: 1px solid #ccc;
    border-bottom: 1px solid #ccc;
}

.aco-btn.aco-wrapper {
    padding: 1rem 0;
    align-items: center;
    position: relative;
}

.aco-btn:before {
    content: '';
    display: block;
    width: 15px;
    height: 2px;
    background-color: #999;
    transition: all 0.4s;
    position: absolute;
    right: 1%;
    bottom: 50%;
}

.aco-btn:after {
    content: '';
    display: block;
    width: 15px;
    height: 2px;
    background-color: #999;
    transition: all 0.4s;
    position: absolute;
    right: 1%;
    bottom: 50%;
    transform: rotate(90deg);
}

.aco-btn.active:after {
    transform: rotate(0deg);
}

.aco-btn .q-head {
    color: #EB6C84;
    font-size: 2.13rem;
    font-weight: bold;
    letter-spacing: 0.25rem;
    margin: 0;
    float: left;
    line-height: 1.3;
}

.aco-btn.aco-wrapper h4 {
    margin: 0 5rem 0 0;
    padding-left: 5rem;
    font-size: 1.87rem;
    vertical-align: bottom;
}

.aco-text.aco-wrapper {
    position: relative;
    display: none;
}

.aco-text .a-head {
    color:#CC0000;
    font-size: 2.13rem;
    font-weight: bold;
    letter-spacing: 0.25rem;
    line-height: 1;
    margin: 0;
    float: left;
}

.aco-text.aco-wrapper p:not(.a-head) {
    word-break: break-all;
    line-height: 1.3;
    padding-bottom: 2rem;
    padding-left: 5rem;
    margin: 0;
}

.aco-wrapper tr:first-of-type .aco-text {
    display: block;
}

.aco-wrapper tr:first-of-type .aco-btn:after {
    content: '';
    display: block;
    width: 15px;
    height: 2px;
    background-color: #999;
    transition: all 0.4s;
    position: absolute;
    right: 1%;
    bottom: 50%;
    transform: rotate(0deg);
}

.aco-wrapper tr:first-of-type .aco-btn.active:after {
    transform: rotate(90deg);
}

@media screen and (max-width: 1280px) {
    .aco-btn.aco-wrapper h4, .aco-btn .q-head, .aco-text .a-head {
        font-size: 22px
    }

    .aco-text.aco-wrapper p:not(.a-head) {
        font-size: 18x
    }
}

@media screen and (max-width:767px) {
    .works-content {
        flex-direction: column;
        align-items: center;
        max-width: 520px;
        margin: 0 auto 6rem;
    }

    .works-content div {
        width: 100%;
        margin-bottom: 2rem
    }

    .works-content section {
        width: 100%;
    }

    .aco-text .a-head {
        font-size: 14px;
        line-height: 1.3;
    }
	    .aco-btn.aco-wrapper h4, .aco-btn .q-head, .aco-text .a-head {
        font-size: 14px
    }
    .aco-wrapper tr .aco-btn:before {
    margin-right: 10px;
}
    .aco-wrapper tr .aco-btn:after {
    margin-right: 10px;
}
}


/* プラン比較表 */

.hikaku_kasoushiki {
  width: 100%;
  max-width: 986px;
  margin: 30px auto 0 auto;
  padding: 0 10px;
  box-sizing: border-box;
}

.hikaku_kasoushiki table {
  width: 100% !important;
  table-layout: fixed;
  border-collapse: collapse;
}

.hikaku_kasoushiki img{
  display: block;
  width: 100%;
  height: auto;
}

.hikaku_kasoushiki td{
  padding: 0;
  margin: 0;
}

.hikaku_1 {
  width: 12.37%;
}

.hikaku_2 {
  width: 34.89%;
}

.hikaku_3 {
  width: 26.37%;
}

.hikaku_4 {
  width: 26.37%;
}

.hikaku_k2 {
  width: 26.37%;
}

.hikaku_k3 {
  width: 34.89%;
}