@charset "utf-8";

/* 

Theme Name: Genova Template

File: content.css

Theme Author: Genova Design

Author URL: https://genova.co.jp/

Template: genova_tpl

Description: This file is reserved for under pages (not top-page) and other elements

Version: 1.3

*/



@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho+B1:wght@400;500;600;700&display=swap');

#header .header__main-container .header__sub-container .toggle-menu__trigger span {
    background: #B4C73A;
}

/*-----------------------------------------------------------

■ 1 Under page

-----------------------------------------------------------*/



#group {
    position: relative;
    margin: 81px 0 0;
  }
  @media screen and (max-width: 767px) {
    #group {
      margin-top: 64px;
    }
  }
  #group::before, #group:after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    height: 50%;
  }
  @media screen and (max-width: 767px) {
    #group::before, #group:after {
      height: 100%;
      width: 50%;
    }
  }
  #group::before {
    top: 0;
    background: #91A413;
  }
  @media screen and (max-width: 767px) {
    #group::before {
      right: auto;
    }
  }
  #group::after {
    bottom: 0;
    background: #B4C73A;
  }
  @media screen and (max-width: 767px) {
    #group::after {
      left: auto;
      top: 0;
    }
  }
  #group .inner {
    position: relative;
    z-index: 2;
    padding: 72px 60px;
  }
  @media screen and (max-width: 767px) {
    #group .inner {
      padding: 30px 30px;
    }
  }
  @media screen and (min-width: 768px) {
    #group .inner::before {
      content: "";
      position: absolute;
      top: 0;
      bottom: 0;
      left: calc(50% + 208px);
      right: 0;
      background: url("../img/top/group_deco.png") no-repeat center left/auto 100%;
    }
  }
  #group .box {
    padding: 10px;
    position: relative;
    width: 784px;
    max-width: 100%;
    margin: 0 auto;
  }
  #group .box::before, #group .box:after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    height: 50%;
  }
  @media screen and (max-width: 767px) {
    #group .box::before, #group .box:after {
      height: 100%;
      width: 50%;
      top: 0;
    }
  }
  #group .box::before {
    top: 0;
    background: var(--cl-page);
  }
  @media screen and (max-width: 767px) {
    #group .box::before {
      right: auto;
    }
  }
  #group .box::after {
    bottom: 0;
    background: #91A413;
  }
  @media screen and (max-width: 767px) {
    #group .box::after {
      left: auto;
    }
  }
  #group .box .box-inner {
    position: relative;
    z-index: 2;
    background: url("../img/gastroenterology/group_bg2.png") no-repeat top right/287px auto, url("../img/gastroenterology/group_bg.png") no-repeat center/cover;
    padding: 20px 20px 21px;
  }
  @media screen and (max-width: 767px) {
    #group .box .box-inner {
      padding: 40px 0 0;
      background: url("../img/top/group_bg2_sp.png") no-repeat right bottom 40px/70px auto, url("../img/gastroenterology/group_bg_sp.png") no-repeat center/cover;
    }
  }
  #group .box .box-inner::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background: url("../img/dentistry/group_triangle.png") no-repeat top left/100% auto;
    width: 288.5px;
    height: 82.5px;
  }
  @media screen and (max-width: 767px) {
    #group .box .box-inner::before {
      background: url("../img/top/group_triangle2.png") no-repeat top left/100% auto;
      width: 100px;
      height: 64px;
    }
  }
  #group .box .box-inner .tit {
    position: absolute;
    top: -80px;
    width: 348.5px;
    left: -69.5px;
  }
  #group .box .box-inner h4 {
    width: 418px;
    text-align: right;
    max-width: 100%;
    color: #91A413;
    font-size: 26px;
    line-height: 37px;
    font-weight: 500;
    letter-spacing: 0.04em;
  }
  #group .box .box-inner h4 small {
    display: block;
    font-size: 20px;
    line-height: 1.45;
  }
  @media screen and (max-width: 767px) {
    #group .box .box-inner h4 {
      width: 100%;
      text-align: center;
      font-size: 24px;
      line-height: 35px;
      letter-spacing: -0.05em;
    }
    #group .box .box-inner h4 small {
      font-size: 16px;
      line-height: 1.5;
    }
  }
  #group .box .box-inner .txt {
    font-size: 15px;
    line-height: 26px;
    margin: 17px 0 0;
    letter-spacing: -0.04em;
    max-width: calc(100% - 255px);
  }
  @media screen and (max-width: 767px) {
    #group .box .box-inner .txt {
      line-height: 24px;
      letter-spacing: 0.04em;
      margin: 16px 20px 46px;
      max-width: 100%;
    }
  }
  #group .box .box-inner .btn-link {
    width: 250px;
    text-align: left;
  }
  @media screen and (min-width: 768px) {
    #group .box .box-inner .btn-link {
      position: absolute;
      right: 16px;
      bottom: 16px;
    }
  }
  @media screen and (max-width: 767px) {
    #group .box .box-inner .btn-link {
      width: 100%;
    }
  }
  #group .box .box-inner .btn-link a {
    display: block;
    padding: 12px 0 12px 24px;
    font-size: 16px;
    line-height: 1.5;
    text-align: left;
    font-weight: 500;
    letter-spacing: 0.04em;
    position: relative;
    background: #E0C041;
    color: #fff;
  }
  #group .box .box-inner .btn-link a small {
    display: block;
    font-size: inherit;
  }
  #group .box .box-inner .btn-link a span {
    display: block;
    font-size: 24px;
  }
  #group .box .box-inner .btn-link a::before {
    display: none;
  }
  #group .box .box-inner .btn-link a::after {
    content: "";
    background: url("../img/top/arrow.png") no-repeat center right/100% auto;
    width: 14.5px;
  }
  @media screen and (min-width: 768px) {
    #group .box .box-inner .btn-link a::after {
      position: absolute;
      top: 0;
      bottom: 0;
      right: 20px;
    }
  }
  @media screen and (min-width: 768px) {
    #group .box .box-inner .btn-link a {
      border-radius: 50px;
    }
    #group .box .box-inner .btn-link a:hover {
      opacity: 0.8;
    }
  }
  @media screen and (max-width: 767px) {
    #group .box .box-inner .btn-link a {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0 23px;
      padding: 10px 0;
      border-radius: 0;
      font-size: 14px;
      line-height: 20px;
    }
    #group .box .box-inner .btn-link a span {
        font-size: 18px;
    }
    #group .box .box-inner .btn-link a::after {
      width: 14px;
      height: 12px;
      position: relative;
      top: auto;
      bottom: auto;
      background-image: url("../img/top/group_arrow_sp.png");
    }
  }
/*--------------------------------------

	general

--------------------------------------*/



#content {

    min-height: 600px;

    padding: 63px 0 100px;

}



.home #content {

    padding: 0;

}



.elementor-widget:not(:last-child) {

    margin-bottom: 0 !important;

}



p {

    margin-bottom: 0;

}



body {

    font-size: 16px;

    line-height: 32px;

    letter-spacing: 0.05em;

}



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

    body {

        font-size: 14px;

        line-height: 24px;

    }

}





/*--------------------------------------

	title holder

--------------------------------------*/



.title-holder {

    display: table;

    width: 100%;

    height: 300px;

    background: url('/wp-content/uploads/dentistry_h1_bg.png') no-repeat center/cover;

}



.title-holder .title-holder__inner {

    padding: 120px 0;

}



.title-holder .container {

    max-width: 1080px;

}



.title-holder .container h1,

.title-holder .container h2 {

    font-family: "Shippori Mincho B1", serif;

    background: #fff;

    color: #B5C73B;

    width: fit-content;

    padding: 6px 13px 9px;

    font-weight: bold;

    font-size: 36px;
    font-weight: bold;

    line-height: 1.2;

    letter-spacing: 0.2em;

}



.title-holder .container .sub-title {

    background: #92A415;

    color: #fff;

    width: fit-content;

    padding: 0 14px;

    font-size: 18px;

    line-height: calc(30/18);

    padding-left: 14px;

}



.title-holder .container .sub-title span {

    letter-spacing: 0.2em;

}





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



    .title-holder {

        height: 140px;

    }



    .title-holder .title-holder__inner {

        padding: 60px;

    }



    .title-holder .container h1,

    .title-holder .container h2 {

        font-size: 24px;

    }



    .title-holder .container .sub-title {

        font-size: 16px;

    }

}


.image-left .elementor-image-box-img {
    float: left;
    margin-left: 0!important;
    margin-right: 20px!important;
}

.box-child .elementor-image-box-title {
    background: transparent;
    color: #B4C63B;
    font-weight: 700;
    font-family: "Shippori Mincho B1", serif;
    font-size: 24px;
    line-height: 40px;
    padding: 0;
    overflow: visible;
}
@media screen and (max-width: 767px) {
    .box-child .elementor-image-box-title {
        font-size: 20px;
        line-height: 1.5;
    }
}



/*--------------------------------------

	bread

--------------------------------------*/



#bread {

    max-width: 1080px;

    width: 100%;

    padding: 0 30px;

    margin: 16px auto 0;

    text-align: center;

    line-height: 1.3;

}



#bread li {

    display: inline;

    font-size: 10px;

    letter-spacing: 0.1em;

    color: #77716C;

}



#bread li+li::before {

    content: ">";

    padding-right: .3em;

}



#bread li a {

    vertical-align: baseline;

    text-decoration: underline;

    color: #77716C;

}



#bread li a:hover {

    text-decoration: none;

}





/*--------------------------------------

	titles

--------------------------------------*/



/* h2 */

h2.elementor-heading-title {

    font-family: "Shippori Mincho B1", serif;

    text-align: left;

    background: #B5C73B;

    color: #fff;

    text-align: left;

    padding: 49px 30px 51px 67px;

    margin-bottom: 30px;

    font-size: 32px;

    line-height: calc(50/32);

    font-weight: bold;

    letter-spacing: 0.12em;

}



/* h3 */

h3.elementor-heading-title {

    font-family: "Shippori Mincho B1", serif;

    text-align: left;

    border-bottom: 2px solid #92A415;

    color: #454545;

    margin-bottom: 30px;

    padding-bottom: 18px;

    font-size: 28px;

    font-weight: 600;

    line-height: calc(45/28);

    letter-spacing: 0.12em;

}



/* h4 */

h4.elementor-heading-title {

    position: relative;

    font-family: "Shippori Mincho B1", serif;

    color: #454545;

    margin-bottom: 30px;

    padding-left: 40px;

    font-size: 24px;

    font-weight: 600;

    line-height: calc(40/24);

    letter-spacing: 0.1em;

}



h4.elementor-heading-title::before {

    content: '';

    position: absolute;

    background: #B5C73B;

    border-radius: 50%;

    width: 22px;

    height: 22px;

    top: 10px;

    left: 0;

}



/* h5 */

