@charset "UTF-8";
/*
 * page.css
 *
 */

.kotei-page {
    z-index: 100;
    position: relative;
}
.page-main-div {
    position: relative;
    height: calc(70vh - 80px);
    margin-bottom: 150px;
}
.page-main-div h3 {
    position: absolute;
    bottom: 100px;
    z-index: 10;
    left: 0px;
    text-align: left;
    font-size: 42px;
}
.page-main-div p {
    position:absolute;
    right: 0px;
    top: 0px;
    width: 80%;
}
.page-main-div img{
    object-fit: cover;
    height: calc(70vh - 80px);
}
.page-main-div .h3-ja{
    font-size: 100px;
    text-shadow:1px 1px 0 #FFF, -1px -1px 0 #FFF,
        -1px 1px 0 #FFF, 1px -1px 0 #FFF,
        0px 1px 0 #FFF,  0-1px 0 #FFF,
        -1px 0 0 #FFF, 1px 0 0 #FFF;
}
.page-main-div .h3-ja.tokutei-page {
    font-size: 70px;
}
.page-main-div .h3-en {
    font-size: 50px;
}
.page-main-div h3::before {
    width: 360px;
}

.important-ul h4 {
    font-size: 21px;
    font-weight: bold;
}
.important-div {
    display: flex;
    justify-content: space-between;
    margin: 50px auto;
}
.important-div div {
    width: 45%;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
    border-radius:10px;
    padding: 30px 0px 20px 40px;
    background-color: #fff;
}
.important-div>p {
    height: 300px;
    width: 45%;
    font-size: 21px;
    font-weight: bold;
}
.important-div img {
    height: 100%;
    border-radius: 10px;
    object-fit: cover;
}
.important-div>div>p {
    font-size: 21px;
    font-weight: bold;
    line-height: 1em;
    margin-bottom: 20px;
    padding-left: 45px;
}
.important-div>div>p>span {
    font-size: 14px;
    font-weight: normal;
}
.important-div>div>p:before {
    font-family: "Font Awesome 5 Free", "Font Awesome", "font awesome", "fontawesome";
    font-weight: 900;
    color: #FFF;
    content: "\f02d";
    padding-right: 5px;
    border-radius: 50px;
    background-color: #0031FF;
    padding: 10px;
    left: 40px;
    position: absolute;
}
.important-div li {
    font-weight: bold;
    margin-bottom: 10px;
}
.important-div li::before {
    font-family: "Font Awesome 5 Free", "Font Awesome", "font awesome", "fontawesome";
    font-weight: 900;
    color: #FF0000;
    content: "\f058";
    margin-right: 10px;
}
.important-div li>span {
    font-weight: normal;
    font-size: 14px;
    margin-left: 28px;
}

.kotei-page h5 {
    font-size: 30px;
    font-weight: bold;
    padding: 20px 0px;
    display: block;
    text-align: center;
    margin-bottom: 10px;
    background-color: unset;
    color: #000;
}
.lisk-ul {
    display:flex;
    margin-bottom: 100px;
}
.lisk-ul li {
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
    border-radius: 10px;
    padding: 10px;
    margin: 0px 10px;
    width: calc(25% - 30px);
    background-color: #fff;
}
.lisk-ul li h6 {
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    margin-bottom: 10px;
}
.lisk-ul li h6::before {
    text-align: center;
    font-family: "Font Awesome 5 Free", "Font Awesome", "font awesome", "fontawesome";
    font-weight: 900;
    color: yellow;
    content: "\f071";
    display: block;
    background-color: #000;
    border-radius: 8px;
    padding: 2px 7px;
    width: fit-content;
    margin: 10px auto 5px;
    font-size: 34px;
}
.lisk-ul li p {
    font-size: 12px;
    margin-bottom: 20px;
}

