﻿/*--------link_font--------*/
@font-face {
    font-family: 'hiragino_min';
    font-style: normal;
    font-weight: 400;
    src: url('../Dup/img/hiragino_min_r.woff') format('woff'),
        url('../Dup/img/hiragino_min_r.eot')  format('eot');
    font-display: swap;
}
@font-face {
    font-family: 'hiragino_min';
    font-style: normal;
    font-weight: 700;
    src: url('../Dup/img/hiragino_min_b.woff') format('woff'),
        url('../Dup/img/hiragino_min_b.eot')  format('eot');
    font-display: swap;
}
@font-face {
    font-family: 'trajan';
    font-style: normal;
    font-weight: 400;
    src: url('../Dup/img/trajan.woff') format('woff'),
        url('../Dup/img/trajan.eot')  format('eot');
    font-display: swap;
}

.linkStyle{color: #333333; text-decoration: underline;}


/*--------all_page--------*/
.fa-calendar-check-o:before {
    content: "\f274";
}
.fa-mobile-alt:before {
    content: "\f3cd";
}
#nav_menu .mg_b-50px h2,#nav_menu .mg_b-50px .nav_menu_more:last-of-type{display:none;}
.nav_menu_more:first-of-type a .icon:before {
    content: "\f879";
}

#pc_nav li:last-of-type{
    padding-right: 160px;
}
main .num{z-index:3!important;}

/*
#contents1 .con_img{box-shadow: #e9e9e9 -50px 50px 40px -7px;}
#contents2 .con_img{box-shadow: #e9e9e9 50px 50px 40px -7px;}
*/
.con_img:before{
    position: absolute;
    content: '';
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    box-shadow: inset 0px 0px 10px 5px #fff;
    z-index: +1;
}

#intro_wrap.bg_white {
    background-color: rgba(255, 255, 255, .6);
    box-shadow: rgba(17, 12, 46, 0.15) 0px 48px 100px 0px;
}
#contents3_wrap:after {
    background-color: rgba(173, 173, 173, .5)!important;
}
#contents3 .con_box {
  position: relative;
  background-color: rgba(255,255,255,0.75);
}
#contents3_wrap:before {
    background-attachment: fixed;
}

#logo2 a{    max-width: 245px;}
/*
#top_cms .cms_1-a .cate_box{
    background-color: rgba(245, 241, 234, .75);
}
*/
#info_contact .con_img:before{box-shadow: inset 0px 0px 10px 5px #ffffff;}


@media screen and (min-width: 1281px){
#header #nav_menu .add_contact{
    top: 28px;
    right: 128px;
}
}
@media screen and (min-width: 769px) and (max-width: 1280px){
    header .add_contact{
    top: 35px;
    right: 128px;
    }
    header.scr_header .add_contact {
    top: 25px;
    }
    
}
@media screen and (max-width: 768px){    
   #header #nav_menu .add_contact {
    top: 30px;
    right: 100px;
    transition: all 0.3s;
}
}
@media screen and (max-width: 667px){
   #header #nav_menu .add_contact {
    top: 17px;
    right: 67px;
}
#header #nav_menu .add_contact a {
    padding: 5px 6px;
    font-size: 4.1vw;
    letter-spacing: 0.1em;
}
.scr_header #header #nav_menu .add_contact {
    top: 18px;
}
}

#copyright{font-family: serif;}

/*--------animation--------*/
.txt_anim4 {
	overflow: hidden;
	color: #424242;
}
.txt_anim4 span.d_inline_b {
	overflow: hidden;
	height: 1em;
	line-height: 1;
}
.txt_anim4 span:not(.d_inline_b) {
	display: inline-block;
	line-height: 1;
	transition: 0.8s;
	transition-property: transform;
	transition-timing-function: cubic-bezier(0,.64,.29,.99);
	transform-origin: top;
	transform: translateY(1em) rotate(10deg);
}
.txt_anim4 span.start {
	transform: translateY(-0.15em);
}

.overlay .bg_color1 {
    background-color: #cfbd9f;
}

/*--------subpage--------*/
.page .back1:before {
    z-index: -1;
}
.page section .con_box.bg_white {
    background-color: rgba(255, 255, 255, .75);
}
#page_title{
    background-image: url(./Dup/img/sub.jpg);
    background-repeat: no-repeat;
    background-position: 50% 50%;
}
#page_title .page_title_box.bg_color1 {
     background-color: rgba(255,255,255,0); 
}
.cate_title{
    position: relative;
    border-bottom: 1px solid rgba(187, 68, 148, .4);
    padding: 10px 0px 5px 20px;
   
}
.cate_title::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0px;
    right: 0px;
    box-shadow: 0px 20px 30px rgba(197, 197, 197, 1);
    z-index: -1;
}

.box_title1 {
     position: relative;
     padding-bottom: 0;
     margin-bottom: 35px;
}
 .box_title1::after {
     position: absolute;
     bottom: -5px;
     left:0;
     content: '';
     width: 10%;
     height: 1px;
     background-color: #dda1c9;
}