h5.elementor-heading-title {

    position: relative;

    font-family: "Shippori Mincho B1", serif;

    color: #92A415;

    margin-bottom: 20px;

    font-size: 20px;

    line-height: calc(35/20);

    font-weight: 500;

    letter-spacing: 0.05em;

}





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



    /* h2 */

    h2.elementor-heading-title {

        padding: 25px 20px;

        font-size: 25px;

    }



    /* h3 */

    h3.elementor-heading-title {

        padding-bottom: 12px;

        font-size: 23px;

    }



    /* h4 */

    h4.elementor-heading-title {

        padding-left: 30px;

        font-size: 21px;

    }



    h4.elementor-heading-title::before {

        width: 20px;

        height: 20px;

        top: 9px;

    }



    /* h5 */

    h5.elementor-heading-title {

        font-size: 18px;

    }

}



/*--------------------------------------

	btn

--------------------------------------*/

.btn {}



.btn a {

    position: relative;

    display: block;

    width: fit-content;

    background: #E0C041;

    color: #fff;

    border-radius: 50px;

    padding: 12px 60px 12px 24px;

    font-size: 15px;

    font-weight: 500;

    line-height: 21px;

    letter-spacing: 0.04em;

}



.btn a::before {

    content: '';

    position: absolute;

    background: url('../img/child/btn_icon.png') no-repeat;

    background-size: 100%;

    width: 14.5px;

    height: 13px;

    top: 50%;

    right: 24px;

    transform: translateY(-50%);

}



.btn a:hover {

    opacity: 0.7;

}



/*-----------------------------------------------------------

■ 2 Blocks

-----------------------------------------------------------*/



/*--------------------------------------

	google calendar

--------------------------------------*/



.google-calendar {

    position: relative;

    height: 0;

    padding-top: 500px;

    overflow: hidden;

}



.google-calendar iframe {

    position: absolute;

    top: 0;

    left: 0;

    width: 100%;

    height: 100%;

}



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



    .google-calendar {

        padding-top: 400px;

    }



}





/*--------------------------------------

	map

--------------------------------------*/



.map {

    position: relative;

    width: 100%;

    padding-top: 300px;

}



.map iframe {

    position: absolute;

    top: 0;

    right: 0;

    width: 100% !important;

    height: 100% !important;

    border: none;

}







/*--------------------------------------

	timetable

--------------------------------------*/

.time-table table {

    font-family: "Shippori Mincho B1", serif;

    table-layout: fixed;

    border-collapse: collapse;

    width: 100%
}



.time-table table * {

    font-weight: 500
}



.time-table table th {

    width: 18%;

    padding-left: 27px;

}



.time-table table td {

    text-align: center;

}



.time-table table thead {

    background: #92A415;

    color: #fff
}



.time-table table thead th {

    font-size: 18px;

    line-height: 58px;

    letter-spacing: .15em
}



.time-table table thead td {

    font-size: 25px;

    letter-spacing: .05em
}



.time-table table tbody {

    border-bottom: 1px solid #cbcac9
}



.time-table table tbody tr:nth-child(1) * {

    padding-top: 19px;

}



.time-table table tbody tr:nth-child(2) * {

    padding-bottom: 21px;

}





.time-table table tbody th {

    letter-spacing: .05em
}



.time-table table tbody td {

    color: #B5C73B;

    font-size: 20px;

    letter-spacing: .05em
}



.time-table table tbody td.txt-color {

    color: #22201e
}



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

    .time-table table thead th {

        font-size: 15px;

    }



    .time-table table thead td {

        font-size: 22px;

    }



    .time-table table tbody th {

        font-size: 13px;

    }



    .time-table table tbody td {

        font-size: 17px;

    }

}



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

    .time-table * {

        font-size: 12px !important;

    }



    .time-table table th {

        width: 90px;

        padding-left: 10px;

    }



    .time-table table td:last-child {

        width: 50px;

    }



    .time-table table thead th {

        line-height: 40px;

    }



    .time-table table tbody tr:nth-child(1) * {

        padding-top: 10px;

    }



    .time-table table tbody tr:nth-child(2) * {

        padding-bottom: 12px;

    }

}



/*--------------------------------------

	image wrap

--------------------------------------*/



.image-wrap__left img {

    float: left;

    margin: 0 15px 15px 0;

}



.image-wrap__right img {

    float: right;

    margin: 0 0 15px 15px;

}



@media (max-width: 768px) {



    .image-wrap__left img,

    .image-wrap__right img {

        display: block;

        float: none;

        width: auto;

        margin: 0 auto;

    }



}



/*--------------------------------------

	border box

--------------------------------------*/



.frame-box {

    padding: 40px;

    background: #F3FEF9;

    font-weight: 500;

}



.frame-box h3 {

    position: relative;

    padding: 0 0 15px 30px;

    margin-bottom: 20px;

    font-size: 20px;

    font-weight: 500;

    line-height: 31px;

    letter-spacing: 0.06em;

    color: #22201E;

    border-bottom: 1px solid #FF9AA2;

}



.frame-box h3::before {

    content: "";

    width: 16px;

    height: 16px;

    background: #FF9AA2;

    border-radius: 50%;

    position: absolute;

    left: 0;

    top: 8px;

}



.frameH.frame-box {

    border: 2px solid #000;

    background: none;

}



.frameH.frame-box h3 {

    border-bottom: 1px solid #C7C7C7;

    font-size: 20px;

}



.frameH.frame-box h3::before {

    background: #5C5C5C;

    width: 15px;

    height: 15px;

    border-radius: 0;

    top: 10px;

}



.frameH.frame-box .circle_list {

    padding-left: 10px;

}



.frameH.frame-box .circle_list li::before {

    background: #94C789;

}



.frameI {

    padding: 0 !important;

    background: none;

}



.frameI.frame-box h3 {

    border-bottom: 1px solid #F09586;

}



.frameI.frame-box h3::before {

    background: #F09586;

}





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

    .frame-box {

        padding: 5%;

    }



    .frame-box h3 {

        font-size: 18px;

        line-height: 29px;

        padding: 0 0 10px 25px;

        margin-bottom: 15px;

    }



    .frameH.frame-box h3 {

        font-size: 18px;

    }



    .frame-box h3::before {

        width: 13px;

        height: 13px;

        top: 7px;

    }



    .frameH.frame-box {

        border: 1px solid #000;

    }

}



/*--------------------------------------

	Q&A

--------------------------------------*/



.qa .qa__block+.qa__block {

    margin-top: 40px;

}



.qa__block dt,

.qa__block dd {

    position: relative;

}



.qa__block dt {

    background-image: linear-gradient(to right top, #8c5ba3, #9666a9, #a071ae, #aa7cb4, #b388ba);

    color: #fff;

    text-align: center;

    font-size: 32px;

    line-height: 1.5;

    padding: 18px 60px 18px 20px;

    border-radius: 40px;

    cursor: pointer;

}



.qa__block dd:after {

    content: '';

    width: 4px;

    position: absolute;

    left: 0;

    top: 0;

    bottom: 0;

    display: none;

}



.qa__block dd p {

    padding-top: 30px;

}





.qa__block dt:before {

    content: 'Q.';

    font-size: 40px;

    color: #fff;

    font-family: "Marcellus", serif;

    font-weight: 400;

    font-style: normal;

    margin-right: 20px;

}



.qa__block dt:after {

    content: "";

    background: url(../img/icon_plus.png) no-repeat top center;

    -webkit-background-size: 100% auto;

    background-size: 100% auto;

    width: 24px;

    height: 24px;

    position: absolute;

    top: 50%;

    right: 30px;

    margin-top: -12px;

}



.qa__block dt.open:after {

    background: url(../img/icon_plus.png) no-repeat bottom center;

    -webkit-background-size: 100% auto;

    background-size: 100% auto;

}



.qa__block dd {}



.qa__block dd:after {

    content: '';

    font-size: 31px;

    position: absolute;

    left: 17px;

    top: 0;

    color: #F5D09D;

    display: none;

}



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



    .qa__block dt,

    .qa__block dd {}



    .qa__block dt {

        font-size: 20px;

        padding: 12px 50px 12px 20px;

    }



    .qa__block dt:before {

        font-size: 20px;

    }



    .qa__block dt:after {

        width: 18px;

        height: 18px;

        right: 20px;

        margin-top: -9px;

    }



    .qa__block dd p {

        padding-top: 20px;

    }



    .qa .qa__block+.qa__block {

        margin-top: 25px;

    }

}



.melit .box {

    border-radius: 20px;

    padding: 45px 50px;

}



.melit .box .ttl {

    font-size: 20px;

    font-weight: bold;

    line-height: 27px;

    padding-left: 30px;

    position: relative;

    margin-bottom: 30px;

}



.melit .box .ttl:before {

    content: '';

    width: 16px;

    height: 16px;

    background: #F29800;

    border-radius: 50%;

    position: absolute;

    left: 0;

    top: 7px;

}



.melit .box ul li {

    position: relative;

    line-height: 24px;

    font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", sans-serif;

    padding-left: 30px;

}



.melit .box ul li:before {

    content: '';

    width: 11px;

    height: 11px;

    border-radius: 50%;

    background: #F29800;

    position: absolute;

    left: 0;

    top: 7px;

}



.melit .box ul li+li {

    margin-top: 13px;

}



.melit .box1 {

    background: #F7F6F0;

    margin-bottom: 35px;

}



.melit .box2 {

    background: #F1F0F7;

}



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

    .melit .box {

        padding: 25px;

    }



    .melit .box .ttl {

        font-size: 18px;

        padding-left: 25px;

    }



    .melit .box ul li {

        padding-left: 25px;

    }

}



/*--------------------------------------

	flow

--------------------------------------*/



.flow>li {

    position: relative;

    padding: 30px;

    margin-bottom: 35px;

    background: #F3F3F3;



}



.flow>li:last-child {

    margin-bottom: 0;

}



.flow>li::before {

    content: '';

    width: 0px;

    height: 0px;

    border-style: solid;

    border-width: 18px 18px 0 18px;

    border-color: #52514F transparent transparent transparent;

    position: absolute;

    bottom: -18px;

    left: 50%;

    transform: translateX(-50%);

}



.flow li:after {

    content: "." !important;

    clear: both !important;

    display: block !important;

    height: 0 !important;

    visibility: hidden !important;

}



.flow>li:last-child::before {

    display: none;

}



.flow .flow__title {

    position: relative;

    overflow: hidden;

    font-size: 20px;

    line-height: 31px;

    margin-bottom: 15px;

    color: #22201E;



}



.flow .flow__title span {



    display: inline-block;

    width: 33px;

    height: 33px;

    border-radius: 50%;

    margin-right: 10px;

    vertical-align: top;

    text-align: center;

    font-size: 20px;

    font-weight: 500;

    line-height: 32px;

    letter-spacing: 0;

    color: #fff;

    background: #52514F;

}