.service-shosai-ul ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-bottom: 50px;
}
.service-shosai-ul h4 {
    font-size: 24px;
    background-color: #147fc1;
    width: max-content;
    margin: 10px auto;
    border-radius: 60px;
    padding: 5px 60px;
    color: #fff;
    font-weight: bold;
}
.service-shosai-ul ul li {
    width: 31%;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
    border-radius:10px;
    margin: 20px 38px 30px 0px;
}
.service-shosai-ul ul li:nth-of-type(3n) {
    margin-right: 0px;
}
.kotei-page .service-shosai-ul img {
    border-radius:10px 10px 0px 0px;
}
.kotei-page .service-shosai-ul h5 {
    font-size: 21px;
    font-weight: bold;
    padding: 20px 20px 5px;
    display: block;
    text-align: left;
    margin-bottom: 0px;
    background-color: #FFF;
    color: #000;
}
.kotei-page .service-shosai-ul p {
    font-size: 14px;
    padding: 0px 20px 30px 20px;
}
.flow-ul {
    margin: 50px 0px;
}
.flow-ul li {
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin-bottom: 50px;
    position: relative;
}
.flow-ul li::after {
    width: 0.25rem;
    height: 3rem;
    background-color:#FF0004;
    content: "";
    position: absolute;
    bottom: -50px;
}
.flow-ul li:last-of-type::after {
    display: none;
}
.flow-ul li div {
    width: 40%;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
    border-radius:10px;
    margin: 0px;
    padding: 20px 30px 30px;
}
.flow-ul li>p {
    width: 45%;
}
.flow-ul li div h4>span:nth-of-type(1) {
    padding: 7px 12px;
    border-radius: 59px;
    background-color: #FF0000;
    color: #FFF;
    display: inline-block;
    margin-right: 10px;
}
.flow-ul li div a.phone-only {
    display: block;
}
.flow-ul li div h4 {
    font-size: 24px;
    font-weight: bold;
    padding-bottom: 20px;
}
.flow-ul li div .flow-time {
    font-size: 14px;
    padding-left: 64px;
}
.flow-ul li div .flow-time::before {
    font-family: "Font Awesome 5 Free", "Font Awesome", "font awesome", "fontawesome";
    font-weight: 900;
    color: #FF0000;
    content: "\f017";
    padding-right: 6px;
}
.flow-ul li div p:nth-of-type(2){
    margin-top: 24px;
}
.flow-ul li div .contact-how {
    font-size: 20px;
}
.flow-ul li div .contact-span {
    font-size: 28px;
    padding: 0px 0px 0px 20px;
    line-height: 1em;
}
.flow-ul li div .contact-span img {
    width: 300px;
}
.flow-ul li div .contact-time{
    padding-left: 20px;
    padding-bottom: 10px;
    display: inline-block;
}