#cms_2-c #cate0 .cate_box{border-left:none;background-color: rgba(0,0,0,0);}
#cms_2-c #cate0 .box_txt1,
#cms_2-c #cate0 .box_txt2{padding-left:130px;}

#cms_2-c #cate0 .box_wrap{
    position: relative;
    padding-left: 30px;
}
#cms_2-c #cate0 .box_wrap:before{
    content: "";
    display: inline-block;
    height: calc(100% - 65px);
    border-left: 1px solid #bb4494;
    position: absolute;
    top: 60px;
    left: 45px;
}

#cms_2-c #cate0 .box_txt1{position:relative;}
#cms_2-c #cate0 .box_txt1::before,
#cms_2-c #cate0 .box_txt1::after {
	content: "";
	display: block;
	position: absolute;
}

#cms_2-c #cate0 {counter-reset: number 0;}
#cms_2-c #cate0 .box_txt1::before {
    counter-increment: number 1;
    content: "step." counter(number);
    background-color: #ffffff;
    padding: 8px 10px;
    color: #bb4494;
    font-size: 0.8em;
    display: block;
    width: 90px;
    left: -44px;
    top: -3px;
    font-family: 'trajan',serif;
}
#cms_2-c #cate0 .box_txt1::after {
    width: 65px;
    border-bottom: 1px dashed #dda0c9;
    position: absolute;
    top: 21px;
    left: 49px;
}

#cms_2-c #cate0 .box_description2{
    position: relative;
    border-left: none;
    background-color: rgba(255, 255, 255, 0);
}
#cms_2-c #cate0 .box_description2 span{
position: absolute;
    display: inline-block;
    width: 90px;
    top: -23px;
    left: -50px;
}


#page4 .box_title1 {
     margin-bottom: 0px;
}
#page4  .box_title1::after {
     display: none;
}
#page7  .box_title1::after {display:none;}
#page8 .tel_box{
    position: relative;
    overflow: hidden;
    padding: 20px 20px 15px 20px;
}
#page8 .tel_box > a:before{
    content:"";
    position: absolute;
    width:100vw;
    height:100vh;
    -moz-transform: translateX(-50%) translateY(-50%);
    -webkit-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
    left:50%;
    top:50%;
}
@media screen and (max-width: 1200px){
    #page8 .tel_box p{
        display: block;
        padding-right: 0px;
        margin-right: 0px;
        border-right: none;
        
    }
}

@media screen and (max-width: 667px){  
#page8 .tel_box a{
    font-size: 5vw;
    letter-spacing: 2px;    
}
}
#page10 .more_btn {
    text-transform: capitalize;
}
/*--------mobile_tb--------*/
@media screen and (max-width: 768px){
    #fakeloader{
    background-image: url(./Dup/img/back_sp.jpg);
}

#logo{opacity:0;}
header.scr_header #logo {opacity: 1;}
#page_title .page_title_box { width: 85%;}
 /*   
#cms_2-c #cate0 .flex_order2_tb{
    width: 78%!important;
    margin-left: auto;
}
*/
#cms_2-c #cate0 .box_description1{padding-left: 150px;}
.cms_6-c .cate_box {
    width: 100%;
    margin-bottom: 7%;
}
/*#footer{padding-bottom: 85px;}*/
}

/*--------mobile_sp--------*/
@media screen and (max-width: 667px){

#main_img .square_box a{max-width: 240px;}

#logo2 a {
    max-width: 150px;
}
#page_title .page_title_box h2{font-size:5.2vw;}
.cate_title {
    padding: 10px 0px 5px 10px;
}
#cms_2-c #cate0 .box_description2 {
    padding: 0;
}
#cms_2-c #cate0 .box_description2 span {
    width: 70px;
}
#cms_2-c #cate0 .box_wrap{
    padding-left: 23px;
}
#cms_2-c #cate0 .box_wrap:before {
    left: 22px;
}
#cms_2-c #cate0 .box_txt1::before, #cms_2-c #cate0 .box_txt1::after {
    top: 58px;
}
#cms_2-c #cate0 .box_txt1::before {
    left: -26px;
    width: 70px;
    font-size: 3.7vw;
    padding: 5px 0px;
}
#cms_2-c #cate0 .box_txt1::after {
    width: 24px;
    display: none;
}
#cms_2-c #cate0 .box_txt1, #cms_2-c #cate0 .box_txt2 {
    padding-left: 51px;
}
#cms_2-c #cate0 .box_txt1{
    padding-top: 60px;
}
#cms_2-c #cate0 .flex_order2_tb {
    width: 87%!important;
}
#cms_2-c #cate0 .box_description1 {
    padding-left: 50px;
}
#page4 .cate_box:not(:first-of-type) .box_title,#page4 .cate_box:not(:first-of-type) .box_txt1,#page4 .cate_box:not(:first-of-type) .box_txt1_add{
   font-size: 3.3vw;
}
}


/*--------------------------------------------
IE
--------------------------------------------*/
@media all and (-ms-high-contrast:none){
.cms_1-a figure img{width:100%!important;height:auto!important;}
.pager li a{padding:12px 10px 8px 10px;}
}