.flow p.photo {

    float: right;

    width: 30%;

    overflow: hidden;

    border-radius: 0px;

    margin: 0 0 20px 20px !important;

}



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

    .flow p.photo {

        float: none;

        width: 100%;

        border-radius: 5px;

        margin: 0 0 20px 0px !important;

    }



}





/*--------------------------------------

	post box

--------------------------------------*/



.post-box {

    margin: 30px auto 0 auto;

}



.post-box__header {

    position: relative;

    padding: 0 0 28px;

    border-bottom: 1px solid #EBE9E7;

}



.post-box__header h2 {

    text-align: center;

    font-size: 22px;

    font-weight: bold;

    letter-spacing: 0.15em;

    line-height: 1;

    color: #000000;

}



.post-box__summary-link {

    position: absolute;

    right: 0;

    top: 0;

    font-size: 13px;

    text-decoration: underline;

    color: #473019;

}



.post-box__summary-link:hover {

    text-decoration: none;

}



.post-box dl {

    padding: 15px 0 20px;

    background-size: 20px 1px;

}



.post-box dl dt {

    line-height: 1;

    margin-bottom: 10px;

    font-size: 13px;

    color: #72706E;

}



.post-box dl dt .new-label {

    display: inline-block;

    width: 37px;

    height: 13px;

    padding: 0;

    margin: -2px 0 0 10px;

    vertical-align: middle;

    line-height: 13px;

    font-size: 9px;

    font-weight: bold;

    letter-spacing: 0;

    text-indent: 0;

    text-align: center;

    color: #fff;

    background: #B09DC8;

}



.post-box dl dd a:hover {

    text-decoration: underline;

}





/*--------------------------------------

two columns table

--------------------------------------*/



.two-columns-table th,

.two-columns-table td {



    vertical-align: top;

    line-height: 1.6;

}



.two-columns-table th {

    width: 30%;

    padding: 13px 0px 10px 14px;

    border-bottom: 1px solid #9060A5;



}





.two-columns-table.color2 th {

    border-color: #90E0E0;

}



.two-columns-table td {

    padding: 13px 14px 10px;

    border-bottom: 1px solid #CBCAC9;

}



.square-list li {

    position: relative;

    padding-left: 32px;

}



.square-list li:before {

    content: '';

    width: 21px;

    height: 18px;

    background: #F29801;

    background: url(../img/icon_check.png) no-repeat;

    -webkit-background-size: 100% auto;

    background-size: 100% auto;

    position: absolute;

    left: 0;

    top: 7px;

}



.googlemap {

    position: relative;

    height: 350px;

}



.googlemap iframe {

    width: 100%;

    height: 100%;

    border: none;

    position: absolute;

    left: 0;

    right: 0;

    top: 0;

    bottom: 0;

}



/*-----------------------------------------------------------

■ 2 Blog

-----------------------------------------------------------*/



/*--------------------------------------

	post

--------------------------------------*/



#posts {

    float: left;

    width: 65%;

}



#blogDetail,

#blogList {

    min-height: 850px;

    margin-top: 40px;

    margin-bottom: 103px;

}



#blogList .post {

    padding-bottom: 35px;

    font-size: 16px;

    line-height: 2;

}



.posts__list li {

    position: relative;

    float: left;

    width: 45%;

    margin-left: 10%;

    margin-bottom: 75px;

}



.posts__list li:nth-child(2n+1) {

    margin-left: 0;

    clear: both;

}



.posts__list li .post__category {

    position: absolute;

    left: 0;

    top: 0;

    margin: 0;

    line-height: 1;

    z-index: 10;

}



.post .post__category a,

.posts__list .post__category a {

    display: inline-block;

    min-width: 107px;

    height: 25px;

    padding: 2px 8px;

    font-size: 12px;

    font-weight: 500;

    letter-spacing: 0;

    line-height: 23px;

    text-transform: uppercase;

    color: #fff;

    background: #8F68A2;

}



.post .post__category a:hover,

.posts__list .post__category a:hover {

    background: #8cc856;

}



.post .post__category a.news,

.posts__list .post__category a.news {

    background: #8F68A2;

}



.post .post__category a.news:hover,

.posts__list .post__category a.news:hover {

    background: #E05C4F;

}



.post .post__category a:before,

.posts__list .post__category a:before {

    margin-right: 7px;

    vertical-align: baseline;

    font-size: 10px;

}



.posts__list li .post__image {

    position: relative;

    overflow: hidden;

    min-height: 26px;

    margin-bottom: 20px;

}



.posts__list li .post__image a {

    display: block;

    width: 100%;

    height: 100%;

    padding-top: 54%;

}



.posts__list li .post__image a span {

    position: absolute;

    top: 0;

    left: 0;

    display: block;

    width: 100%;

    height: 100%;

    background-position: center;

    background-size: cover;

    background-repeat: no-repeat;

    -moz-transform: scale(1);

    -ms-transform: scale(1);

    -webkit-transform: scale(1);

    transform: scale(1);

    -moz-transition: ease-in-out .2s;

    -o-transition: ease-in-out .2s;

    -webkit-transition: ease-in-out .2s;

    transition: ease-in-out .2s;

}



.posts__list li .post__image a:hover span {

    -moz-transform: scale(1.1);

    -ms-transform: scale(1.1);

    -webkit-transform: scale(1.1);

    transform: scale(1.1);



}



.posts__list li .post__image span.noimage {

    overflow: hidden;

    line-height: 0;

    text-indent: 100%;

}



.posts__list h3 {

    margin-bottom: 35px;

    font-size: 18px;

    font-weight: bold;

    line-height: 1.4;

    letter-spacing: 0;

}



.posts__list h3 a:hover {

    color: #8F68A2;

}



.posts__list .post__excerpt {

    margin-bottom: 16px;

    font-size: 14px;

    line-height: 1.5;

    letter-spacing: 0;

    color: #72706E;

}





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



    .posts__list li {

        width: 48%;

        margin-left: 4%;

    }



    .posts__list li:nth-child(2n+1) {

        margin-left: 0;

    }



}





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



    #posts {

        float: none;

        width: 100%;

    }



    .posts__list li {

        margin-bottom: 50px;

    }



}





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



    .posts__list li {

        float: none;

        width: 100%;

        margin-left: 0;

    }



    #blogDetail .post__header h2 {

        font-size: 22px;

        line-height: 1.4;

    }



    #blogDetail .post__content h3 {

        padding: 26px 5px 26px 20px;

        margin: 35px 0 30px;

        font-size: 20px;

        line-height: 1.4;

    }



    #blogDetail .post__content h4 {

        font-size: 19px;

    }



}





/*--------------------------------------

	blog detail

--------------------------------------*/



#blogDetail .post {

    padding-bottom: 35px;

    font-size: 14px;

    line-height: 1.7;

    color: #0F0E0E;

}



#blogDetail .post__header {

    padding: 0px;

    margin-bottom: 25px;

}



#blogDetail .post__header h1 {

    font-size: 30px;

    font-weight: bold;

    line-height: 1.8;

    letter-spacing: 0.05em;

}



#blogDetail .post__header .post__meta {

    margin-bottom: 45px;

}



#blogDetail .post__header .post__meta .post__date {

    margin-top: 22px;

}





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



    #blogDetail .post__header .post__category,

    #blogDetail .post__header .post__meta .post__date {

        float: none;

    }



}





/*--------------------------------------

	post date

--------------------------------------*/



.post .post__date,

.posts__list .post__date {

    font-size: 10px;

    letter-spacing: 0;

    color: #8F68A2;

}



.post .post__date span,

.posts__list .post__date span {

    margin-left: 10px;

}



.post .post__date span::before,

.posts__list .post__date span::before {

    margin-right: 5px;

    font-size: 9px;

}



.post .post__date span a,

.posts__list .post__date span a {

    vertical-align: baseline;

    color: #8F68A2;

}



.post .post__date span a:hover,

.posts__list .post__date span a:hover {

    text-decoration: underline;

}



.post__content {

    overflow: hidden;

    letter-spacing: 0;

    line-height: 2.3;

}



.post__content a {

    color: #0000ee;

    text-decoration: underline;

}



.post__content h2 {

    font-size: 1.5em;

}



.post__content h3 {

    font-size: 1.4em;

}



.post__content h4 {

    font-size: 1.3em;

}



.post__content h5 {

    font-size: 1.2em;

}



div#blogDetail .post__content img {

    width: auto;

    height: auto;

    max-width: 100%;

}





/*--------------------------------------

	bloginfo box

--------------------------------------*/



.blog-info-box {

    display: table;

    width: 100%;

    margin-top: 60px;

    background: #EBE9E7;

}



.blog-info-box .blog-info-box__name {

    display: table-cell;

    width: 50%;

    padding: 29px 30px;

    border-right: 1px solid #BFBEBD;

    vertical-align: middle;

}



.blog-info-box .blog-info-box__name .icon-blog {

    position: relative;

    display: block;

    padding-left: 25px;

    font-size: 16px;

    line-height: 1.6;

    color: #373431;

}



.blog-info-box .blog-info-box__name .icon-blog::before {

    position: absolute;

    left: 0;

    top: 50%;

    display: block;

    margin-top: -6px;

    font-size: 15px;

    color: #8F68A2;

}



.blog-info-box .blog-info-box__share {

    display: table-cell;

    width: 50%;

    padding: 30px 10px;

    vertical-align: middle;

    text-align: center;

}



.blog-info-box .blog-info-box__share li {

    display: inline-block;

    margin: 0 5px;

    vertical-align: middle;

}



.blog-info-box .blog-info-box__share li a {

    display: block;

    overflow: hidden;

    width: 50px;

    height: 50px;

    border-radius: 50%;

    font-size: 0;

    line-height: 1;

}



.blog-info-box .blog-info-box__share li a::before {

    color: #fff;

}



.blog-info-box .blog-info-box__share .icon-facebook {

    background: #4967A3;

}



.blog-info-box .blog-info-box__share .icon-facebook:hover {

    background: #587cc1;

}



.blog-info-box .blog-info-box__share .icon-facebook::before {

    margin-top: 12px;

    font-size: 26px;

}



.blog-info-box .blog-info-box__share .icon-line {

    background: #18BC01;

}



.blog-info-box .blog-info-box__share .icon-line:hover {

    background: #1cde00;

}



.blog-info-box .blog-info-box__share .icon-line::before {

    font-size: 29px;

    margin-top: 11px;

}



.blog-info-box .blog-info-box__share .icon-twitter {

    background: #11BBEF;

}



.blog-info-box .blog-info-box__share .icon-twitter:hover {

    background: #13C7FE;

}



.blog-info-box .blog-info-box__share .icon-twitter::before {

    margin-top: 14px;

    font-size: 24px;

}



.blog-info-box .blog-info-box__share .icon-google {

    background: #E05C4F;

}



.blog-info-box .blog-info-box__share .icon-google:hover {

    background: #fb7468;

}



