@charset "UTF-8";
body.com:after {
  content: '内容支給予定';
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  color: #fff;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  z-index: 1000;
  left: 0;
  top: 0; }

/* ++++++++++++++++++++++++++++++++++++++++++++++    PC    ++++++++++++++++++++++++++++++++++++++++++++++  */
/* 801px ~ */
@media screen and (min-width: 801px), print {
  .flame {
    position: absolute;
    z-index: 101; }

  .deco {
    position: absolute; }

  .flame_tr {
    top: -1px;
    right: -3px; }

  .flame_tl {
    top: -1px;
    left: -3.5px; }

  .flame_br {
    bottom: -1.5px;
    right: -3.5px; }

  .flame_bl {
    bottom: -1px;
    left: -3px; }

  .overwrap {
    overflow: hidden; }

  .js-open {
    cursor: pointer; }

  .detail {
    overflow: hidden; }

  .wrap_w {
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    padding: 0 50px; }

  .detail .sec {
    margin-top: 200px;
    position: relative; }

  .detail .sec h2 {
    position: relative;
    margin: 0 auto 30px;
    text-align: center;
    font-size: 25px;
    letter-spacing: 3px;
    width: 275px;
    padding-left: 3px; }

  .detail .sec h2:before,
  .detail .sec h2:after {
    content: '';
    display: block;
    position: absolute;
    width: 15px;
    height: 29px;
    top: 0;
    bottom: 0;
    margin: auto 0; }

  .detail .sec h2:before {
    background: url("../img/tit_l.png") no-repeat center/cover;
    left: 0; }

  .detail .sec h2:after {
    background: url("../img/tit_r.png") no-repeat center/cover;
    right: 0; }

  .detail .sec .lead + p {
    margin-top: 40px; }

  .detail .mainimgArea {
    position: relative; }

  .detail .mainimgArea .mainimg {
    border-radius: 20px;
    overflow: hidden; }

  .detail .mainimgArea .mainimg img {
    max-width: none;
    width: 100%; }

  .detail .mainimgArea .flame.flame_tl {
    top: 0; }

  .detail .mainimgArea .flame.flame_br {
    bottom: -3.5px; }

  .detail .mainimgArea h1 {
    position: absolute;
    top: 15%;
    left: 10%;
    width: 372px; }

  .detail #sec01 .txtArea {
    max-width: 720px;
    width: 60%;
    float: left; }

  #profile06.detail #sec01 .txtArea {
    float: none;
    margin: 0 auto;
    width: 860px;
    max-width: inherit; }

  .detail #sec01 .txtArea .lead {
    text-align: left; }

  .detail #sec01 .phtArea {
    max-width: 400px;
    width: 35%;
    float: right; }

  .detail #sec01 .phtArea .pht_blo {
    position: relative;
    margin-top: 10px; }

  .detail #sec01 .phtArea .flame_tl {
    top: -3.5px; }

  .detail #sec01 .phtArea dl {
    text-align: right;
    font-weight: bold;
    line-height: 1;
    margin-top: 10px; }

  .detail #sec01 .phtArea dl dd {
    margin-top: 10px;
    font-size: 22px; }

  .detail #sec02 .flame_tr,
  .detail #sec02 .flame_bl {
    width: 16px; }

  .detail #sec02 .flame_tr {
    top: 61px;
    right: 0; }

  .detail #sec02 .flame_tl {
    top: 70px; }

  .detail #sec02,
  .detail #sec04 {
    position: relative;
    background-image: url("../../common/img/bg_b.jpg");
    background-size: 350px;
    background-position: 0 0;
    padding-top: 130px;
    padding-bottom: 100px;
    z-index: 100; }

  .detail #sec04 {
    background-image: url("../../common/img/bg_p.jpg"); }

  .detail #sec02:before,
  .detail #sec02:after,
  .detail #sec04:before,
  .detail #sec04:after {
    content: '';
    display: block;
    position: absolute;
    width: calc(50% - 245px);
    height: 70px;
    background-color: #fff;
    top: 0; }

  .detail #sec02:before,
  .detail #sec04:before {
    left: 0; }

  .detail #sec02:after,
  .detail #sec04:after {
    right: 0; }

  .detail .headbg {
    position: absolute;
    width: 490px;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto; }

  .detail #sec02 .swiper-button-next,
  .detail #sec02 .swiper-button-prev,
  .detail #sec04 .swiper-button-next,
  .detail #sec04 .swiper-button-prev {
    width: 70px;
    height: 70px;
    top: 240px;
    bottom: auto; }

  .detail #sec02 .swiper-button-next,
  .detail #sec04 .swiper-button-next {
    right: 3%; }

  .detail #sec02 .swiper-button-prev,
  .detail #sec04 .swiper-button-prev {
    left: 3%; }

  .detail .sec .newsList {
    margin: 30px auto 0; }

  .detail .sec .swiper-method {
    margin: 80px auto 0; }

  .detail .sec .newsList li,
  .detail .sec .swiper-method li {
    padding-top: 8px; }

  .detail .sec .newsList li {
    float: left;
    width: 32%; }

  /* アニメーション調整　*/
  .detail .sec .newsList li:nth-of-type(2) {
    transition-delay: 0.4s; }

  .detail .sec .newsList li:nth-of-type(3) {
    transition-delay: 0.6s; }

  .detail .sec .newsList .con01 li {
    float: none;
    width: 32%;
    margin: auto; }

  .detail .sec .newsList .con02 {
    display: flex;
    justify-content: center; }
    .detail .sec .newsList .con02 li {
      float: none;
      width: 32%; }

  .detail .sec .newsList li + li {
    margin-left: 2%; }

  .detail .sec .newsList li .inner,
  .detail .sec .swiper-method li .inner {
    background-color: #fff;
    padding: 50px 10%;
    border-radius: 24px;
    position: relative;
    box-sizing: border-box; }

  .detail .sec .newsList li .inner .icon_box,
  .detail .sec .swiper-method li .inner .icon_box {
    width: 43px;
    left: 15px;
    top: 15px;
    position: absolute; }

  .detail .sec .newsList li .inner .num,
  .detail .sec .swiper-method li .inner .num {
    width: 32px;
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;
    top: -16px; }

  .detail .sec .newsList li .inner .img_box,
  .detail .sec .swiper-method li .inner .img_box {
    max-width: 255px;
    margin: 0 auto 30px; }

  .detail .sec .newsList li .inner dl dt,
  .detail .sec .swiper-method li .inner dl dt,
  #profile12 .sec .swiper-method li .inner .txt {
    font-weight: bold;
    text-align: center;
    font-size: 18px;
    margin-bottom: 15px; }

  .detail .sec .newsList li .inner dl dd a,
  .detail .sec .swiper-method li .inner dl dd a {
    display: block;
    text-align: center;
    margin-top: 10px;
    text-decoration-line: underline; }

  .detail .sec .newsList li .inner dl dd a.btn {
    text-decoration: none;
    text-align: left;
    width: 100%;
    line-height: 1.5;
    padding: 8px 25px 8px 15px; }

  .detail #sec02 .newsList li a {
    position: relative;
    display: block; }

  .detail #sec02 .newsList li a::after {
    content: '';
    display: block;
    position: absolute;
    background: url(../img/arrow_gr.png) no-repeat center/cover;
    width: 35px;
    height: 35px;
    right: 15px;
    bottom: 15px;
    transition: 300ms;
    z-index: 101; }

  .detail #sec02 .newsList li a:hover::after {
    right: 8px; }

  .detail #sec02 .newsList li dl dd a::after {
    display: none; }

  .detail #sec03 ul {
    margin: 80px 20px 0; }

  .detail #sec03 ul li {
    float: left;
    width: 49%; }

  .detail#profile04 #sec03 ul li,
  .detail#profile13 #sec03 ul li {
    float: none;
    margin: auto;
    width: 100%; }

  .detail#profile13 #sec03 ul li + li {
    margin-top: 40px; }

  .detail #sec03 ul li + li {
    margin-left: 2%; }

  .detail #sec03 ul li dl {
    position: relative; }

  .detail #sec03 ul li dl dt {
    position: absolute;
    width: 75px;
    top: 0;
    left: 0; }

  .detail#profile13 #sec03 ul li dl dt {
    left: 160px; }

  .detail #sec03 ul li dl dd {
    padding-top: 30px;
    max-width: 420px;
    margin: auto; }

  .detail#profile04 #sec03 ul li dl dd {
    padding-top: 0; }

  .detail#profile02 #sec03 ul li dl dd,
  .detail#profile04 #sec03 ul li dl dd,
  .detail#profile13 #sec03 ul li dl dd {
    max-width: 640px; }

  .detail#profile13 #sec03 ul li dl dd {
    padding-top: 60px; }

  .detail #sec04 .swiper-method li .inner .pointArea {
    margin-left: -5px; }

  .detail #sec04 .swiper-method li .inner .point {
    border-radius: 6px;
    position: relative;
    padding: 18px 18px 16px;
    color: #ff97aa;
    font-weight: bold;
    margin-top: 35px;
    background-color: #ffcbd4;
    z-index: 1;
    line-height: 1.4;
    display: inline-block;
    margin: 35px 0 0 5px; }

  .detail #sec04 .swiper-method li .inner .point + .point {
    margin-top: 10px; }

  .detail #sec04 .swiper-method li .inner .point::after {
    position: absolute;
    content: "";
    top: 0px;
    left: 0px;
    bottom: 0;
    right: 0;
    margin: auto;
    background-size: cover;
    background-color: #fff;
    width: calc(100% - 12px);
    height: calc(100% - 12px);
    border-radius: 3px;
    z-index: -1; }

  .detail #sec04 .swiper-method li .inner .point::before {
    position: absolute;
    content: "";
    bottom: 0px;
    right: 0px;
    width: 30px;
    height: 30px;
    background-size: cover;
    background-image: url("../img/sec04_flame.png"); }

  .swiper-button-next, .swiper-container-rtl .swiper-button-prev {
    background-image: url(../img/arrow_r.png); }

  .swiper-button-prev, .swiper-container-rtl .swiper-button-next {
    background-image: url(../img/arrow_l.png); }

  .detail #sec05 .deco01 {
    top: -240px;
    left: 5%; }

  #profile05.detail #other .deco01 {
    top: -240px;
    left: 5%; }

  .detail #sec05 .deco02 {
    bottom: 370px;
    right: -2%; }

  .detail #sec05 .secArea {
    margin-top: 100px; }

  .detail #sec05 .secArea .phtArea {
    float: left;
    width: 311px;
    position: relative; }

  .detail #sec05 .secArea .phtArea .sec_ill {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 129px; }

  .detail #sec05 .secArea .txtArea {
    float: right;
    width: calc(100% - 411px); }

  .detail .secArea table {
    border-collapse: collapse;
    width: 100%; }

  .detail .secArea table th,
  .detail .secArea table td {
    text-align: left;
    border-bottom: 1px solid #dddddd;
    padding: 10px 0; }

  .detail #sec05 .secArea table th {
    width: 10.5em; }

  .detail .secArea table tr:last-child th,
  .detail .secArea table tr:last-child td {
    border: none; }

  .detail .secArea table td span {
    line-height: 1.4;
    display: inline-block; }

  .detail #sec05 .secArea table td span + br + strong {
    display: inline-block;
    margin-top: 5px; }

  .detail .secArea table td a {
    text-decoration: underline;
    color: #ff97aa;
    font-weight: bold; }

  .detail #sec05 #mapArea,
  .detail #sec05 .mapArea {
    max-width: 1200px;
    margin: 80px auto 0;
    height: 400px; }
    .detail #sec05 #mapArea iframe,
    .detail #sec05 .mapArea iframe {
      border-radius: 45px; }
  .detail #sec05 .sec_inn {
    float: left;
    width: 48%; }
    .detail #sec05 .sec_inn + .sec_inn {
      margin-left: 4%; }
  .detail #sec05 .map_col3 .sec_inn {
    width: 100%;
    clear: both;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 4%; }
    .detail #sec05 .map_col3 .sec_inn + .sec_inn {
      margin-left: auto;
      margin-top: 100px; }
    .detail #sec05 .map_col3 .sec_inn:nth-of-type(2n) table {
      order: 1; }
    .detail #sec05 .map_col3 .sec_inn:nth-of-type(2n) .mapArea {
      order: 0; }
    .detail #sec05 .map_col3 .sec_inn #mapArea,
    .detail #sec05 .map_col3 .sec_inn .mapArea {
      margin: 0 auto;
      height: auto;
      width: 100%; }

  .detail #about .lead + p {
    font-size: 16px;
    line-height: 2; }

  .detail #about .secArea {
    background-image: url("../img/about_flame.png");
    background-size: cover;
    width: 748px;
    height: 260px;
    margin: 80px auto 0;
    position: relative; }

  .detail #about .secArea + .lead {
    margin-top: 30px; }

  .detail #about .secArea .sec_tit {
    font-weight: bold;
    font-size: 18px;
    text-align: center;
    position: absolute;
    top: -10px;
    left: 0;
    right: 0;
    margin: auto; }

  .detail #about .secArea ul {
    padding: 68px 80px; }

  .detail #about .secArea ul li {
    font-size: 16px;
    font-weight: bold;
    width: 50%;
    float: left;
    position: relative;
    padding-left: 45px;
    box-sizing: border-box; }

  .detail #about .secArea ul li:nth-child(n + 3) {
    margin-top: 20px; }

  .detail #about .secArea ul li::before {
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 27px;
    height: 17px;
    background-image: url("../img/about_check.png");
    background-size: cover; }

  .detail #about .about_inn ul {
    width: 640px;
    margin: 60px auto 0; }

  .detail #about .about_inn ul li {
    float: left;
    width: 300px;
    position: relative;
    height: 300px; }

  .detail #about .about_inn ul li + li {
    margin-left: 40px; }

  .detail #about .about_inn .fl {
    position: absolute;
    top: 0;
    line-height: 1;
    width: 100%; }

  .detail #about .about_inn .fl:last-of-type {
    top: auto;
    bottom: 0; }

  .detail #about .about_inn dl {
    background-image: url("../img/box02.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100% 100%;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    flex-direction: column;
    flex-basis: auto;
    height: 100%;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    padding: 0 40px;
    font-weight: bold;
    font-size: 18px; }

  .detail #about .about_inn ul li:last-child dl {
    background-image: url("../img/box02_p.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100% 100%; }

  .detail #about .about_inn dl dt {
    position: relative;
    z-index: 2;
    color: #0da997;
    margin-bottom: 10px;
    text-align: center;
    width: 100%; }

  .detail #about .about_inn ul li:last-child dl dt {
    color: #f7668b; }

  .detail #about .about_inn dl dd {
    position: relative;
    z-index: 2;
    width: 100%; }

  .detail #point {
    position: relative;
    background-image: url("../../common/img/bg_p.jpg");
    background-size: 350px;
    background-position: 0 0;
    padding-top: 80px;
    padding-bottom: 100px;
    z-index: 100;
    border-radius: 16px; }

  .detail #point:before,
  .detail #point:after {
    content: '';
    display: block;
    position: absolute;
    width: calc(50% - 245px);
    height: 70px;
    background-color: #fff;
    top: 0; }

  .detail #point:before {
    left: 0; }

  .detail #point:after {
    right: 0; }

  .detail .headbg {
    position: absolute;
    width: 490px;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto; }

  .detail #point .flame_tl,
  .detail #point .flame_tr {
    top: 61px;
    width: 16px; }

  .detail #point .flame_tl {
    left: 0; }

  .detail #point .flame_tr {
    right: 0; }

  .detail #point .secArea ul {
    padding: 68px 80px 0; }

  .detail #point .secArea ul li {
    font-weight: bold;
    width: 32%;
    float: left;
    position: relative;
    padding: 20px;
    text-align: center;
    box-sizing: border-box;
    border: solid 6px #ff97aa;
    background-color: #fff;
    border-radius: 20px; }

  .detail #point .secArea ul.txt li {
    padding: 40px 30px; }

  .detail #point .secArea ul li:not(:nth-child(3n + 1)) {
    margin-left: 2%; }

  .detail #point .secArea ul li:nth-child(n + 4) {
    margin-top: 20px; }

  .detail #point .secArea ul li p {
    font-size: 18px; }

  .detail #point .secArea ul li span {
    display: block;
    font-size: 16px;
    margin-top: 15px;
    text-align: left;
    line-height: 2; }

  .detail #activity .secArea {
    margin-top: 80px; }

  .detail #activity .lead {
    text-align: left;
    float: left;
    width: calc(100% - 380px); }

  .detail #activity .phtArea {
    float: right;
    width: 300px; }

  .detail #sche {
    background-color: #f4f4f4;
    position: relative;
    border-radius: 16px; }

  .detail #sche:after {
    content: '';
    display: block;
    position: absolute;
    width: 800px;
    height: 400px;
    border-radius: 50% / 100% 100% 0 0;
    background-color: #f4f4f4;
    top: -70px;
    left: 0;
    right: 0;
    margin: 0 auto;
    z-index: -1; }

  .detail #sche .flame {
    width: 120px;
    height: 120px; }

  .detail #sche .flame_br {
    transform: rotate(-180deg); }

  .detail #sche ul {
    margin: 80px 0; }

  .detail #sche ul li {
    background-color: #fff;
    border-radius: 12px;
    padding: 40px; }

  .detail #sche ul li + li {
    margin-top: 30px; }

  .detail #sche ul li dl dt {
    width: 113px;
    float: left;
    margin-right: 40px; }

  .detail #sche ul li dl dd {
    float: left;
    padding: 14.5px 0px; }

  .detail #sche ul li dl dd + dd {
    margin-left: 30px;
    padding-left: 30px;
    border-left: 1px solid #e3e3e3; }

  .detail #sche ul li dl dd .inner {
    float: left;
    /*margin-right: 30px;*/
    line-height: 84px;
    width: 100px; }

  .detail #sche ul li:nth-of-type(1) dl dd:nth-of-type(1) .inner {
    width: 130px; }

  .detail #sche ul li dl dd .cbox .inner {
    line-height: 42px; }

  .detail #sche ul li dl dd div div {
    font-size: 18px;
    font-weight: bold; }

  .detail #sche ul li dl dd div span {
    width: 73px;
    display: block; }

  .detail #sche ul li dl dd div span img {
    vertical-align: middle; }

  .detail #sche ul li:first-child dl dd div div {
    color: #66cbaf;
    margin-right: 30px; }

  .detail #sche ul li:last-child dl dd div div {
    color: #ff97aa; }

  .detail #sche ul li dl dd p {
    float: left;
    font-weight: bold;
    font-size: 16px; }

  .detail #sche ul li dl dd .cbox .inner + p {
    line-height: 42px; }

  .detail #time {
    width: 46%;
    float: left;
    position: relative; }

  .detail #time .deco {
    bottom: -260px;
    left: 12%; }

  .detail #cost {
    width: 46%;
    float: right; }

  .detail #cost .lead {
    text-align: left; }

  .detail #cost .secArea {
    margin-top: 40px; }

  .detail #cost .secArea p {
    margin-top: 30px; }

  .detail #flow {
    position: relative;
    background-image: url("../../common/img/bg_p.jpg");
    background-size: 350px;
    background-position: 0 0;
    padding-top: 80px;
    padding-bottom: 120px;
    z-index: 100;
    border-radius: 16px; }

  .detail #flow:before,
  .detail #flow:after {
    content: '';
    display: block;
    position: absolute;
    width: calc(50% - 245px);
    height: 70px;
    background-color: #fff;
    top: 0; }

  .detail #flow:before {
    left: 0; }

  .detail #flow:after {
    right: 0; }

  .detail #flow .flame_tl {
    top: 68.5px; }

  .detail #flow .flame_tr {
    top: 61px;
    right: 0;
    width: 16px; }

  .detail #flow .secArea {
    margin-top: 60px; }

  .detail #flow .secArea ul li {
    float: left;
    width: 30%;
    box-sizing: border-box;
    background-color: #fff;
    border-radius: 12px;
    padding: 30px;
    position: relative; }

  .detail #flow .secArea ul li:not(:nth-child(3n + 1)) {
    margin-left: 5%; }

  .detail #flow .secArea ul li:nth-child(n + 4) {
    margin-top: 70px; }

  .detail #flow .secArea ul li:not(:nth-child(3n + 1))::before {
    content: "";
    position: absolute;
    top: 0;
    left: -40px;
    bottom: 0;
    background-image: url("../img/arrow_p.png");
    background-size: cover;
    width: 21px;
    height: 15px;
    margin: auto; }

  .detail #flow .secArea ul li div {
    position: absolute;
    top: -15px;
    left: 0;
    right: 0;
    margin: auto;
    width: 32px; }

  .detail #flow .secArea ul li p {
    display: table;
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    width: 100%;
    height: 100%; }

  .detail #flow .secArea ul li p span {
    display: table-cell;
    vertical-align: middle; }

  .detail #policy .secArea ul {
    padding: 40px 31px 0; }

  .detail #policy .secArea ul li {
    float: left;
    box-sizing: border-box;
    background-image: url("../img/policy_odd.png");
    background-size: cover;
    width: 286px;
    height: 286px;
    margin: auto; }

  .detail #policy .secArea ul li:nth-child(even) {
    background-image: url("../img/policy_even.png"); }

  .detail #policy .secArea ul li + li {
    margin-left: 60px; }

  .detail #policy .secArea ul li:nth-child(n + 4) {
    margin-top: 70px; }

  .detail #policy .secArea ul li p {
    display: table;
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    width: 100%;
    height: 100%; }

  .detail #policy .secArea ul li p span {
    display: table-cell;
    vertical-align: middle; }

  .detail #policy .deco {
    bottom: -160px;
    right: -6%; }

  .detail #other .secArea ul {
    width: 940px;
    margin: 0 auto; }

  .detail #other .secArea ul {
    padding: 40px 31px 0; }

  .detail #other .secArea ul li {
    float: left;
    box-sizing: border-box;
    background-image: url("../img/policy_odd.png");
    background-size: cover;
    width: 286px;
    height: 286px;
    margin: auto; }

  .detail #other .secArea ul li:nth-child(even) {
    background-image: url("../img/policy_even.png"); }

  .detail #other .secArea ul li + li {
    margin-left: 40px; }

  .detail #other .secArea ul li:nth-child(n + 4) {
    margin-top: 70px; }

  .detail #other .secArea ul li .inner {
    display: table;
    text-align: center;
    width: 100%;
    height: 100%; }

  .detail #other .secArea ul li .inner dl {
    display: table-cell;
    vertical-align: middle; }

  .detail #other .secArea ul li .inner dl dt {
    font-weight: bold;
    font-size: 18px;
    text-align: center;
    margin-bottom: 15px;
    letter-spacing: 1px; }

  .detail #other .secArea ul li .inner a {
    text-decoration: underline;
    color: #ff97aa;
    font-weight: bold; }

  .detail #staff .secArea {
    margin-top: 80px; }

  .detail #staff .secArea ul li {
    position: relative; }

  .detail #staff .secArea ul li + li {
    margin-top: 80px;
    padding-top: 80px; }

  .detail #staff .secArea ul li + li::before {
    content: '';
    display: block;
    position: absolute;
    width: 100%;
    height: 4px;
    background-color: #66cbaf;
    border-radius: 2px;
    top: 0;
    left: 0; }

  .detail #staff .secArea ul li dl dt {
    font-weight: bold;
    font-size: 20px;
    text-align: center; }

  .detail #staff .secArea ul li dl dd {
    font-size: 16px;
    margin-top: 25px; }

  .detail #staff .secArea ul li dl dd div span {
    content: '';
    display: block;
    width: 100%;
    height: 2px;
    background-color: #e8e8e8;
    border-radius: 2px;
    margin: 1em 0; }

  .detail #staff .secArea ul li dl dd p {
    margin-top: 50px;
    border: solid 3px #66cbaf;
    border-radius: 12px;
    padding: 30px 15px;
    position: relative; }

  .detail #staff .secArea ul li dl dd p span {
    font-weight: bold;
    text-align: center;
    position: absolute;
    left: 0;
    right: 0;
    top: -15px;
    background-color: #fff;
    display: inline-block;
    width: 120px;
    margin: auto; }

  .detail #req {
    position: relative; }

  .detail #req .deco {
    right: -100px;
    z-index: 101;
    bottom: -80px; }

  .detail #req h2 {
    margin-bottom: 80px; }

  .detail #req .wrap {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center; }

  .detail #req .wrap > dl {
    position: relative;
    margin: 0 25px;
    font-weight: bold; }

  .detail #req .wrap > dl > dt {
    position: absolute;
    top: -8px;
    text-align: center;
    right: 0;
    left: 0;
    margin: 0 auto;
    font-size: 16px; }

  .detail #req .wrap > dl > dd {
    background: url("../img/box_req2.png") no-repeat top center/cover;
    width: 261px;
    height: 261px;
    text-align: center;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 18px; }

  .detail #req .wrap > dl:nth-of-type(1) > dd {
    background: url("../img/box_req.png") no-repeat top center/cover; }

  .detail #req .deco {
    right: -100px;
    z-index: 101;
    bottom: -80px;
    position: absolute;
    width: 162px; }

  .detail #ex ul {
    position: relative;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    z-index: 101; }

  .detail #ex ul:after {
    display: none; }

  .detail #ex ul li {
    width: 100%;
    position: relative;
    min-height: 300px; }

  .detail #ex ul li:nth-of-type(1) {
    background: url("../img/ex01.jpg") no-repeat center/cover;
    border-radius: 0 16px 16px 0; }

  .detail #ex ul li:nth-of-type(3) {
    background: url("../img/ex02.jpg") no-repeat center/cover;
    border-radius: 16px; }

  .detail #ex ul li:nth-of-type(4) {
    background: url("../img/ex03.jpg") no-repeat center/cover;
    border-radius: 16px 0 0 16px; }

  .detail #ex ul li + li {
    margin-left: 25px; }

  .detail #ex ul li > img {
    border-radius: 16px; }

  .detail #ex ul li:first-of-type > img {
    border-radius: 0 16px 16px 0; }

  .detail #ex ul li:last-of-type > img {
    border-radius: 16px 0 0 16px; }

  .detail #ex ul li .fl {
    position: absolute;
    top: 0;
    width: 100%; }

  .detail #ex ul li .fl:last-of-type {
    top: auto;
    bottom: 0; }

  .detail #ex ul li:nth-of-type(2) dl {
    background-image: url("../img/box02.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100% 100%;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    flex-direction: column;
    flex-basis: auto;
    height: 100%;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    padding: 0 40px;
    font-weight: bold;
    font-size: 18px; }

  .detail #ex ul li dl dt {
    position: relative;
    z-index: 2;
    color: #0da997;
    margin-bottom: 10px;
    width: 100%;
    text-align: center; }

  .detail #ex ul li dl dd {
    position: relative;
    z-index: 2;
    width: 100%; }

  .detail #ex ul li .fl img {
    display: block;
    border-radius: 0; }

  #contact .btnArea {
    margin-top: 10px; }

  #contact .btnArea .btn {
    margin: 0 auto; }

  #contact .btnArea p {
    text-align: center;
    margin-bottom: 40px; }

  #contact .deco {
    bottom: 0;
    right: 50%;
    margin-right: -420px;
    width: 155px; }

  .detail .btn {
    width: 215px;
    border: solid 3px #66cbaf;
    border-radius: 18px;
    position: relative;
    color: #0da997;
    padding: 18px 25px 18px 5px;
    text-align: center;
    display: block;
    font-weight: bold;
    margin: 30px 0 0;
    line-height: 1em;
    box-sizing: border-box;
    font-feature-settings: "palt"; }

  .detail .btn + .btn {
    margin-top: 20px; }

  .detail .btn::before {
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    right: 15px;
    margin: auto;
    background-image: url(../../common/img/arrow.png);
    background-size: cover;
    width: 20px;
    height: 15px;
    transition: 300ms; }

  .detail .btn:hover {
    background-color: #66cbaf !important;
    color: #fff; }

  .detail .btn:hover::before {
    right: 8px;
    background-image: url(../../common/img/arrow_w.png); }

  .detail .btn .type {
    display: inline-block;
    font-size: 12px;
    color: #fff;
    background-color: #0da997;
    border-radius: 6px;
    padding: 5px 8px;
    line-height: 1em;
    margin-right: 5px; }

  .detail .btn:hover .type {
    color: #0da997;
    background-color: #fff; }

  /* movie
  ---------------------------------*/
  #movieArea {
    position: relative;
    text-align: center; }

  #movieArea .deco {
    top: -30px;
    right: 30px;
    width: 197px; }

  #movieArea .wrap {
    position: relative;
    background-image: url(../../common/img/bg_p.jpg);
    background-size: 350px;
    background-position: 0 0;
    padding-top: 110px;
    padding-bottom: 70px;
    width: 1040px;
    border-radius: 16px; }

  #movieArea .wrap:before, #movieArea .wrap:after {
    content: '';
    display: block;
    position: absolute;
    width: calc(50% - 245px);
    height: 70px;
    background-color: #fff;
    top: 0; }

  #movieArea .wrap:before {
    left: 0; }

  #movieArea .wrap:after {
    right: 0; }

  #movieArea .wrap .flame_tl {
    top: 60px;
    left: 0;
    width: 16px; }

  #movieArea .wrap .flame_tr {
    top: 70px;
    right: 0;
    width: 64px; }

  #movieArea .wrap .flame_bl {
    transform: scale(-1, -1);
    left: 0;
    width: 64px; }

  #movieArea .headbg {
    position: absolute;
    width: 490px;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto; }

  #movieArea .wrap .deco.icon {
    width: 123px;
    left: 0;
    right: 0;
    top: 40px;
    margin: auto; }

  #movieArea h2 {
    width: auto; }

  #movieArea h2:before,
  #movieArea h2:after {
    display: none; }

  /* prof11
  ---------------------------------*/
  #profile11.detail #logoArea {
    margin-top: 120px; }

  #profile11.detail #logoArea .img_box {
    margin: 0 auto 40px;
    width: 240px; }

  /* prof12
  ---------------------------------*/
  #profile12.detail .mainimgArea h1 {
    width: 405px; }

  #profile12 #about .wrap_w {
    position: relative; }

  #profile12 #about .deco01 {
    bottom: -120px;
    left: 50%;
    margin-left: -450px;
    width: 153px; }

  #profile12 #about .deco02 {
    width: 162px;
    right: -100px;
    z-index: 101;
    top: -120px; }

  #profile12 .calam > section {
    width: 46%;
    float: left;
    position: relative; }

  #profile12 .calam > section:nth-of-type(2n) {
    float: right; }

  #profile12 .calam > section .secArea {
    margin-top: 40px; }

  #profile12 .calam #contact .btnArea {
    margin-top: 40px; }

  #profile12 .calam #cafe h2 {
    width: 100%;
    max-width: 400px;
    font-feature-settings: "palt"; }

  #profile12 .calam #cafe dl {
    position: relative;
    margin: 0 auto;
    font-weight: bold;
    width: 261px; }

  #profile12 .calam #cafe dt {
    position: absolute;
    top: -8px;
    text-align: center;
    right: 0;
    left: 0;
    margin: 0 auto;
    font-size: 16px; }

  #profile12 .calam #cafe dd {
    background: url(../img/box_req2.png) no-repeat top center/cover;
    width: 100%;
    height: 261px;
    text-align: center;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 18px; } }