.price-ul {
    display: flex;
    justify-content: space-around;
    margin: 30px 0px 30px;
}
.price-ul>li {
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
    border-radius: 10px;
    padding: 20px 40px;
    width: 25%;
    border: 1px solid #0084FF;
}
.price-ul>li:nth-of-type(2) {border: 1px solid #FF4C00;}
.price-ul>li:nth-of-type(3) {border: 1px solid #12A700;}
.price-ul>li h4 {
    text-align: center;
    font-size: 28px;
    font-weight: bold;
    color: #0084FF;
}
.price-ul>li h4 span {
    font-size: 18px;
    display: block;
    font-weight: bold;
}
.price-ul>li:nth-of-type(2) h4 {color: #FF4C00;}
.price-ul>li:nth-of-type(3) h4 {color: #12A700;}
.price-ul>li p:nth-of-type(1) {
    text-align: center;
    font-size: 14px;
}
.kotei-page .price-ul h5 {
    padding: 20px 0px 0px;
    margin-bottom: 0px;
}
.kotei-page .price-ul h5 .price-rei {
    display: block;
    font-size: 12px;
}
.price-ul>li p:nth-of-type(2) {
    text-align: center;
    font-size: 14px;
}
.price-ul>li ul {
    margin: 30px 0px 0px;
}
.price-ul>li li {
    display: flex;
}
.price-ul>li li::before {
    font-family: "Font Awesome 5 Free", "Font Awesome", "font awesome", "fontawesome";
    font-weight: 900;
    color: #12A700;
    content: "\f058";
    padding-right: 6px;    
}
.option-ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.option-ul li {
    width: 45%;
    background-color: #F3F3F3;
    padding: 20px;
    border-radius: 10px;
    position: relative;
    margin-bottom: 20px;
}
.option-ul li h4 {
    font-size: 21px;
    font-weight: bold;
}
.option-ul li p:nth-of-type(1) {
    position: absolute;
    top: 20px;
    right: 20px;
    color: #FF7E00;
    font-weight: bold;
}
.option-ul li p:nth-of-type(1) .option-price-kome {
    display: block;
    font-size: 12px;
}
.option-ul li p:nth-of-type(2) {
    font-size: 16px;
    padding: 20px 0px;
    color: #575757;
}

.question-dl dt {
    background: #F8F8F8;
    font-size: 21px;
    font-weight: bold;
    cursor: pointer;
    position: relative;
    padding: 15px 58px 15px 47px;
    margin-top: 23px;
    border-radius: 10px 10px 0px 0px;
}
.question-dl dd {
    position: relative;
    background: #F8F8F8;
    display: none;
    line-height: 1.7em;
    letter-spacing: .06em;
    padding: 0px 69px 30px 48px;
    border-radius: 0px 0px 10px 10px;
}
.question-dl dt.open + dd {
    display: block;
}
.question-dl dt:before, .question-dl dd:before {
    content: 'Q.';
    font-family: "Source Sans 3", sans-serif;
    color: #08584c;
    font-size: 24px;
    letter-spacing: .02em;
    position: absolute;
    font-weight: 500;
    left: 13px;
    top: 6px;
}
.question-dl dd:before {
    content: 'A.';
    color: #c44a4a;
}
.question-dl dt:after{
    content: "";
    display: block;
    width: 15px;
    height: 15px;
    border-top: #000 2px solid;
    border-right: #000 2px solid;
    -webkit-transform: rotate(135deg);
    -ms-transform: rotate(135deg);
    transform: rotate(135deg);
    position: absolute;
    right: 32px;
    top: 0;
    bottom: 15%;
    margin: auto;
}
.question-dl dt.open:after {
  content:"";
  display:block;
  width:15px;
  height:15px;
  border-top: #000 2px solid;
  border-right: #000 2px solid;
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
  position:absolute;
  right: 32px;
  top: 7%;
  bottom: 0;
  margin: auto;
}

/* company */
.motto {
    display: flex;
    margin-bottom: 100px;
}
.motto h4 {
    width: 45%;
    font-size: 60px;
    font-weight: bold;
    color: #147fc1;
    line-height: 1.4em;
}
.motto.company-page-motto h4 {
    font-size: 32px;
}
.motto p {
    width: 54%;
    font-size: 14px;
    line-height: 2em;
    text-align: justify;
    color: #147fc1;
}
.motto p span {
    padding-top: 21px;
    font-size: 10px;
    display: block;
    line-height: 1.5em;
}
.hoshin h4 {
    font-size: 28px;
    font-weight: bold;
    color: #147fc1;
    line-height: 1.4em;
    padding-bottom: 10px;
}
.hoshin h4::before {
    content: "●";
}
.hoshin ul {
    padding: 0px 0px 50px 20px;
}
.hoshin ul li {
    font-size: 14px;
    line-height: 2.5em;
    padding-left: 20px;
    color: #6C6C6C;
}
.hoshin ul li::before {
    content: "・";
    position: relative;
    left: -18px;
}
.hoshin ul li span {
    font-size: 16px;
    font-weight: bold;
    margin-left: -13px;
    display: inline-block;
}
.creus {
    background-color: #F9F9F9;
    padding: 50px;
    margin: 100px;
}
.creus li {
    line-height: 4em;
    font-size: 21px;
    opacity: 0;
    transform: translateX(0);
    transition: all 2s ease;
}
.creus li.show {
    opacity: 1;
    transform: translateX(50px);
}

.creus li:nth-of-type(2) {padding-left: 30px;}
.creus li:nth-of-type(3) {padding-left: 60px;}
.creus li:nth-of-type(4) {padding-left: 90px;}
.creus li:nth-of-type(5) {padding-left: 120px;}
.creus li>span>span {
    font-size: 100px;
    color: #147fc1;
    font-family: "Momo Trust Display", sans-serif;
}
.creus li:nth-of-type(4)>span>span,
.creus li:nth-of-type(5)>span>span{
    color: #afcd14;
}
.creus li>span {
    padding-right: 50px;
    font-size: 60px;
    color: #969696;
    font-family: "Momo Trust Display", sans-serif;
}
/* 順番にずらしてアニメーション */
.creus li:nth-child(1) { animation-delay: 0s; }
.creus li:nth-child(2) { animation-delay: 1s; }
.creus li:nth-child(3) { animation-delay: 2s; }
.creus li:nth-child(4) { animation-delay: 3s; }
.creus li:nth-child(5) { animation-delay: 4s; }

@keyframes slideInRight {
  0% {
    opacity: 0;
    transform: translateX(50px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}

.aisatsu {
    display: flex;
}
.aisatsu p {
    width: 50%;
    line-height: 3em;
    font-size: 17px;
    color: #6F6F6F;
}
.aisatsu p span:nth-of-type(1) {
    font-size: 18px;
    padding-right: 20px;
    line-height: 10em;
}
.aisatsu p span:nth-of-type(2) {
    font-size: 21px;
    font-weight: bold;
}
.gaiyo-dl {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 100px;
}
.gaiyo-dl dt, .gaiyo-dl dd {
    width: 20%;
    border-bottom: 1px solid #ECECEC;
    padding: 20px 0px;
}
.gaiyo-dl dt {
    font-weight: bold;
    color: #147fc1;
}
.gaiyo-dl dd {
    width: 80%;
}

.features-ul {
    margin: 100px 0px;
}
.features-ul li {
    display: flex;
    flex-wrap: wrap;
    margin: 0px 0px 50px;
}
.features-ul li h4 span {
    font-family: "Playfair Display", serif;
    font-optical-sizing: auto;
    font-weight: 900;
    font-style: italic;
    font-size: 100px;
    color: #155aa8;
}
.features-ul h4 {
    font-size: 40px;
    font-weight: bold;
    line-height: 1.4;
    width: 100%;
}
.features-ul li p {
    padding: 0px 0px 0px 50px;
    width: 45%;
    font-size: 19px;
    display: block;
    line-height: 2em;
    color: #404040;
    text-indent: 1em;
}
.environment-tb {
    width: 100%;
}
.environment-tb th {
    background-color: #ddd;
    border: 1px solid #333;
    padding: 10px;
}
.environment-tb td {
    border: 1px solid #333;
    padding: 10px;
}
.environment-tb caption {
    text-align: center;
    font-size: 21px;
    font-weight: bold;
    padding: 0px 0px 12px;
}
.jisseki {
    width: 60%;
    margin: 0px auto;
}
.kotei-page .jisseki h5 {
    font-weight: bold;
    font-size: 18px;
    text-align: left;
    padding: 20px 0px 0px;
    line-height: 0.3em;
}
.jisseki li {
    margin-bottom: 10px;
}
.jisseki li p {
    padding-left: 20px;
}
.jisseki>li>ul {
    margin-left: 40px;
}
.jisseki>li>ul>li {
    list-style: disc;
}

/*     partner     */
.partner-div h3 {
    margin: 80px 0px 10px;
}
.partner-main {
    font-size: 18px;
    text-align: left;
    font-weight: normal;
    line-height: 4em;
    width: 70%;
    display: block;
    margin: 0px auto;
}
.partner-h4 {
    font-size: 21px;
    font-weight: bold;
    border-bottom: 1px solid #333;
    padding-bottom: 10px;
    margin-bottom: 21px;
}
.partner-ul {
    list-style: disc;
    padding: 0px 0px 30px 40px;
}
.partner-ul:nth-of-type(2) {
    padding: 0px 0px 10px 40px;
}
.partner-chui {
    font-size: 12px;
    padding: 0px 0px 30px 40px;
}
.partner-h6 {
    font-size: 28px;
    display: inline;
    text-align: left;
    color: #147fc1;
    font-weight: bold;
}
.partner-h6:before {
    font-family: "Font Awesome 5 Free", "Font Awesome", "font awesome", "fontawesome";
    font-weight: 900;
    color: #147fc1 ;
    content: "\f00c";
    padding: 10px;
    margin-right: 15px;
}
.partner-merit li {
    margin-bottom: 20px;
}
.partner-merit li p {
    margin-left: 65px;
}
.price-ul.partner-oubo {
    justify-content: center;
}
.price-ul.partner-oubo li {
    margin: 20px;
}
.price-ul.partner-oubo li h4 {
    margin-bottom: 20px;
}
.price-ul.partner-oubo li p {
    text-align: left;
}
.partner-oubo-p {
    font-size: 18px;
    color: red;
    font-weight: bold;
    text-align: center
}
.partner-oubo-pkome {
    font-size: 12px;
    text-align: center;
}
.partner-flow {
    width: 70%;
    margin: 10px auto;
}
.partner-flow li {
    border-bottom: 1px solid #333;
    padding: 20px;
    margin-bottom: 20px;
    position: relative;
}
.partner-flow li h4 {
    font-size: 21px;
    font-weight: bold;
}
.partner-flow li::after {
    content: "";
    position: absolute;
    bottom: -50px;
    left: 50%;
    border: 14px solid transparent;
    border-top: 20px solid #147fc1 ;
    right: 50%;
}
.partner-flow li:nth-of-type(4)::after {
    content: none;
}

/*    otoiawase    */
.contact ul li {
    background-color: #fff;
}
.page-id-10 .bg {
    height: 164vh;
    overflow: clip;
}

/*    privacypolicy    */
.privacypolicy {
	margin:20px 50px;
	padding:20px;
	background:rgba(255, 255, 255, 0.6);
	-webkit-border-radius:5px 5px 5px 5px;
	-moz-border-radius:5px 5px 5px 5px;  
	border-radius:5px 5px 5px 5px;
}
.privacypolicy dt {
	font-size:16px;
	font-weight:bold;
	color:#147fc1;	
}
.privacypolicy dt:nth-of-type(1) {
    margin:50px 0px 0px 0px;
}
.privacypolicy dd {
	margin:10px 10px 50px 10px;
}
.privacypolicy a {
	text-decoration:none;
}
.privacypolicy a:hover {
	color:#147FC1;
}

/*   sitemap    */
.sitemap-div {
    width: 65%;
    margin: 10px auto;
}
.sitemap-div ul {
    margin-left: 20px;
}
.sitemap-div ul li {
    line-height: 2em;
}
.sitemap-div ul li::before {
    font-family: "Font Awesome 5 Free", "Font Awesome", "font awesome", "fontawesome";
    font-weight: 900;
    content: "\f0da";
    padding-right: 10px;
    color: #147FC1;
}
.sitemap-div>ul>li:nth-of-type(2)::before,
.sitemap-div>ul>li:nth-of-type(2)>ul>li::before{
    font-size: 10px;
    content: "\f111";
}
.kotei-page .service-shosai-ul p.bokataishobutsutenken-work-p {
    text-align: center;
    font-size: 10px;
}
.single-page .page-main-div h3 {
    position: relative;
    bottom: 0px;
    z-index: 10;
    left: auto;
    text-align: center;
    font-size: 42px;
}
.single-page .page-main-div {
    height: auto;
    margin-bottom: 20px;
}
.single-page>p {
    padding: 0px 50px 50px;
    line-height: 2em;
}

/* group */
.group-ul {
    display: flex;
    flex-wrap: wrap;
}
.group-ul>li {
    width: calc((100% - 216px) / 3);
    margin: 10px;
    padding: 25px;
    border: 1px solid #ccc;
    border-radius: 5px;
    background-color: #fff;
}
.group-ul>li h4 {
    text-align: center;
    margin-bottom: 15px;
}
.group-ul>li h4 img {
    width: 80%;
    height: auto;
}
.group-ul>li div p {
    font-size: 12px;
    padding: 20px 0px;
}
.group-ul>li div>dl {
    display: grid;
    font-size: 12px;
    border-bottom: 2px solid #fff;
    grid-template-columns: 100px 1fr;
}
.group-ul>li div>dl>dt {
    background-color: #EFEFEF;
    vertical-align: middle;
    height: auto;
    padding: 8px;
    align-items: center;
    display: flex;
}
.group-ul>li div>dl>dd {
    padding: 8px;
    align-items: center;
    display: flex;
}
.group-ul div img {
    width: 100%;
    height: auto;
}
.group-ul>li div>dl>dd .phone-only {
    font-size: 12px;
    font-weight: normal;
}
.group-ul>li div>dl>dd.hp-link {
    position: relative;
    padding-left: 22px;
}
.hp-link::after {
    font-family: "Font Awesome 5 Free", "Font Awesome", "font awesome", "fontawesome";
    font-weight: 900;
    color: #001EFF;
    content: "\f35d";
    left: 5px;
    position: absolute;
}
.group-ul>li div>dl>dd.mukauno-dd {
    display: block;
}
.shisetsu {
    font-weight: bold;
}
.group-ul>li div>dl>dd.mukauno-dd dd {
    padding-bottom: 10px;
}
.group-ul>li div>dl>dd.mukauno-dd dl:nth-of-type(3) dd {
    padding-bottom: 0px;
}