.blog-info-box .blog-info-box__share .icon-google::before {

    margin-top: 15px;

    font-size: 20px;

}



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



    .blog-info-box .blog-info-box__share li {

        margin: 0 3px;

    }



    .blog-info-box .blog-info-box__share li a {

        width: 40px;

        height: 40px;

    }



    .blog-info-box .blog-info-box__share .icon-facebook::before {

        margin-top: 9px;

        font-size: 22px;

    }



    .blog-info-box .blog-info-box__share .icon-line::before {

        margin-top: 8px;

        font-size: 25px;

    }



    .blog-info-box .blog-info-box__share .icon-twitter::before {

        margin-top: 11px;

        font-size: 20px;

    }



    .blog-info-box .blog-info-box__share .icon-google::before {

        margin-top: 12px;

        font-size: 16px;

    }



}



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



    .blog-info-box {

        display: block;

    }



    .blog-info-box .blog-info-box__name {

        display: block;

        width: 100%;

        padding: 20px;

        border-right: none;

        border-bottom: 1px solid #BFBEBD;

        text-align: center;

    }



    .blog-info-box .blog-info-box__name .icon-blog {

        display: inline-block;

        text-align: left;

    }



    .blog-info-box .blog-info-box__share {

        display: block;

        width: 100%;

        padding: 20px 10px;

    }



}





/*--------------------------------------

	navigation

--------------------------------------*/



.navigation {

    margin-top: 52px;

    overflow: hidden;

}



.navigation::after {

    content: "";

    display: table;

    clear: both;

}



.navigation .prev {

    float: left;

    width: 100px;

}



.navigation .next {

    float: right;

    width: 100px;

}



.navigation a {

    position: relative;

    display: block;

    width: 100%;

    height: 40px;

    border-radius: 5px;

    text-align: center;

    font-size: 14px;

    font-weight: bold;

    line-height: 40px;

    letter-spacing: 0.1em;

    color: #373431;

    background: #BFBEBD;

}



.navigation a:hover {

    background: #94C789;

}



.navigation .prev a span {

    padding-left: 8px;

}



.navigation .next a span {

    padding-right: 8px;

}



.navigation .prev a span::before {

    position: absolute;

    left: 8px;

    top: 50%;

    display: block;

    margin-top: -5px;

    font-size: 10px;

}



.navigation .next a span::before {

    position: absolute;

    right: 8px;

    top: 50%;

    display: block;

    margin-top: -5px;

    font-size: 10px;

}



.navigation ul {

    display: -webkit-flex;

    display: flex;

    max-width: 200px;

    margin: 0 auto;

}



.navigation li {

    display: -webkit-flex;

    display: flex;

    margin: 0 1px 0 2px;

    width: 30px;

}





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



    .navigation {

        margin-top: 35px;

    }



    .navigation ul {

        padding-top: 20px;

        clear: both;

    }



}





/*--------------------------------------

	pagination

--------------------------------------*/



.pagination {

    position: relative;

    padding-top: 52px;

    border-top: 1px solid #72706E;

    overflow: hidden;

}



.pagination ul {

    text-align: center;

}



.pagination ul li {

    display: inline-block;

    width: 30px;

}



.pagination ul li a,

.pagination ul li span.dots {

    position: relative;

    display: block;

    width: 100%;

    height: 40px;

    border-radius: 5px;

    text-align: center;

    font-size: 16px;

    line-height: 40px;

    letter-spacing: 0;

    font-weight: 400;

    color: #373431;

    background: #BFBEBD;

}



.pagination ul li span.dots {

    background: none;

}



.pagination ul li a:hover {

    background: #8F68A2;

}



.pagination ul li span.current {

    position: relative;

    display: block;

    width: 100%;

    height: 40px;

    border-radius: 5px;

    text-align: center;

    font-size: 16px;

    line-height: 40px;

    letter-spacing: 0;

    font-weight: 400;

    color: #373431;

    background: #8F68A2;

}



.pagination ul li .prev {

    position: absolute;

    left: 0;

    top: 52px;

    display: block;

    width: 100px;

    padding-left: 8px;

}



.pagination ul li .next {

    position: absolute;

    right: 0;

    top: 52px;

    display: block;

    width: 100px;

    padding-right: 8px;

    font-weight: bold;

}



.pagination ul li .prev span::before {

    position: absolute;

    left: 8px;

    top: 50%;

    display: block;

    margin-top: -5px;

    font-size: 10px;

}



.pagination ul li .next span::before {

    position: absolute;

    right: 8px;

    top: 50%;

    display: block;

    margin-top: -5px;

    font-size: 10px;

}







/*-----------------------------------------------------------

■ 2 Side

-----------------------------------------------------------*/



/*--------------------------------------

	general

--------------------------------------*/



.blogside {

    float: right;

    width: 28%;

}



.blogside h2.widgettitle {

    display: none;

}



.blogside h2 {

    padding-bottom: 9px;

    margin-bottom: 24px;

    border-bottom: 2px solid #373431;

    font-size: 18px;

    font-weight: 500;

    letter-spacing: 0.1em;

    line-height: 1;

    color: #373431;

}



.blogside h2 span {

    display: inline-block;

    margin-left: 10px;

    vertical-align: middle;

    font-size: 14px;

    letter-spacing: 0;

    color: #72706E;

}





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



    .blogside {

        float: right;

        width: 30%;

    }



    .blogside h2 {

        font-size: 14px;

        letter-spacing: 0;

    }



    .blogside h2 span {

        font-size: 12px;

    }



}





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



    .blogside {

        float: none;

        width: 100%;

        padding: 46px 0 0;

        border-top: 1px solid #5D5555;

        margin-top: 35px;

    }



}





/*--------------------------------------

	search box

--------------------------------------*/



.blogside .search-box {

    margin-bottom: 40px;

}



.blogside .search-box label {

    display: none;

}



.blogside .search-box #searchform {

    position: relative;

}



.blogside .search-box #s {

    height: 55px;

    width: 100%;

    padding: 0 40px 0 14px;

    border: none;

    font-size: 13px;

    color: #72706E;

    background: #EBE9E7;

}



.blogside .search-box .icon-search::before {

    position: absolute;

    right: 16px;

    top: 50%;

    margin-top: -8px;

    color: #8F68A2;

}



.blogside .search-box #searchsubmit {

    position: absolute;

    top: 50%;

    right: 16px;

    width: 15px;

    height: 15px;

    border: none;

    margin-top: -8px;

    font-size: 0;

    background: none;

    cursor: pointer;

}





/*--------------------------------------

	category box

--------------------------------------*/



.blogside .category-box {

    margin-bottom: 50px;

}



.blogside .category-box ul li {

    padding-bottom: 16px;

    border-bottom: 1px solid #b8c2c1;

    margin-bottom: 18px;

    text-transform: uppercase;

    color: #000;

}



.blogside .category-box ul li:last-child {

    margin-bottom: 0;

}



.blogside .category-box ul li a {

    font-size: 18px;

    font-weight: 500;

    letter-spacing: 0.1em;

    line-height: 1;

    color: #373431;

    -moz-transition: all .3s ease;

    -o-transition: all .3s ease;

    -webkit-transition: all .3s ease;

    transition: all .3s ease;

}



.blogside .category-box ul li a span {

    display: block;

    font-size: 14px;

    letter-spacing: 0;

    line-height: 1;

    color: #373431;

    -moz-transition: all .3s ease;

    -o-transition: all .3s ease;

    -webkit-transition: all .3s ease;

    transition: all .3s ease;

}



.blogside .category-box ul li a:hover,

.blogside .category-box ul li a:hover span {

    color: #8F68A2;

}





/*--------------------------------------

	recent box

--------------------------------------*/



.recent-box {

    margin-bottom: 50px;

}



.recent-box li {

    padding-bottom: 13px;

    border-bottom: 1px solid #BFBEBD;

    margin-bottom: 22px;

    font-size: 13px;

    line-height: 1.3;

}



.recent-box li:last-child {

    margin-bottom: 0;

}



.recent-box li .recent-box__thumbnail {

    position: relative;

    float: right;

    width: 48px;

    height: 48px;

    margin-left: 12px;

    overflow: hidden;

}



.recent-box li .recent-box__thumbnail a {

    display: block;

    width: 48px;

    height: 48px;

    line-height: 1;

}



.recent-box li .recent-box__thumbnail a span {

    display: block;

    width: 100%;

    height: 100%;

    background-position: center;

    background-repeat: no-repeat;

    background-size: cover;

    -moz-transform: scale(1);

    -ms-transform: scale(1);

    -webkit-transform: scale(1);

    transform: scale(1);

}



.recent-box li .recent-box__thumbnail a:hover {

    -moz-transform: scale(1.1);

    -ms-transform: scale(1.1);

    -webkit-transform: scale(1.1);

    transform: scale(1.1);

}



.recent-box li h3 a {

    color: #373431;

    -moz-transition: all .3s ease;

    -o-transition: all .3s ease;

    -webkit-transition: all .3s ease;

    transition: all .3s ease;

}



.recent-box li h3 a:hover {

    color: #8F68A2;

}



.recent-box__date {

    margin-top: 5px;

    font-size: 10px;

    color: #72706E;

}



.recent-box li .recent-box__date {

    margin-top: 15px;

}





/*--------------------------------------

	tag box

--------------------------------------*/



.blogside .tag-box {

    margin-bottom: 40px;

}



.blogside .tag-box h2 {

    margin-bottom: 12px;

}



.blogside .tag-box .tagcloud a {

    display: inline-block;

    padding: 7px 10px;

    border: 1px solid #72706E;

    margin-bottom: 9px;

    border-radius: 3px;

    font-size: 14px !important;

    letter-spacing: 0;

    line-height: 1;

    color: #373431;

    -moz-transition: all .3s ease;

    -o-transition: all .3s ease;

    -webkit-transition: all .3s ease;

    transition: all .3s ease;

}



.blogside .tag-box .tagcloud a:hover {

    color: #fff;

    background: #72706E;

}





/*--------------------------------------

	archive box

--------------------------------------*/



.archive-box {

    font-size: 14px;

    line-height: 1.4;

}



.archive-box>ul>li {

    margin-top: 20px;

}



.archive-box>ul>li:first-child {

    margin: 0;

}



.archive-box ul li p {

    position: relative;

    display: inline-block;

    padding-left: 22px;

    margin: 0;

    cursor: pointer;

}



.archive-box ul li p:visited {

    color: #373431;

}



.archive-box ul li p:hover {

    font-weight: 500;

    color: #8F68A2;

}



.archive-box ul li p.acv_open {

    font-weight: 500;

    color: #8F68A2;

}



.archive-box ul li p::before {

    content: '';

    position: absolute;

    top: 4px;

    left: 0;

    display: block;

    width: 8px;

    height: 8px;

    border-right: 1px solid #8F68A2;

    border-bottom: 1px solid #8F68A2;

    -moz-transform: rotate(-45deg);

    -ms-transform: rotate(-45deg);

    -webkit-transform: rotate(-45deg);

    transform: rotate(-45deg);

}