/* ++++++++++++++++++++++++++++++++++++++++++++++    sp    ++++++++++++++++++++++++++++++++++++++++++++++  */
/* ~ 800px */
@media only screen and (max-width: 800px) {
  .flame {
    position: absolute;
    z-index: 101;
    width: 60px; }

  .deco {
    position: absolute;
    z-index: 101; }

  .flame_tr {
    top: -1px;
    right: -2px; }

  .flame_tl {
    top: -1px;
    left: -2px; }

  .flame_br {
    bottom: -1px;
    right: -2px; }

  .flame_bl {
    bottom: -1px;
    left: -2px; }

  .overwrap {
    overflow: hidden; }

  /* lead */
  #index.profile .title_str {
    margin-bottom: 160px; }

  #index.profile .lead {
    position: relative;
    margin-bottom: 60px; }

  .detail .sec {
    margin-top: 100px;
    position: relative; }

  .detail .sec h2 {
    position: relative;
    margin: 0 auto 30px;
    text-align: center;
    font-size: 20px;
    width: 90%;
    max-width: 275px;
    padding-left: 3px; }

  .detail .sec h2:before,
  .detail .sec h2:after {
    content: '';
    display: block;
    position: absolute;
    width: 15px;
    height: 29px;
    top: 0;
    bottom: 0;
    margin: auto 0; }

  .detail .sec h2:before {
    background: url("../img/tit_l.png") no-repeat center/cover;
    left: 0; }

  .detail .sec h2:after {
    background: url("../img/tit_r.png") no-repeat center/cover;
    right: 0; }

  .detail .sec .lead {
    font-weight: bold;
    font-size: 16px;
    margin: auto; }

  .detail .sec .lead + p {
    margin-top: 40px; }

  .detail .mainimgArea {
    position: relative; }

  .detail .mainimgArea .mainimg {
    border-radius: 12px;
    overflow: hidden; }

  .detail .mainimgArea .flame.flame_br {
    display: none; }

  .detail .mainimgArea h1 {
    margin: -30% auto 70px; }

  .detail #sec01 {
    margin-top: 0px; }

  .detail #sec01 .txtArea br + br {
    display: none; }

  .detail #sec01 .txtArea .lead {
    text-align: left; }

  .detail #sec01 .phtArea {
    width: 60%;
    margin: 30px auto 0; }

  .detail #sec01 .phtArea .pht_blo {
    position: relative; }

  .detail #sec01 .phtArea .flame_tl {
    top: -3px;
    left: -3px;
    width: 40px; }

  .detail #sec01 .phtArea dl {
    text-align: center;
    font-weight: bold;
    line-height: 1;
    margin-top: 15px; }

  .detail #sec01 .phtArea dl dt {
    display: inline-block; }

  .detail #sec01 .phtArea dl dd {
    display: inline-block;
    margin-left: 10px;
    font-size: 18px; }

  .detail #sec02 .flame_tl {
    display: none; }

  .detail #sec02,
  .detail #sec04 {
    position: relative;
    background-image: url("../../common/img/bg_b.jpg");
    background-size: 350px;
    background-position: 0 0;
    padding-top: 80px;
    padding-bottom: 50px;
    z-index: 100; }

  .detail #sec04 {
    background-image: url("../../common/img/bg_p.jpg"); }

  .detail #sec02:before,
  .detail #sec02:after,
  .detail #sec04:before,
  .detail #sec04:after {
    content: '';
    display: block;
    position: absolute;
    width: 5vw;
    height: 13vw;
    background-color: #fff;
    top: 0; }

  .detail #sec02:before,
  .detail #sec04:before {
    left: 0; }

  .detail #sec02:after,
  .detail #sec04:after {
    right: 0; }

  .detail .headbg {
    position: absolute;
    max-width: 490px;
    width: 90%;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto; }

  .detail #sec02 .headbg {
    width: 100%; }

  .detail #sec02 .swiper-button-next,
  .detail #sec02 .swiper-button-prev,
  .detail #sec04 .swiper-button-next,
  .detail #sec04 .swiper-button-prev {
    top: 235px;
    bottom: auto; }

  .detail #sec02 .swiper-button-next,
  .detail #sec04 .swiper-button-next {
    right: 6.5%; }

  .detail #sec02 .swiper-button-prev,
  .detail #sec04 .swiper-button-prev {
    left: 6.5%; }

  .detail .sec .newsList {
    margin: 0px auto 0; }

  .detail .sec .swiper-method {
    margin: 40px auto 0; }

  .detail .sec .newsList li,
  .detail .sec .swiper-method li {
    padding-top: 8px; }

  .detail .sec .newsList li {
    width: 90%;
    margin: auto; }

  .detail .sec .newsList li + li {
    margin-top: 10%; }

  .detail .sec .newsList li .inner,
  .detail .sec .swiper-method li .inner {
    background-color: #fff;
    padding: 30px 5% 60px;
    border-radius: 12px;
    position: relative;
    line-height: 1.6; }

  .detail .sec .swiper-method li .inner {
    padding: 30px 5% 20px; }

  .detail .sec .newsList li .inner .icon_box,
  .detail .sec .swiper-method li .inner .icon_box {
    width: 43px;
    left: 15px;
    top: 15px;
    position: absolute; }

  .detail .sec .newsList li .inner .num,
  .detail .sec .swiper-method li .inner .num {
    width: 32px;
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;
    top: -13px; }

  .detail .sec .newsList li .inner .img_box,
  .detail .sec .swiper-method li .inner .img_box {
    max-width: 240px;
    margin: 0 auto 25px; }

  .detail .sec .newsList li .inner dl dt,
  .detail .sec .swiper-method li .inner dl dt,
  #profile12 .sec .swiper-method li .inner .txt {
    font-weight: bold;
    text-align: center;
    font-size: 17px;
    margin-bottom: 10px; }

  .detail .sec .newsList li .inner dl dd a,
  .detail .sec .swiper-method li .inner dl dd a {
    display: block;
    text-align: center;
    margin-top: 10px;
    color: #0da997;
    text-decoration-line: underline; }

  .detail #sec02 .newsList li a {
    position: relative;
    display: block; }

  .detail #sec02 .newsList li a::after {
    content: '';
    display: block;
    position: absolute;
    background: url(../img/arrow_gr.png) no-repeat center/cover;
    width: 35px;
    height: 35px;
    right: 0;
    left: 0;
    bottom: 15px;
    transition: 300ms;
    z-index: 101;
    margin: auto; }

  .detail #sec02 .newsList li dl dd a::after {
    display: none; }

  .detail .sec .newsList li .inner dl dd a.btn {
    text-decoration: none;
    text-align: left;
    width: 100%;
    line-height: 1.5;
    padding: 8px 25px 8px 15px; }

  .detail #sec03 ul {
    margin: 40px 0 0; }

  .detail#profile02 #sec03 ul li,
  .detail#profile04 #sec03 ul li,
  .detail#profile13 #sec03 ul li {
    overflow-x: scroll; }

  .detail #sec03 ul li + li {
    margin-top: 10%; }

  .detail #sec03 ul li dl {
    position: relative; }

  .detail#profile02 #sec03 ul li dl,
  .detail#profile04 #sec03 ul li dl,
  .detail#profile13 #sec03 ul li dl {
    width: 540px; }

  .detail #sec03 ul li dl dt {
    position: absolute;
    width: 50px;
    top: 0;
    left: 0; }

  .detail#profile04 #sec03 ul li dl dd {
    padding-top: 0; }

  .detail #sec03 ul li dl dd {
    padding-top: 30px; }

  .detail#profile13 #sec03 ul li dl dd {
    padding-top: 60px; }

  .detail #sec04 .lead {
    width: 90%; }

  .detail #sec04 .swiper-method li .pointArea {
    margin-left: -5px; }

  .detail #sec04 .swiper-method li .point {
    color: #ff97aa;
    font-weight: bold;
    margin-top: 35px;
    z-index: 1;
    line-height: 1.4;
    margin: 20px 0 0 22px;
    position: relative;
    font-size: 13px; }

  .detail #sec04 .swiper-method li .point + .point {
    margin-top: 5px; }

  .detail #sec04 .swiper-method li .point::after {
    position: absolute;
    content: "";
    top: 2.5px;
    left: -17px;
    background-color: #ff97aa;
    width: 11px;
    height: 11px;
    border-radius: 6px;
    z-index: -1; }

  .swiper-button-next, .swiper-container-rtl .swiper-button-prev {
    background-image: url(../img/arrow_r.png); }

  .swiper-button-prev, .swiper-container-rtl .swiper-button-next {
    background-image: url(../img/arrow_l.png); }

  .detail #sec05 .deco01,
  .detail #other .deco01 {
    top: -120px;
    left: 5%;
    width: 25%; }

  .detail #sec05 .deco02 {
    bottom: 275px;
    right: 0;
    width: 20%; }

  .detail #sec05 .wrap {
    padding: 0; }

  .detail #sec05 .secArea {
    margin-top: 40px; }

  .detail #sec05 .sec_inn + .sec_inn {
    margin-top: 70px; }

  .detail #sec05 .secArea .phtArea {
    position: relative;
    width: 75%;
    margin: auto; }

  .detail #sec05 .secArea .phtArea .sec_ill {
    position: absolute;
    bottom: 0;
    left: -12.5%;
    width: 30vw; }

  .detail #sec05 .secArea .txtArea {
    margin-top: 30px; }

  .detail .secArea table {
    border-collapse: collapse;
    width: 100%; }

  .detail .secArea table th,
  .detail .secArea table td {
    text-align: left;
    border-bottom: 1px solid #dddddd;
    padding: 10px 0; }

  .detail .secArea table th {
    padding-right: 10px;
    width: 5em;
    line-height: 1.4; }

  .detail .secArea table tr:last-child th,
  .detail .secArea table tr:last-child td {
    border: none; }

  .detail #sec05 .secArea .txtArea table td span {
    line-height: 1.4;
    display: inline-block; }

  .detail #sec05 .secArea .txtArea table td span + br + strong {
    display: inline-block;
    margin-top: 5px; }

  .detail #sec05 .secArea .txtArea table td a {
    color: #ff97aa;
    font-weight: bold; }

  .detail #sec05 #mapArea,
  .detail #sec05 .mapArea {
    margin: 20px auto 0;
    height: 300px; }
    .detail #sec05 #mapArea iframe,
    .detail #sec05 .mapArea iframe {
      border-radius: 30px; }

  .detail #about {
    margin-top: 20px; }

  .detail#profile08 #about {
    margin: 0; }

  .detail #about .lead {
    text-align: left; }

  .detail #about .lead + p {
    font-size: 15px;
    margin-top: 15px;
    line-height: 1.6; }

  .detail #about .secArea {
    background-image: url("../img/about_flame_sp.png");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    margin: 60px auto 0;
    position: relative;
    width: 280px; }

  .detail #about .secArea + .lead {
    margin-top: 20px;
    text-align: center; }

  .detail #about .secArea .sec_tit {
    font-weight: bold;
    font-size: 17px;
    text-align: center;
    position: absolute;
    top: -25px;
    left: 0;
    right: 0;
    margin: auto;
    line-height: 1.6; }

  .detail #about .secArea ul {
    padding: 55px 10% 40px; }

  .detail #about .secArea ul li {
    font-size: 15px;
    font-weight: bold;
    float: left;
    position: relative;
    padding-left: 35px;
    box-sizing: border-box; }

  .detail #about .secArea ul li + li {
    margin-top: 7.5px; }

  .detail #about .secArea ul li::before {
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 24px;
    height: 15.1px;
    background-image: url("../img/about_check.png");
    background-size: cover; }

  .detail #about .about_inn ul {
    margin: 40px auto 0; }

  .detail #about .about_inn ul li {
    position: relative;
    width: 280px;
    margin: auto; }

  .detail #about .about_inn ul li + li {
    margin-top: 30px; }

  .detail #about .about_inn .fl {
    position: absolute;
    top: 0;
    line-height: 1; }

  .detail #about .about_inn .fl:last-of-type {
    top: auto;
    bottom: 0; }

  .detail #about .about_inn dl {
    background: url("../img/box02.png") no-repeat center/100% 100%;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    flex-direction: column;
    height: 100%;
    width: 100%;
    box-sizing: border-box;
    padding: 50px 10%;
    font-weight: bold;
    line-height: 1.6; }

  .detail #about .about_inn ul li:last-child dl {
    background: url("../img/box02_p.png") no-repeat center/100% 100%; }

  .detail #about .about_inn dl dt {
    position: relative;
    z-index: 2;
    color: #0da997;
    margin-bottom: 12px;
    text-align: center;
    font-size: 17px; }

  .detail #about .about_inn ul li:last-child dl dt {
    color: #f7668b; }

  .detail #about .about_inn dl dd {
    position: relative;
    z-index: 2;
    font-size: 15px; }

  .detail #point {
    position: relative;
    background-image: url("../../common/img/bg_p.jpg");
    background-size: 350px;
    background-position: 0 0;
    padding-top: 80px;
    padding-bottom: 50px;
    z-index: 100;
    border-radius: 12px; }

  .detail #point:before,
  .detail #point:after {
    content: '';
    display: block;
    position: absolute;
    width: 5vw;
    height: 13vw;
    background-color: #fff;
    top: 0; }

  .detail #point:before {
    left: 0; }

  .detail #point:after {
    right: 0; }

  .detail .headbg {
    position: absolute;
    max-width: 490px;
    width: 100%;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto; }

  .detail #point .lead {
    margin-bottom: 40px;
    width: 90%; }

  .detail #point .secArea ul {
    padding: 0 5%; }

  .detail #point .secArea ul li {
    font-size: 16px;
    width: 100%;
    position: relative;
    padding: 15px;
    text-align: center;
    box-sizing: border-box;
    border: solid 5px #ff97aa;
    background-color: #fff;
    border-radius: 20px;
    line-height: 1.6; }

  .detail #point .secArea ul.txt li {
    padding: 20px; }

  .detail #point .secArea ul li + li {
    margin-top: 15px; }

  .detail #point .secArea ul li:nth-child(n + 4) {
    margin-top: 20px; }

  .detail #point .secArea ul li p {
    font-weight: bold;
    font-size: 17px; }

  .detail #point .secArea ul li span {
    display: block;
    font-size: 15px;
    margin-top: 12px;
    text-align: left; }

  .detail #activity .secArea {
    margin-top: 30px; }

  .detail #activity .lead {
    text-align: left; }

  .detail #activity .phtArea {
    margin-top: 30px; }

  .detail #sche {
    background-color: #f4f4f4;
    position: relative;
    border-radius: 16px;
    padding-top: 80px;
    padding-bottom: 20px; }

  .detail #sche .flame {
    width: 60px;
    height: 60px; }

  .detail #sche .flame_tl {
    display: none; }

  .detail #sche .flame_br {
    transform: rotate(-180deg); }

  .detail #sche ul {
    margin: 40px 0; }

  .detail #sche ul li {
    background-color: #fff;
    border-radius: 12px;
    padding: 20px 5%; }

  .detail #sche ul li + li {
    margin-top: 30px; }

  .detail #sche ul li dl dt {
    width: 100px;
    margin: 0 auto 30px; }

  .detail #sche ul li dl dd {
    line-height: 1.6; }

  .detail #sche ul li dl dd + dd {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid #e3e3e3; }

  .detail #sche ul li dl dd .inner {
    float: left;
    margin-right: 20px;
    width: 60px; }

  .detail #sche ul li dl dd div div {
    font-size: 16px;
    font-weight: bold; }

  .detail #sche ul li dl dd div span {
    width: 60px;
    display: block; }

  .detail #sche ul li dl dd div span img {
    vertical-align: middle; }

  .detail #sche ul li:first-child dl dd div div {
    color: #66cbaf; }

  .detail #sche ul li:last-child dl dd div div {
    color: #ff97aa; }

  .detail #sche ul li dl dd p {
    float: left;
    font-weight: bold;
    font-size: 16px; }

  .detail #time {
    position: relative; }

  .detail #time .deco {
    bottom: -80px;
    right: 0%;
    width: 80px; }

  .detail #time .secArea table th {
    width: 6em; }

  .detail #cost .lead {
    text-align: left; }

  .detail #cost .secArea {
    margin-top: 40px; }

  .detail #cost .secArea table th {
    width: 6em; }

  .detail #flow {
    position: relative;
    background-image: url("../../common/img/bg_p.jpg");
    background-size: 350px;
    background-position: 0 0;
    padding-top: 80px;
    padding-bottom: 80px;
    z-index: 100;
    border-radius: 12px; }

  .detail #flow:before,
  .detail #flow:after {
    content: '';
    display: block;
    position: absolute;
    width: calc(50% - 245px);
    height: 70px;
    background-color: #fff;
    top: 0; }

  .detail #flow:before {
    left: 0; }

  .detail #flow:after {
    right: 0; }

  .detail #flow .flame_tl {
    display: none; }

  .detail #flow .secArea {
    margin-top: 40px; }

  .detail #flow .secArea ul li {
    width: 90%;
    margin: auto;
    box-sizing: border-box;
    background-color: #fff;
    border-radius: 12px;
    padding: 30px 5% 25px;
    position: relative; }

  .detail #flow .secArea ul li + li {
    margin-top: 50px; }

  .detail #flow .secArea ul li:not(:nth-child(1))::before {
    content: "";
    position: absolute;
    top: -40px;
    left: 0;
    right: 0;
    background-image: url("../img/arrow_p.png");
    background-size: cover;
    transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    width: 21px;
    height: 15px;
    margin: auto; }

  .detail #flow .secArea ul li div {
    position: absolute;
    top: -15px;
    left: 0;
    right: 0;
    margin: auto;
    width: 32px; }

  .detail #flow .secArea ul li p {
    display: table;
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    width: 100%;
    height: 100%; }

  .detail #flow .secArea ul li p span {
    display: table-cell;
    vertical-align: middle; }

  .detail #message .lead {
    text-align: left; }

  .detail #policy .secArea ul {
    margin-top: 40px; }

  .detail #policy .secArea ul li {
    box-sizing: border-box;
    background-image: url("../img/policy_odd.png");
    background-size: cover;
    width: 240px;
    height: 240px;
    margin: auto; }

  .detail #policy .secArea ul li:nth-child(even) {
    background-image: url("../img/policy_even.png"); }

  .detail #policy .secArea ul li + li {
    margin-top: 20px; }

  .detail #policy .secArea ul li:nth-child(n + 4) {
    margin-top: 70px; }

  .detail #policy .secArea ul li p {
    display: table;
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    width: 100%;
    height: 100%; }

  .detail #policy .secArea ul li p span {
    display: table-cell;
    vertical-align: middle; }

  .detail #policy .deco {
    bottom: -100px;
    right: 0%;
    width: 100px; }

  .detail #other .secArea ul {
    margin-top: 40px; }

  .detail #other .secArea ul li {
    box-sizing: border-box;
    background-image: url("../img/policy_odd.png");
    background-size: cover;
    width: 240px;
    height: 240px;
    margin: auto; }

  .detail #other .secArea ul li:nth-child(even) {
    background-image: url("../img/policy_even.png"); }

  .detail #other .secArea ul li + li {
    margin-top: 20px; }

  .detail #other .secArea ul li:nth-child(n + 4) {
    margin-top: 70px; }

  .detail #other .secArea ul li .inner {
    display: table;
    text-align: center;
    width: 100%;
    height: 100%; }

  .detail #other .secArea ul li .inner dl {
    display: table-cell;
    vertical-align: middle; }

  .detail #other .secArea ul li .inner dl dt {
    font-weight: bold;
    font-size: 16px;
    margin-bottom: 10px;
    letter-spacing: 1px; }

  .detail #other .secArea ul li .inner a {
    text-decoration: underline;
    color: #ff97aa;
    font-weight: bold; }

  .detail #staff {
    margin: 80px auto; }

  .detail #staff .wrap {
    padding: 0; }

  .detail #staff .secArea ul li {
    position: relative;
    padding: 0 5%; }

  .detail #staff .secArea ul li + li {
    margin-top: 55px;
    padding-top: 55px; }

  .detail #staff .secArea ul li + li::before {
    content: '';
    display: block;
    position: absolute;
    width: 100%;
    height: 3px;
    background-color: #ff97aa;
    border-radius: 2px;
    top: 0;
    left: 0; }

  .detail #staff .secArea ul li dl {
    line-height: 1.6; }

  .detail #staff .secArea ul li dl dt {
    font-weight: bold;
    font-size: 18px;
    text-align: center; }

  .detail #staff .secArea ul li dl dd {
    margin-top: 15px; }

  .detail #staff .secArea ul li dl dd div span {
    content: '';
    display: block;
    width: 100%;
    height: 2px;
    background-color: #e8e8e8;
    border-radius: 2px;
    margin: 1em 0; }

  .detail #staff .secArea ul li dl dd p {
    margin-top: 40px;
    border: solid 3px #66cbaf;
    border-radius: 12px;
    padding: 25px 15px 20px;
    position: relative;
    font-size: 14px; }

  .detail #staff .secArea ul li dl dd p span {
    font-weight: bold;
    text-align: center;
    position: absolute;
    left: 0;
    right: 0;
    top: -14px;
    background-color: #fff;
    display: inline-block;
    width: 120px;
    margin: auto;
    font-size: 16px; }

  .detail #req {
    position: relative; }

  .detail #req .deco {
    width: 80px;
    right: 0px;
    z-index: 101;
    top: -90px; }

  .detail #req h2 {
    margin-bottom: 40px; }

  .detail #req .wrap > dl {
    position: relative;
    margin: 0 auto;
    font-weight: bold; }

  .detail #req .wrap > dl + dl {
    margin-top: 30px; }

  .detail #req .wrap > dl > dt {
    position: absolute;
    top: -8px;
    text-align: center;
    right: 0;
    left: 0;
    margin: 0 auto;
    font-size: 14px; }

  .detail #req .wrap > dl > dd {
    background: url("../img/box_req2.png") no-repeat top center/cover;
    width: 220px;
    height: 220px;
    margin: 0 auto;
    text-align: center;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 16px; }

  .detail #req .wrap > dl:nth-of-type(1) > dd {
    background: url("../img/box_req.png") no-repeat top center/cover; }

  .detail #ex ul {
    position: relative;
    width: 90%;
    margin: 0 auto; }

  .detail #ex ul:after {
    display: none; }

  .detail #ex ul li {
    position: relative; }

  .detail #ex ul li:nth-of-type(1) {
    background: url("../img/ex01.jpg") no-repeat center/cover;
    border-radius: 16px;
    height: 300px; }

  .detail #ex ul li:nth-of-type(3) {
    background: url("../img/ex02.jpg") no-repeat center/cover;
    border-radius: 16px;
    height: 300px; }

  .detail #ex ul li:nth-of-type(4) {
    background: url("../img/ex03.jpg") no-repeat center/cover;
    border-radius: 16px;
    height: 300px; }

  .detail #ex ul li + li {
    margin-top: 20px; }

  .detail #ex ul li:nth-of-type(2) dl {
    background: url("../img/box02.png") no-repeat center/100% 100%;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    flex-direction: column;
    width: 100%;
    box-sizing: border-box;
    padding: 30px 40px 0;
    font-weight: bold;
    font-size: 16px; }

  .detail #ex ul li dl dt {
    position: relative;
    z-index: 2;
    color: #0da997;
    margin-bottom: 10px; }

  .detail #ex ul li dl dd {
    position: relative;
    z-index: 2; }

  .detail #ex ul li .fl:last-of-type {
    margin-top: -40px; }

  .detail .btn {
    width: 215px;
    border: solid 3px #66cbaf;
    border-radius: 18px;
    position: relative;
    color: #0da997;
    padding: 18px 25px 18px 5px;
    text-align: center;
    display: block;
    font-weight: bold;
    margin: 30px 0 0;
    line-height: 1em;
    box-sizing: border-box;
    font-feature-settings: "palt"; }

  .detail .btn + .btn {
    margin-top: 20px; }

  .detail .btn::before {
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    right: 15px;
    margin: auto;
    background-image: url(../../common/img/arrow.png);
    background-size: cover;
    width: 20px;
    height: 15px;
    transition: 300ms; }

  .detail .btn .type {
    display: inline-block;
    font-size: 12px;
    color: #fff;
    background-color: #0da997;
    border-radius: 6px;
    padding: 5px 8px;
    line-height: 1em;
    margin-right: 5px; }

  /* movie
  ---------------------------------*/
  #movieArea {
    position: relative;
    text-align: center;
    z-index: 100; }

  #movieArea .deco {
    top: -40px;
    right: -30px;
    width: 110px; }

  #movieArea .wrap {
    position: relative;
    background-image: url(../../common/img/bg_p.jpg);
    background-size: 350px;
    background-position: 0 0;
    padding-top: 100px;
    padding-bottom: 40px; }

  #movieArea .wrap .flame {
    display: none; }

  #movieArea .headbg {
    position: absolute;
    width: 100%;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto; }

  #movieArea h2 {
    line-height: 1.5;
    margin-bottom: 20px; }

  #movieArea h2:before,
  #movieArea h2:after {
    display: none; }

  #movieArea .wrap .deco.icon {
    width: 123px;
    left: 0;
    right: 0;
    top: 30px;
    margin: auto; }

  #movieArea .wrap iframe {
    width: 100%;
    height: 50.63vw; }

  /* prof11
  ---------------------------------*/
  #profile11.detail #sec01 .phtArea dl dt {
    text-align: center; }

  #profile11.detail #sec01 .phtArea dl dd {
    text-align: center;
    margin: 5px auto 0; }

  #profile11.detail #logoArea {
    margin-top: 60px; }

  #profile11.detail #logoArea .img_box {
    margin: 0 auto 20px;
    width: 160px; }

  #profile11.detail #logoArea .lead {
    text-align: left; }

  /* prof12
  ---------------------------------*/
  #profile12 #about .wrap_w {
    position: relative; }

  #profile12 #about .lead {
    text-align: center; }

  #profile12 #about .deco01 {
    bottom: -120px;
    left: 0;
    max-width: 153px;
    width: 25vw; }

  #profile12 #about .deco02 {
    width: 110px;
    right: -50px;
    z-index: 101;
    bottom: -160px; }

  #profile12 .calam > section .secArea {
    margin-top: 20px; }

  #profile12 .calam #contact .btnArea {
    margin-top: 20px; }

  #profile12 .calam #contact .btnArea a {
    margin: 0 auto; }

  #profile12 .calam #cafe h2 {
    max-width: 300px;
    font-feature-settings: "palt"; }

  #profile12 .calam #cafe dl {
    position: relative;
    margin: 0 auto;
    font-weight: bold;
    width: 261px; }

  #profile12 .calam #cafe dt {
    position: absolute;
    top: -8px;
    text-align: center;
    right: 0;
    left: 0;
    margin: 0 auto;
    font-size: 16px; }

  #profile12 .calam #cafe dd {
    background: url(../img/box_req2.png) no-repeat top center/cover;
    width: 100%;
    height: 261px;
    text-align: center;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 18px; } }