.archive-box ul li p.acv_open::before {

    top: 1px;

    left: 2px;

    -moz-transform: rotate(45deg);

    -ms-transform: rotate(45deg);

    -webkit-transform: rotate(45deg);

    transform: rotate(45deg);

}



.archive-box ul li a {

    color: #373431;

}



.archive-box ul li a:link {

    text-decoration: underline;

}



.archive-box ul li a:visited {

    color: #373431;

}



.archive-box ul li a:hover {

    color: #8F68A2;

}



.archive-box ul li a:active {

    color: #8F68A2;

}



.archive-box ul li ul {

    margin-left: 44px;

}



.archive-box ul li li {

    margin-top: 10px;

}



.archive-box ul li ul.hide {

    display: none;

}





/*-----------------------------------------------------------

 ■ 4 Special under pages

-----------------------------------------------------------*/



/*--------------------------------------

	sitemap

--------------------------------------*/



.sitemap>ul {

    margin: 0 auto;

    background: none;

}



.sitemap>ul>li {

    position: relative;

    border-bottom: 1px dashed #ccc;

    margin: 0;

    line-height: 1.4;

}



.sitemap>ul>li:first-child {

    border-top: 1px dashed #ccc;

}



.sitemap>ul>li::before {

    content: '';

    position: absolute;

    left: 0;

    top: 25px;

    display: block;

    width: 8px;

    height: 8px;

    border-radius: 50%;

    background: #8F68A2;

}



.sitemap>ul>li a {

    position: relative;

    display: block;

    padding: 19px 40px 15px 20px;

    background: none;

}



.sitemap>ul>li a::after {

    content: "";

    position: absolute;

    top: 50%;

    right: 18px;

    display: block;

    width: 10px;

    height: 10px;

    border-top: 2px solid #ccc;

    border-right: 2px solid #ccc;

    margin-top: -5px;

    -moz-transform: rotate(45deg);

    -ms-transform: rotate(45deg);

    -webkit-transform: rotate(45deg);

    transform: rotate(45deg);

}



.sitemap>ul>li a:hover {

    color: #8F68A2;

}



.sitemap ul li:nth-child(9),

.sitemap ul li:last-child {}



/*-----------------------------------------------------------

 ■ 5 Contact

-----------------------------------------------------------*/



.wrap_contact {

    max-width: 800px;

    margin: 0 auto;

}



.inquiryForm_message {

    text-align: center;

}



/* step list */

.step_list {

    width: 467px;

    margin: 0 auto 90px;

}



.step_list li {

    position: relative;

    float: left;

    width: 100px;

    margin-left: 83px;

    text-align: center;

    font-size: 18px;

    font-weight: bold;

    line-height: 1;

    color: #BFBEBD;

}



.step_list li:first-child {

    margin: 0;

}



.step_list li span {

    position: relative;

    display: block;

    width: 54px;

    height: 54px;

    margin: 0 auto 12px;

    border-radius: 50%;

    text-align: center;

    font-size: 22px;

    font-weight: bold;

    letter-spacing: 0;

    line-height: 54px;

    color: #fff;

    background: #BFBEBD;

}



.step_list li span::after {

    content: "";

    position: absolute;

    top: 50%;

    left: 54px;

    display: block;

    width: 130px;

    height: 1px;

    background: #bfbebd;

}



.step_list li:last-child span::after {

    display: none;

}



.step_list li.current {

    color: #373431;

}



.step_list li.current span {

    background: #8F68A2;

}



.step_list li span.current:after {

    background: #8F68A2;

}



.inquiryForm_message .step_catch {

    margin-bottom: 44px;

    text-align: center;

    font-size: 16px;

    letter-spacing: 0.05em;

    color: #373431;

}



.inquiryFormTable {

    padding-top: 22px;

    border-top: 1px solid #707070;

    font-size: 16px;

}



.inquiryFormTable dl {

    display: table;

    width: 100%;

}



.inquiryFormTable dt,

.inquiryFormTable dd {

    display: table-cell;

    padding: 20px 0 24px;

    vertical-align: top;

    text-align: left;

}



.inquiryFormTable dt {

    position: relative;

    width: 29%;

    padding-top: 31px;

    border-right: none;

    letter-spacing: 0.1em;

    font-weight: bold;

    color: #2C2F30;

}



.inquiryFormTable dd {

    position: relative;

    padding-right: 40px;

}



.inquiryFormTable .wpcf7-list-item {

    display: block;

    width: 100%;

    margin: 0 0 13px;

}



.wpcf7-list-item-label {

    position: relative;

}



span.wpcf7-list-item-label::before,

span.wpcf7-list-item-label::after {

    display: none;

}



.wpcf7-form-control-wrap {

    display: block;

}



.inquiryFormTable input,

.inquiryFormTable textarea,

.inquiryFormTable select {

    display: block;

    width: 100%;

    padding: 13px 14px 14px;

    border: 1px solid #BFBEBD;

    border-radius: 5px;

    color: #333;

    background: #EBE9E7;

}



.inquiryFormTable textarea {

    resize: vertical;

}



.inquiryFormTable select {

    position: relative;

    background: #ECECEC url(../img/icons/ico_select.svg) no-repeat 96% center;

    background-size: 12px 10px;

    appearance: none;

    -webkit-appearance: none;

    -moz-appearance: none;

}



.inquiryFormTable select::-ms-expand {

    display: none;

}



.inquiryFormTable input:focus,

.inquiryFormTable textarea:focus,

.inquiryFormTable select:focus {

    box-shadow: 0 0 3px 1px #80cbc4;

}



/* checkbox and radio*/

.inquiryFormTable input[type="checkbox"],

.inquiryFormTable input[type="radio"] {

    -moz-opacity: 0;

    opacity: 0;

    -webkit-appearance: none;

    -moz-appearance: none;

    appearance: none;

    position: absolute;

}



.inquiryFormTable input[type="radio"]+span::before,

.inquiryFormTable input[type="checkbox"]+span::before {

    display: inline-block;

    margin-bottom: 2px;

    margin-right: 10px;

    font-family: 'icomoon';

    font-style: normal;

    font-weight: normal;

    font-variant: normal;

    text-transform: none;

    line-height: 1;

    speak: none;

    vertical-align: middle;

    -webkit-font-smoothing: antialiased;

    -moz-osx-font-smoothing: grayscale;

}



.inquiryFormTable input[type="checkbox"]+span::before {

    content: "\ea53";

    border-radius: 2px;

}



.inquiryFormTable input[type="checkbox"]:checked+span::before {

    content: "\ea52";

    color: #354fa8;

}



.inquiryFormTable input[type="checkbox"]:focus+span::before {

    box-shadow: 0px 0px 2px 2px #80cbc4;

}



.inquiryFormTable input[type="radio"]+span::before {

    content: "\ea56";

    border-radius: 50%;

}



.inquiryFormTable input[type="radio"]:checked+span::before {

    content: "\ea54";

    color: #354fa8;

}



.inquiryFormTable input[type="radio"]:focus+span::before {

    box-shadow: 0px 0px 2px 2px #80cbc4;

}



/* checkbox and radio confimation screen */

.confirm_table input[type="checkbox"]:not(:checked)+span,

.confirm_table input[type="radio"]:not(:checked)+span {

    display: none;

}



.inquiryFormTable .wpcf7-checkbox>span:first-child,

.inquiryFormTable .wpcf7-radio>span {

    padding-top: 10px;

}



.inquiryFormTable .wpcf7-radio {

    display: -webkit-flex;

    display: flex;

    -webkit-justify-content: flex-start;

    justify-content: flex-start;

    -webkit-align-items: flex-start;

    align-items: flex-start;

}



.inquiryFormTable .wpcf7-radio>.wpcf7-list-item {

    width: auto;

    margin-right: 20px;

}



.inquiryFormTable .wpcf7-radio>.wpcf7-list-item:last-child {

    margin-right: 0;

}



.failed .verified_table.inquiryFormTable input.wpcf7-validates-as-required,

.invalid .verified_table.inquiryFormTable input.wpcf7-validates-as-required {

    border: 1px solid #8F68A2;

    background: #fff;

    box-shadow: 0 0 5px rgba(111, 186, 44, 0.5);

}



.inquiryFormTable input.wpcf7-not-valid {

    border: 1px solid #D93636 !important;

    background: #FDD2D2 !important;

}



.inquiryFormTable .comment {

    display: block;

    margin-top: 0.4em;

    font-size: 13px;

    letter-spacing: 0;

    color: #63696A;

}



/* required and optional */

.inquiryFormTable .required {

    position: absolute;

    top: 36px;

    right: 28px;

    display: inline-block;

    padding-left: 0;

    width: 46px;

    height: 22px;

    border-radius: 10px;

    text-align: center;

    font-size: 14px;

    font-weight: 700;

    line-height: 22px;

    color: #fff;

    background: #D93636;

}



.inquiryFormTable .optional {

    position: absolute;

    top: 36px;

    right: 28px;

    display: inline-block;

    width: 46px;

    height: 22px;

    padding-left: 0;

    border-radius: 10px;

    text-align: center;

    font-size: 14px;

    font-weight: 700;

    line-height: 22px;

    color: #fff;

    background: #63696A;

}



.inquiryFormTable .btBox {

    text-align: center;

    margin: 103px 0 80px;

}



.inquiryFormTable .btBox input[type="submit"] {

    display: block;

    width: 100%;

    padding: 29px 32px 28px 30px;

    border: none;

    margin: 0 auto;

    border-radius: 0 !important;

    font-size: 26px;

    letter-spacing: 0.1em;

    line-height: 1.2;

    color: #fff;

    background: #8F68A2 url(../img/icons/ico_arrow02.png) no-repeat 95% center !important;

    background-size: 6px 10px;

    cursor: pointer;

    outline: 0px;

    -webkit-appearance: none;

}



.inquiryFormTable .btBox input[type="submit"].disabled {

    padding: 29px 40px 28px 40px;

    opacity: 1 !important;

    color: #BFBEBD;

    background: #72706E url(../img/icons/ico_arrow01.png) no-repeat 96% center !important;

    background-size: 6px 10px;

    pointer-events: none;

    cursor: default;

}



.inquiryFormTable .btBox input[type="submit"].abled {

    padding: 29px 40px 28px 40px;

    background-position: 96% center !important;

}



.inquiryFormTable .wpcf7-back {

    float: left;

    width: 37.5% !important;

    padding: 29px 30px 28px;

    border: none;

    margin: 0 auto;

    border-radius: 0 !important;

    outline: 0px;

    text-align: left;

    font-size: 26px;

    letter-spacing: 0.1em;

    line-height: 1.2;

    color: #fff;

    background: #72706E url(../img/icons/ico_arrow02.png) no-repeat 92% center !important;

    background-size: 6px 10px;

    cursor: pointer;

    -webkit-appearance: none;

}



.inquiryFormTable .wpcf7-submit {

    float: right;

    width: 58.5% !important;

    text-align: left;

}



.inquiryFormTable .btBox input[type="submit"]:hover,

.inquiryFormTable .btBox input[type="button"]:hover {

    opacity: 0.8;

}



span.verify_icon {

    position: absolute;

    top: 13px;

    right: -42px;

    display: none;

    width: 25px;

    height: 25px;

}



.verified_table .wpcf7-validates-as-required:not(.wpcf7-not-valid)+.verify_icon {

    display: block;

}



.verified_table .wpcf7-validates-as-required:not(.wpcf7-not-valid)+.verify_icon::before {

    vertical-align: top;

    font-size: 25px;

    color: #8F68A2;

}



.inquiryFormTable .wpcf7-not-valid-tip {

    color: #DE5050;

    font-weight: normal;

    display: block;

    font-size: 12px;

}



.file_btn {

    position: relative;

    display: block;

    width: 123px;

    height: 30px;

    margin-top: 13px;

    overflow: hidden;

    text-align: center;

    font-size: 14px;

    line-height: 30px;

    color: #fff;

    background: #807B7B;

    cursor: pointer;

}



.file_btn .wpcf7-form-control-wrap {

    position: absolute;

    top: 0;

    right: 0;

    width: 100%;

    height: 30px;

    margin: 0;

    opacity: 0;

    filter: progid:DXImageTransform.Microsoft.Alpha(opacity=0);

}



div.wpcf7 input[type="file"] {

    position: absolute;

    top: 0;

    right: 0;

    width: 100%;

    height: 30px;

    padding: 0;

    border: 0;

}



.failed .confirm_table input[type="text"],

.failed .confirm_table input[type="tel"],

.failed .confirm_table input[type="email"],

.failed .confirm_table input[type="date"],

.failed .confirm_table textarea,

.failed .confirm_table select,

.failed .confirm_table input[type="checkbox"] {

    display: none;

}



.failed .confirm_table .required,

.failed .confirm_table .optional {

    display: none;

}



.failed .confirm_table .wpcf7-list-item-label {

    display: none;

}



.failed .confirm_table span.comment {

    display: none;

}



.failed .confirm_table .wpcf7-form-control-wrap.your-email_confirm {

    display: none;

}



.result_txt {

    display: block;

    word-break: break-all;

    white-space: pre-wrap;

}



.failed .confirm_table .wpcf7-list-item {

    padding-left: 0;

}



.failed .confirm_table dt,

.failed .confirm_table dd {

    padding: 12px 0 10px;

}



.wpcf7-mail-sent-ok,

div.wpcf7 .ajax-loader,

div.wpcf7-validation-errors {

    display: none !important;

}





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



    .inquiryFormTable dt {

        width: 35%;

    }



}





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



    .step_list {

        width: 400px;

        margin: 0 auto 60px;

    }



    .step_list li {

        margin-left: 50px;

    }



    .inquiryFormTable dl {

        display: block;



    }



    .inquiryFormTable dt,

    .inquiryFormTable dd {

        display: block;

        width: 100%;

        padding: 0;

    }



    .inquiryFormTable dd {

        padding: 10px 40px 30px 0;

    }



    .inquiryFormTable .required,

    .inquiryFormTable .optional {

        position: static;

        display: inline-block;

        margin-left: 20px;

        margin-top: -2px;

        vertical-align: middle;

    }



    .inquiryFormTable .btBox {

        margin: 50px 0;

    }



    .inquiryFormTable .btBox input[type="submit"],

    .inquiryFormTable .wpcf7-back {

        text-align: center;

        float: none;

        width: 100% !important;

        padding: 29px 20px 28px 20px;

        font-size: 20px;

        background-position: 96% center !important;

    }



    .inquiryFormTable .btBox input[type="submit"].disabled,

    .inquiryFormTable .btBox input[type="submit"].abled {

        padding: 29px 20px 28px 20px;

    }



    .inquiryFormTable .wpcf7-back {

        margin-bottom: 15px;

    }



    .file_btn {

        margin-top: 0;

    }



    .failed .confirm_table dt,

    .failed .confirm_table dd {

        padding: 5px 0;

    }



}





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



    .step_list {

        width: 270px;

    }



    .step_list li {

        width: 70px;

        margin-left: 30px;

        font-size: 16px;

    }



    .step_list li span:after {

        width: 60px;

    }



    .inquiryForm_message .step_catch {

        font-size: 12px;

        letter-spacing: 0;

    }



    .inquiryFormTable .btBox input[type="submit"],

    .inquiryFormTable .wpcf7-back {

        font-size: 16px;

        letter-spacing: 0.1em;

    }



}



.wpcf7 form.failed .wpcf7-response-output,

.wpcf7 form.aborted .wpcf7-response-output {

    border-color: #46b450;

}







/*--------------------------------------

* anchorlinks

--------------------------------------*/

.anchorlinks {

    padding: 30px 60px;

    background: #E6ECBD;

    list-style: none;

    display: flex;

    flex-wrap: wrap;

    gap: 7px 42px;

}



.anchorlinks li {

    position: relative;

    padding-left: 21px;

    font-size: 17px;

    line-height: 36px;

    letter-spacing: 0.15em;

}



.anchorlinks li a {

    text-decoration: underline;

    color: #454545;

    letter-spacing: 0.15em;

}



.anchorlinks li a:before {

    content: "";

    position: absolute;

    top: 10px;

    left: 0;

    background: url('../img/child/anchorlinks_icon2.png') no-repeat;

    background-size: 100%;

    width: 13px;

    height: 18px;

    background-size: 100%;

    -webkit-transition-duration: 0.6s;

    -ms-transition-duration: 0.6s;

    -moz-transition-duration: 0.6s;

    transition-duration: 0.6s;

}



.anchorlinks li a:hover:before {

    -webkit-transform: rotate(90deg);

    -moz-transform: rotate(90deg);

    -o-transform: rotate(90deg);

    transform: rotate(90deg);

}



.anchorlinks li a:hover {

    text-decoration: none;

}





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

    .anchorlinks {

        padding: 20px 30px 25px;

    }

}





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

    .anchorlinks {

        padding: 20px;

        gap: 10px 15px;

    }



    .anchorlinks li {

        padding-left: 16px;

        font-size: 14px;

        line-height: 28px;

    }



    .anchorlinks li a::before {

        width: 10px;

        height: 14px;

    }

}



/*--------------------------------------

リスト

--------------------------------------*/

.circle_list li {

    position: relative;

    padding: 2px 0 2px 27px;

    list-style: none;

}





.circle_list li:before {

    content: "";

    position: absolute;

    background: #9161A6;

    top: 9px;

    left: 0;

    height: 16px;

    width: 16px;

    border-radius: 50%;

}











.boxC,

.boxB {

    padding: 45px 50px;

}



.boxC .ttl {

    font-size: 20px;

    line-height: 27px;

    padding-left: 30px;

    position: relative;

    margin-bottom: 30px;

}



.boxC .ttl:before {

    content: '';

    width: 16px;

    height: 16px;

    background: #90E0E0;

    border-radius: 50%;

    position: absolute;

    left: 0;

    top: 7px;

}



.boxC ul li {

    position: relative;

    line-height: 24px;

    font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", sans-serif;

    padding-left: 30px;

}



.boxC ul li:before {

    content: '';

    width: 11px;

    height: 11px;

    border-radius: 50%;

    background: #94C789;

    position: absolute;

    left: 0;

    top: 7px;

}



.boxC ul li+li {

    margin-top: 8px;

}



.boxC {

    border-radius: 20px;

    border: 2px solid #FF9AA2;

}



.boxC .ttl:before {

    background: #FF9AA2;

}



.boxC ul li:before {

    background: #F3A89A;

}



.boxC .photo {

    float: right;

    display: block !important;

    width: 30% !important;

    margin: 0 0 10px 20px !important;

    text-align: right;

}



.boxB {

    padding: 50px;

    border: 2px solid #000;



}



.boxB p {

    margin-bottom: 20px;

}



.boxB p:last-child {

    margin-bottom: 0;

}



.boxB .ttl-s,

.boxB .ttl {

    border-bottom: 1px solid #C7C7C7;

    font-size: 20px;

    line-height: 29px;

    padding: 0 0 10px 25px;

    margin-bottom: 15px;

    position: relative;

}



.boxB .ttl-s::before,

.boxB .ttl::before {

    content: "";

    width: 15px;

    height: 15px;

    background: #5C5C5C;

    transform: rotate(45deg);

    position: absolute;

    top: 8px;

    left: 0;

}



.boxB .ttl-s {

    font-size: 16px;

    padding-left: 25px;

    border-bottom: none;

    margin-bottom: 5px;

}



.boxB .ttl-s::before {

    transform: rotate(0);

    border-radius: 50%;

}



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



    .boxB,

    .boxC {

        padding: 5%;

    }



    .boxB .ttl-s,

    .boxB .ttl,

    .boxC .ttl {

        font-size: 18px;

        padding-left: 25px;

    }



    .boxC ul li {

        padding-left: 25px;

    }



    .boxC .photo {

        float: none;

        width: 100% !important;

        margin: 0 auto 20px !important;

        text-align: center;

    }



    .boxB {

        border: 1px solid #000;

    }







}







.frame_E::after {

    content: "";

    background: #F3FEF9;

    position: absolute;

    top: -50px;

    left: -50%;

    right: -50%;

    bottom: -50px;

    z-index: -1;

}



.frame_E .frame-box {

    background-color: #FFFFFF;

}







.photo_C {

    border: 2px solid #191919;

    padding: 50px;

}



.photo_C .inside {

    color: #707070;

    font-size: 20px;

}



.photo_C .inside+.inside {

    margin-top: 40px;

}



.photo_C .inside .ttl {

    font-size: 20px;

    position: relative;

    border-bottom: 1px solid #C7C7C7;

    padding: 10px 30px;

    margin-bottom: 10px;

    line-height: 1.78;

}





.photo_C .inside .ttl::before {

    content: '';

    position: absolute;

    top: 19px;

    width: 15px;

    height: 15px;

    background: #BADCA2;

    transform: rotate(45deg);

    left: 0px;

    z-index: 1;

}



.photo_C .inside .elementor-image-box-img {

    background: #fff;

    position: relative;

    z-index: 2;

    padding-left: 10px;

    width: 35% !important;

    margin-left: 0 !important;

}



.photo_C .btn-style {

    padding-top: 20px;

    text-align: right;

    color: #000;

}



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

    .photo_C {

        padding: 5%;

        border: 1px solid #000;

    }



    .photo_C .inside,

    .photo_C .inside .ttl {

        font-size: 16px;

    }



    .photo_C .inside+.inside {

        margin-top: 20px;

    }



    .photo_C .inside .elementor-image-box-img {



        float: none;

        width: 100% !important;

        margin: 0 auto 20px !important;

        text-align: center;

        padding-left: 0;



    }



    .photo_C .btn-style {

        text-align: center;

    }



}





.btn-style a {

    padding: 5px 30px;

    background: #8F68A2;

    line-height: 1;

    text-align: center;

    font-size: 11px;

    position: relative;

    border-radius: 24px;

    transition: all .4s ease;

}



.btn-style a.cl-grey {

    background: #504F4F;

}



.btn-style a:hover {

    opacity: .6;

}



.btn-style a::after {

    content: "";

    background: url(../img/icon_arrow.png) no-repeat;

    -webkit-background-size: 100% auto;

    background-size: 100% auto;

    width: 5px;

    height: 8px;

    position: absolute;

    top: 50%;

    margin-top: -4px;

    right: 10px;

}







.photo_D {

    display: flex;

    justify-content: space-between;

}



.photo_D .elementor-col-33 {

    width: 31%;

    padding: 2% 2% 5%;

    border: 2px solid #000;

    box-sizing: border-box;

}



.photo_D .elementor-image {}



.photo_D .elementor-image img {

    width: 100% !important;

}



.photo_D dl {

    padding-top: 20px;

}



.photo_D dl dt {

    font-size: 24px;

    line-height: 35px;

    letter-spacing: 0.02em;

    margin-bottom: 10px;

}



.photo_D dl dd {}





.photo_D .photo_D02 {

    margin: 0 3%;

}



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

    .photo_D {

        display: block;

    }



    .photo_D dl dt {

        font-size: 20px;

    }



    .photo_D .elementor-col-33 {

        width: 100%;

        display: block;

        padding: 5% 5% 8%;

        border: 1px solid #000;

    }



    .photo_D .photo_D02 {

        margin: 40px 0;

    }

}





.box_C {

    border: 2px solid #191919;

    padding: 50px;

}





.circle_num {

    counter-reset: list-number;

}



.circle_num li {

    position: relative;

    list-style: none;

}



.circle_num li+li {

    margin-top: 10px;

}



.circle_num li:before {

    counter-increment: list-number;

    content: counter(list-number);

    margin-right: 10px;

    line-height: 25px;

    width: 25px;

    height: 25px;

    display: inline-flex;

    align-items: center;

    justify-content: center;

    font-size: 16px;

    background-color: #5C5C5C;

    border-radius: 50%;

    color: #fff;

    font-family: "dnp-shuei-gothic-kin-std", sans-serif;

    font-weight: 400;

}



.column2_list {

    display: -webkit-flex;

    display: -moz-flex;

    display: -ms-flex;

    display: -o-flex;

    display: flex;

    justify-content: space-between;

}



.column2_list ul {

    width: 48%;

}



.gray-cl li:before {

    background: #D7D7D7;

}



.browns-cl li:before {

    background: #5C5C5C;

}



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

    .box_C {

        border: 1px solid #191919;

        padding: 5%;

    }



    .column2_list {

        display: block;

    }



    .column2_list ul {

        width: 100%;

    }



}





.frame_D {

    border: 2px solid #191919;

    padding: 50px;

}



.frame_D h4 {

    border-bottom: 1px solid #191919;

    line-height: 1.8;

    padding-bottom: 10px;

    text-align: center;

    margin-bottom: 20px;

    font-size: 20px;

}



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

    .frame_D {

        border: 1px solid #191919;

        padding: 5%;

    }



    .frame_D h4 {

        font-size: 18px;

    }







}





.frame_F .ttl::before {

    content: "";

    background: #5C5C5C;

    width: 15px;

    height: 15px;

    border-radius: 0;

    top: 8px;

    transform: rotate(0);

}



.frame_F .circle_num {

    margin-bottom: 30px;

    border-bottom: 1px solid #C7C7C7;

    padding-bottom: 20px;

}





.frame_G {

    display: -webkit-flex;

    display: -moz-flex;

    display: -ms-flex;

    display: -o-flex;

    display: flex;

    justify-content: space-between;

}



.frame_G .frame_D {

    width: 49%;

    border-width: 3px;

    border-color: #5C5C5C;



}



.frame_G .frame_D h4 {

    border-color: #5C5C5C;

}



.frame_G .frame_D:first-child {

    background: #C7C7C7;

    border-color: #C7C7C7;

}



.frame_G .frame_D p {

    padding-left: 20px;

    padding-right: 20px;

}



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

    .frame_G {

        display: block;

    }



    .frame_G .frame_D {

        width: 100%;

        border-width: 2px;

    }



    .frame_G .frame_D:first-child {

        margin-bottom: 30px;

    }

}



/* list A */

.list_A {}



.list_A li {

    position: relative;

    padding-left: 31px !important;

    letter-spacing: 0.05em;

}



.list_A li * {

    letter-spacing: 0.05em;

}



.list_A li::before {

    content: '';

    position: absolute;

    border: 4px solid #B5C73B;

    width: 17px;

    height: 17px;

    border-radius: 50%;

    top: 8.5px;

    left: 0;

}



.list_A li+li {

    margin-top: 5px !important;

}

@media screen and (max-width: 767px) {
    .list_A li {
        padding-left: 24px !important;
    }
    .list_A li::before {
        width: 14px;
        height: 14px;
        top: 5.5px;
    }
}




/* list A@ */

.list_A2 {}



.list_A2 li {

    position: relative;

    padding-left: 31px !important;

    letter-spacing: 0.05em;

}



.list_A2 li * {

    letter-spacing: 0.05em;

}



.list_A2 li::before {

    content: '';

    position: absolute;

    background: url('../img/child/list_a2_icon.png') no-repeat;

    background-size: 100%;

    width: 24.5px;

    height: 23px;

    top: 8px;

    left: 0;

}



.list_A2 li+li {

    margin-top: 5px !important;

}



/* Frame Custom 1 */

.frame_custom2 {

    background: url('../img/child/frame_custom2_deco.png') no-repeat right bottom/516px;

}



.frame_custom2 .row .elementor-row {

    justify-content: space-between;

    flex-wrap: nowrap;

    -moz-column-gap: 30px;

    column-gap: 30px
}



.frame_custom2 .row .elementor-col-50:nth-child(1) {

    width: 686px !important
}



.frame_custom2 .row .elementor-col-50:nth-child(2) {

    width: 300px !important
}



.frame_custom2 h3.elementor-heading-title {

    margin-bottom: 38px;

}



.frame_custom2 h4.elementor-heading-title {

    margin-top: 32px;

    margin-bottom: 22px;

}



.frame_custom2 .elementor-text-editor {

    letter-spacing: .04em
}



.frame_custom2 .elementor-icon-list-items {

    background: rgba(230, 236, 189, .75);

    border-radius: 20px;

    padding: 46px 30px 60px 60px !important;

}



.frame_custom2 .elementor-image img {

    border-radius: 30px;

}



.frame_custom2.type-2 {

    background-position: left bottom;

}



.frame_custom2.type-2 .elementor-icon-list-items {

    background: #ECF1CE;

}



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

    .frame_custom2.type-2 .row .elementor-col-50:nth-child(1) {

        order: 2;

    }



    .frame_custom2.type-2 .row .elementor-col-50:nth-child(2) {

        order: 1;

    }

}



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

    .frame_custom2 .elementor-icon-list-items {

        padding: 30px 40px !important;

    }

}



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

    .frame_custom2 .row .elementor-row {

        flex-wrap: wrap;

        row-gap: 30px;

    }



    .frame_custom2 .row .elementor-col-50:nth-child(1) {

        order: 2;

        width: 100% !important
    }



    .frame_custom2 .row .elementor-col-50:nth-child(2) {

        order: 1;

        width: 100% !important
    }



    .frame_custom2 h3.elementor-heading-title {

        margin-bottom: 25px;

    }



    .frame_custom2 h4.elementor-heading-title {

        margin-top: 15px;

        margin-bottom: 25px;

    }



    .frame_custom2 .elementor-icon-list-items {

        padding: 20px 25px !important;

    }

}





/* Frame Photo */

.frame_photo .elementor-row {

    justify-content: space-between;

}



.frame_photo .elementor-row .elementor-col-33 {

    width: calc((340/1080)*100%) !important;

}



.frame_photo div.elementor-heading-title {

    font-family: "Shippori Mincho B1", serif;

    color: #92A415;

    margin: 24px 0 4px;

    font-size: 24px;

    line-height: calc(40/24);

    font-weight: bold;

    letter-spacing: 0.1em;

}



.frame_photo .elementor-text-editor {

    letter-spacing: 0.05em;

}



.frame_photo .elementor-text-editor * {

    letter-spacing: 0.05em;

}



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

    .frame_photo div.elementor-heading-title {

        font-size: 2.105263157vw;

    }

}



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

    .frame_photo .elementor-row {

        row-gap: 30px;

    }



    .frame_photo .elementor-row .elementor-col-33 {

        width: 100% !important;

    }



    .frame_photo div.elementor-heading-title {

        margin: 15px 0 4px;

        font-size: 21px;

    }

}





/* Frame A1 */

.frame_A1 {

    background: #F0F5EF;

    border-radius: 20px;

    padding: 42px 69px 52px 62px;

}



.frame_A1 .elementor-row {

    justify-content: space-between;

    flex-wrap: nowrap;

    gap: 20px;

}



.frame_A1 .elementor-row .elementor-col-50:nth-child(1) {

    width: 390px !important;

}



.frame_A1 .elementor-row .elementor-col-50:nth-child(2) {

    width: 523px !important;

}



.frame_A1 .elementor-row .elementor-col-50:nth-child(2) img {

    border-radius: 70px;

}



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

    .frame_A1 {

        padding: 30px 40px;

    }

}



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

    .frame_A1 {

        padding: 20px 20px 30px;

    }



    .frame_A1 .elementor-row {

        flex-wrap: wrap;

    }



    .frame_A1 .elementor-row .elementor-col-50:nth-child(1) {

        width: 100% !important;

        order: 2;

    }



    .frame_A1 .elementor-row .elementor-col-50:nth-child(2) {

        width: 100% !important;

        order: 1;

    }



    .frame_A1 .elementor-row .elementor-col-50:nth-child(2) img {

        border-radius: 20px;

    }

}



/* frame B1*/

.frame_B1 {

    border: 2px solid #43937C;

    border-radius: 20px;

    padding: 61px 20px 0 20px;

    overflow: hidden;

}



.frame_B1 .elementor-row {

    flex-wrap: nowrap;

    justify-content: space-between;

    max-width: 910px;

    margin: 0 auto;

}



.frame_B1 .elementor-row .elementor-col-50:nth-child(1) {

    position: relative;

    width: 390px !important;

}



.frame_B1 .elementor-row .elementor-col-50:nth-child(1)::before {

    content: '';

    position: absolute;

    background: url('../img/child/frame_B1_deco1.png') no-repeat;

    background-size: 100%;

    width: 190px;

    height: 479px;

    top: -16px;

    right: 0;

    z-index: 1;

}



.frame_B1 .elementor-row .elementor-col-50:nth-child(1)::after {

    content: '';

    position: absolute;

    background: url('../img/child/frame_B1_deco2.png') no-repeat;

    background-size: 100%;

    width: 479px;

    height: 191px;

    bottom: 0;

    right: 20px;

    z-index: 1;

}



.frame_B1 .elementor-row .elementor-col-50:nth-child(2) {

    position: relative;

    z-index: 2;

    width: 538px !important;

    margin: 2px 0 0 -8px;

}



.frame_B1 .elementor-image img {

    border-radius: 34px;

}



.frame_B1 .elementor-icon-list-items {

    padding-bottom: 20px !important;

}



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

    .frame_B1 {

        padding: 30px 20px;

    }



    .frame_B1 .elementor-row {

        flex-wrap: wrap;

        gap: 30px;

    }



    .frame_B1 .elementor-row .elementor-col-50:nth-child(1) {

        width: 100% !important;

    }



    .frame_B1 .elementor-row .elementor-col-50:nth-child(1)::before {

        background: url('../img/child/frame_B1_deco1.png') no-repeat right bottom/auto 100%;

        width: auto;

        height: auto;

        top: -10px;

        bottom: 0;

        left: 0;

        right: 0;

        z-index: 1;

    }



    .frame_B1 .elementor-row .elementor-col-50:nth-child(1)::after {

        background: url('../img/child/frame_B1_deco2.png') no-repeat left bottom/100%;

        width: auto;

        height: auto;

        bottom: 0;

        top: 0;

        left: -20px;

        right: 0;

        z-index: 1;

    }



    .frame_B1 .elementor-row .elementor-col-50:nth-child(2) {

        width: 100% !important;

        margin: 0;

    }



    .frame_B1 .elementor-image img {

        border-radius: 20px;

    }



    .frame_B1 .elementor-icon-list-items {

        padding-bottom: 0 !important;

    }

}





/*--------------------------------------

	table_B

--------------------------------------*/

.table_b {

    border-bottom: none
}



.table_b dl {

    display: flex;

}



.table_b dl>* {

    padding: 9px 16px 9px;

    color: #22201E;

    width: 50%;

    line-height: 28px;

    letter-spacing: .05em
}



.table_b dl dt {

    background: #92A415;

    border: 1px solid #CBCAC9;
    color: #FFF;

    border-bottom: none;

    border-right: none;
    width: 150px;

}



.table_b dl dd {

    border: 1px solid #cbcac9;

    border-bottom: none;
    width: calc(100% - 150px);
}



.table_b dl:last-child dt {

    border-bottom: 1px solid #CBCAC9;

}



.table_b dl:last-child dd {

    border-bottom: 1px solid #cbcac9;

}



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

    .table_b dl>* {

        padding: 5px 12px;

        font-size: 12px;

        line-height: 24px;

    }
    .table_b dl dt {
        width: 100px;
    }
    .table_b dl dd {
        width: calc(100% - 100px);
    }

}



/* Flow I */

.flow_I {

    position: relative;

    padding: 100px 0
}



.flow_I::before {

    content: "";

    position: absolute;

    background: rgba(247, 250, 228, .52);

    top: 0;

    right: calc(-50vw + 50%);

    left: calc(-50vw + 50%);

    bottom: 0;

    z-index: -1
}



.flow_I .item {

    position: relative;

    z-index: 1;

    display: flex;

    justify-content: space-between;

    padding-left: 146px;

}



.flow_I .item::before {

    content: "";

    position: absolute;

    background: #fff;

    top: 0;

    left: 60px;

    right: 0;

    bottom: 0;

    border-radius: 10px;

    z-index: -1
}



.flow_I .item .step {

    position: absolute;

    top: 50%;

    left: 0;

    transform: translateY(-50%);

    font-family: "Cormorant", serif;

    box-shadow: 0px 3px 6px rgba(0, 0, 0, .16);

    background: #B5C73B;

    color: #fff;

    border-radius: 50%;

    max-width: 120px;

    width: 100%;

    height: 120px
}



.flow_I .item .step span {

    display: block;

    text-align: center;

    line-height: 1;

    font-weight: bold;

    letter-spacing: 0
}



.flow_I .item .step span.en {

    padding-top: 14px;

    margin-bottom: -10px;

    font-size: 40px
}



.flow_I .item .step span.num {

    font-size: 60px
}



.flow_I .item .group-txt {

    width: 490px;

    padding: 50px 0 44px 7px;

    min-height: 274px;

}



.flow_I .item .group-txt h3 {

    font-family: "Shippori Mincho B1", serif;

    color: #B5C73B;

    font-size: 24px;

    line-height: 1.6666666667;

    font-weight: bold;

    letter-spacing: .1em
}



.flow_I .item .group-txt .txt {

    margin-top: 13px;

    letter-spacing: .05em
}



.flow_I .item .photo {

    width: 410px
}



.flow_I .item .photo img {

    border-radius: 0 10px 10px 0
}



.flow_I .item+.item {

    margin-top: 58px
}



.flow_I .item:not(:last-child):after {

    content: "";

    position: absolute;

    background: rgb(146, 164, 21);

    background: linear-gradient(13deg, rgba(146, 164, 21, 1) 0%, rgba(181, 199, 59, 1) 100%);

    bottom: 0;

    left: 50%;

    transform: translateX(-50%);

    width: 68px;

    height: 37px;

    -webkit-clip-path: polygon(50% 100%, 0 0, 100% 0);

    clip-path: polygon(50% 100%, 0 0, 100% 0);

    bottom: -37px
}



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

    .flow_I .item .group-txt h3 {

        font-size: 2.8vw
    }

}



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

    .flow_I .item {

        align-items: center;

    }

}



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

    .flow_I {

        padding: 50px 0
    }



    .flow_I .item {

        flex-direction: column;

        row-gap: 20px;

        padding: 0 20px 30px
    }



    .flow_I .item::before {

        top: 60px;

        left: 0
    }



    .flow_I .item .step {

        position: unset;

        transform: unset;

        order: 1;

        max-width: 100px;

        height: 100px;
        margin: 0 auto;
    }



    .flow_I .item .step span.en {

        padding-top: 17px;

        font-size: 30px
    }



    .flow_I .item .step span.num {

        font-size: 50px
    }



    .flow_I .item .group-txt {

        order: 3;

        width: auto;

        min-height: auto;

        padding: 0
    }



    .flow_I .item .group-txt h3 {

        font-size: 21px
    }



    .flow_I .item .photo {

        width: auto;

        order: 2
    }



    .flow_I .item .photo img {

        border-radius: 10px
    }



    .flow_I .item+.item {

        margin-top: 58px
    }



    .flow_I .item:not(:last-child):after {

        content: "";

        position: absolute;

        background: #43937b;

        background: linear-gradient(0deg, rgb(67, 147, 123) 0%, rgb(89, 183, 163) 100%);

        bottom: 0;

        left: 50%;

        transform: translateX(-50%);

        width: 68px;

        height: 37px;

        -webkit-clip-path: polygon(50% 100%, 0 0, 100% 0);

        clip-path: polygon(50% 100%, 0 0, 100% 0);

        bottom: -37px
    }

}





/* Frame QA */

.frame_QA {

    color: #454545
}



.frame_QA dl dt,

.frame_QA dl dd {

    display: flex
}



.frame_QA dl dt span,

.frame_QA dl dd span {

    display: block
}



.frame_QA dl dt span:nth-child(1),

.frame_QA dl dd span:nth-child(1) {

    font-family: "Cormorant", serif;

    text-align: center;

    width: 56px;

    height: 56px;

    border-radius: 50%;

    line-height: 50px;

    font-weight: bold;

    font-size: 31px;

    letter-spacing: 0
}



.frame_QA dl dt span:nth-child(2),

.frame_QA dl dd span:nth-child(2) {

    flex: 1
}



.frame_QA dl dt span:nth-child(1) {

    background: #92A415;

    color: #fff
}



.frame_QA dl dt span:nth-child(2) {

    font-family: "Shippori Mincho B1", serif;

    margin: 12px 0 0 14px;

    font-size: 24px;

    font-weight: bold;

    line-height: 1.6666666667;

    letter-spacing: .1em
}



.frame_QA dl dd {

    margin-top: 21px
}



.frame_QA dl dd span:nth-child(1) {

    background: #CBCAC9;

    color: #22201e
}



.frame_QA dl dd span:nth-child(2) {

    margin: -3px 0 0 13px;

    letter-spacing: .05em
}



.frame_QA dl+dl {

    margin-top: 55px
}



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



    .frame_QA dl dt span:nth-child(1),

    .frame_QA dl dd span:nth-child(1) {

        width: 50px;

        height: 50px;

        line-height: 44px;

        font-size: 28px
    }



    .frame_QA dl dt span:nth-child(2) {

        margin: 8px 0 0 10px;

        font-size: 21px
    }



    .frame_QA dl dd {

        margin-top: 15px
    }



    .frame_QA dl dd span:nth-child(2) {

        margin: 5px 0 0 10px;

        letter-spacing: .05em
    }



    .frame_QA dl+dl {

        margin-top: 30px
    }

}



/* Photo left */

.photo-left .elementor-row {

    justify-content: space-between;

}



.photo-left .elementor-row .elementor-col-66 {

    width: calc((685/1080)*100%) !important;

}



.photo-left .elementor-row .elementor-col-33 {

    width: calc((350/1080)*100%) !important;

}



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

    .photo-left .elementor-row {

        justify-content: space-between;

        row-gap: 20px;

    }



    .photo-left .elementor-row .elementor-col-66 {

        order: 2;

        width: 100% !important;

    }



    .photo-left .elementor-row .elementor-col-33 {

        order: 1;

        width: 100% !important;

    }

}



/* Column 7 - 3 */

.col-7-3 .elementor-row {

    justify-content: space-between;

}



.col-7-3 .elementor-row .elementor-col-66 {

    width: 65% !important;

}



.col-7-3 .elementor-row .elementor-col-33 {

    width: 32% !important;

}



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

    .col-7-3 .elementor-row {

        row-gap: 20px;

    }



    .col-7-3 .elementor-row .elementor-col-66 {
        order: 2;
        width: 100% !important;

    }



    .col-7-3 .elementor-row .elementor-col-33 {
        order: 1;
        width: 100% !important;

    }

}





/* Column 3 - 3 - 3 */

.col-3-3-3 .elementor-row {

    justify-content: space-between;

}



.col-3-3-3 .elementor-row .elementor-col-33 {

    width: calc((340/1080)*100%) !important;

}



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

    .col-3-3-3 .elementor-row {

        row-gap: 30px;

    }



    .col-3-3-3 .elementor-row .elementor-col-33 {

        width: 100% !important;

    }

}