@charset "UTF-8";
/*--------------------
base
---------------------*/
@font-face {
    font-family: 'Noto Sans JP';
    font-style: normal;
    font-weight: 400;
    src: local("Noto Sans CJK JP"),
         url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.woff2) format('woff2'),
         url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.woff) format('woff'),
         url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.otf) format('opentype');
 }
html{
    font-size: 62.5%;
}
body{   
    color:#333333;
    font-family: 'montserrat','Noto Sans JP', sans-serif;
    font-feature-settings: "palt";
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    font-size: 1.6rem;
    line-height: 1;
}
a{
    color: #333;
    text-decoration: none;
    transition: all .2s;    
    -webkit-transition: all .2s;
    -moz-transition: all .2s;
    -ms-transition: all .2s;
    -o-transition: all .2s;
}
a:hover{
    opacity:0.5;
}
img{
    max-width:100%;
    height:auto;
}
input,textarea{
    appearance:none;
    -webkit-appearance:none;
    -moz-appearance:none;
    outline:none;
    color:#333333;
    font-size: 1.6rem;
}
/*--------------------
parts
---------------------*/
.text-center{
    text-align:center;
}
/*--------------------
header,nav,footer
---------------------*/
/* header */
.header{
    position: fixed;
    top:0;
    left:0;
    z-index: 100;
    box-sizing: border-box;
    width: 100%;
    height: 69px;
    padding: 20px 20px 16px;
    border-top: 1px solid #e2dede;
    border-bottom: 1px solid #e2dede;
    background-color: #fff;
}
.header-inner{
    padding: 0;
}
.header-nav{
    display: none;
    position: fixed;
    top:0;
    left:0;
    z-index: 50;  
    box-sizing: border-box; 
    width:100%;
    height: 120%;
    padding: 120px 0 0;
    background-color: rgba(255,255,255,0.97);
}
.site-title{
    width:56px;
}
/* nav */
.btn-trigger{
    appearance:none;
    -webkit-appearance:none;
    overflow: hidden;
    position: absolute;
    top:12px;
    right:12px;
    z-index: 100;
    width: 40px;
    padding: 0;
    border:none;
    background-color: #fff;
    white-space: nowrap;    
}
use{
    -webkit-transition: 0.5s all;
    -moz-transition: 0.5s all;
    -ms-transition: 0.5s all;
    transition: 0.5s all;
}
.btn-trigger.active use:nth-of-type(1) {
    -webkit-transform: translateY(30px) rotate(-45deg);
    transform: translateY(30px) rotate(-45deg);
}

.btn-trigger.active use:nth-of-type(2) {
    opacity: 0;
}
.btn-trigger.active use:nth-of-type(3) {
    -webkit-transform: translateX(35px) translateY(-15px) rotate(45deg);
    transform: translateX(35px) translateY(-15px) rotate(45deg);
}
.br-sp{
    display: none;
}
.nav-list{
    margin:0 0 55px;
}
.nav-list:last-of-type{
    margin:0 0 75px;
} 
.nav-item{
    margin:0 0 55px;
}
.nav-item>a{
    color:#626262;
    font-size:1.4rem;
    text-transform: uppercase;
}
.sns{
    font-size:3.0rem;
    color:#777;
}
/* footer */
.footer{
    padding:75px 0 75px;
    background-color: #fff;
    color:#626262;    
}
.footer .logo{
    max-width: 75px;
    margin: 0 auto 55px;
}
.btn-pageTop{
    display: none;
}
.address{
    margin:0 0 75px;
    font-size:1.3rem;
    line-height: 2.1;
}
.copyrights{
    font-size: 1.1rem;
}
/*--------------------
hero-image
---------------------*/
.hero{
    position: relative;
    margin-top: 69px;
}
.hero .logo{
    position: absolute;
    top:50%;
    left:50%;
    z-index: 100;
    width:80px;
    height: 80px;
    -webkit-transform:translate3d(-50%,-50%,0);
    -moz-transform:translate3d(-50%,-50%,0);
    -ms-transform:translate3d(-50%,-50%,0);
    -o-transform:translate3d(-50%,-50%,0);
}
.hero-img__pc{
    display: none;
}
/*--------------------
layout,background
---------------------*/
.main{
    padding: 69px 0 0;
}
.bg-a{
    background-color: #f4f4f4;
}
.bg-b{
    background-color: #e6e6e6;
}
.bg-c{
    background-color: #fff;
}
.section-head{
    padding:75px 0 55px;
}
.section-title{
    margin:0 0 17px;
    font-size:3.0rem;
    text-transform: uppercase;
}
.section-main{
    padding:0;
}   
.section-footer{
/*    padding: 55px 0 75px;*/
	/*ボタンを入れる時のパディング*/
	
	padding: 55px 0 50px;
}
/*--------------------
worklist
---------------------*/
.mix{
    display: none;
}
.works-list-item{
    position: relative;
}
.works-list-title{
    font-size: 3.0rem;
    text-transform: uppercase;
}
.work-list-label{
    position: absolute;
    top:50%;
    left:50%;
    width: 100%;
    -webkit-transform:translate3d(-50%,-50%,0);
    -moz-transform:translate3d(-50%,-50%,0);
    -ms-transform:translate3d(-50%,-50%,0);
    -o-transform:translate3d(-50%,-50%,0);
    color:#fff;
    text-align: center; 
}
.works-info{
    position: absolute;    
    bottom: 30px;
    left: 20px;
}
/*--------------------
btn
---------------------*/
.btn-outer{
    padding: 0 56px;
}
.btn{
    appearance:none;
    -webkit-appearance:none;
    -moz-appearance:none;
    display: inline-block;
    width:100%;
    padding: 16px 0;
    border-radius: 0;
    background-color: #444;
    color:#fff;
    text-align: center;
    text-transform: uppercase;
}
.btn:after{
    position: relative;
    left:16px;
    content: "\f105";
    font-family: FontAwesome;
}
.btn-maps:before{
    position: relative;
    left:-16px;
    content:"\f041";
    font-family: FontAwesome;    
}  
.btn-maps:after{
    content:none;
}    
/*--------------------
card(news)
---------------------*/
.card-list{
    margin:0 8px; 
}
.card-item{
    margin:0 0 30px;
    background-color: #fff;    
}
.card-item:last-of-type{
    margin-bottom:0;
}
.card-item>a{
    display: block;
}    
.card-main{
    padding: 30px 12px 0;
}
.card-meta{
    padding: 0 0 30px;
}
.card-date{
    font-size: 1.1rem;
}
.card-category{
    display: inline-block;
    float: right;
    clear: right;
    width: 100px;
    padding: 5px 0;
    border-radius:3px;
    color:#fff;
    font-size: 1.1rem;      
    text-align: center;
}
.seminar{
    background-color:#17d8e6;   
}
.media{
    background-color: #e69a17;
}
.recruit{
    background-color:#a0a0a0;
}
.card-summary{
    padding: 0 0 55px;
    font-size: 1.3rem;
    line-height: 1.6;
}
/*--------------------
lowpage
---------------------*/
.lowpage-title{
    margin-bottom: 17px;
    color:#2e2e2e;      
    font-size:3.5rem;
    font-weight: 600;
    text-transform: uppercase;
}
.lowpage-subhead{
    color:#2e2e2e;   
}
/*--------------------
lowpage-about
---------------------*/
.lowpage-sublead{
    font-family:'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3','Noto Sans JP', sans-serif;    
    line-height: 1.5;
}
.company .section-main{
    padding-bottom: 75px;
}
.about-lead{
    margin:0 0 30px;
    font-size:2.4rem;
    font-weight: 600;
}
.about-lead:last-child{
    margin: 0;
}
.about-lead__ja{
    display: block;
    padding: 17px 0 0;
    font-size: 1.6rem;
}
.about-img{
    padding: 75px 0 0;
}
/* company */
.company-info{
    box-sizing: border-box;
    padding: 0 16px;
}
.company-item{
    display: table;
    width:100%;
    padding:0 0 30px;
    color:#393939;
    font-family:  'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3','Noto Sans JP', sans-serif;
    line-height: 1.5;
}
.company-item:last-of-type{
    padding: 0;
}    
.company-title{
    display: table-cell;
    width: 30%;
    text-align: right;
}
.company-detail{
    display: table-cell;
    padding:0 0 0 30px;    
    text-align: left;
}
/* access */
.maps-outer{
    position: relative;
    padding-top: 75%;
}
.maps{
    position: absolute;
    top:0;
    left:0;
    width: 100%;
    height: 100%;
}
.access-info{
    margin-bottom: 55px;
    line-height: 2;
}
.access .btn{
    text-transform:capitalize;
}
/*--------------------
lowpage
---------------------*/
/* works */
.cat-nav{
    padding:0 0 75px;
}
.cat-nav-item{
    margin:0 0 30px;
    color:#aaa;
    font-weight: 500;
    cursor: pointer;
    -webkit-transition: all .2s;
    -moz-transition: all .2s;
    -ms-transition: all .2s;
    -o-transition: all .2s;
    transition: all .2s;
}
.cat-nav-item:last-of-type{
    margin: 0;
}
.cat-nav-item:hover,.cat-nav-item.active{
    color:#777;
}
.works-info{
    position: absolute;
    bottom:30px;
    left: 20px;
}
.works-label{
    color: #fff;
    text-align: center;
    font-size: 2.4rem;
    font-weight:500;
}
.works-info{
    font-size: 1.4rem;
    color:#fff;
}
.black{
    color:#2e2e2e;
}
.bule{
    color: #457AF3;
}
/*--------------------
lowpage-contact
---------------------*/
.coop-item{
    padding: 0 0 10px;
}
.coop-item:first-of-type{
    padding: 0 0 20px;
}


.form-outer{
    box-sizing: border-box;
    padding: 55px 0 0;
    font-family:  'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3','Noto Sans JP', sans-serif;
}
.form .section-main{
    box-sizing: border-box;
    padding: 0 20px;
}
.form-title{
    margin:0 0 17px;
}
.form-item{
    margin:0 0 30px;
}
.form-item:last-of-type{
    margin:0 0 55px;
}
.form-parts{
    box-sizing: border-box;
    width: 100%;
    padding: 8px 4px;
    border: solid 1px #e0e0e0;
    border-radius: 3px;
    background-color: #fff;
    color:#333;
    font-size: 1.6rem;
    line-height: 1.5;
    box-shadow: none;
}
.form-parts__checkbox{
    width: 18px;
    height: 18px;
    margin: 0 9px 0 0;
    border: solid 1px #e0e0e0;
    background-color: #fff;
    vertical-align: -3px;
}
.btn-submit{
    border: none;
    letter-spacing:0.3em;
}
.form-parts__checkbox:checked{
    background-color: #444;
}
.require{
    margin-left: 15px;
    padding: 3px 4px;
    border-radius: 3px;
    background-color: #ff0000;
    color: #fff;
    font-size: 1.1rem;
    font-weight: bold;
    vertical-align: 1px;
}


/*--------------------
blog
---------------------*/


.blog-subtext{
    display: none;
}
.harf-title{
    font-size: 2.2rem;
}





/*--------------------
details
---------------------*/

.blog-list{
    margin: 0 auto;
    padding-left: 10px
}
.blog-block{
    display: flex;
    display: -webkit-flex;
}
.blog-category{
    width: 100%;
    margin: 0 auto;
    padding-left: 25px;
}

.blog-title{
}
.blog-detail{
    width: 100%;
    padding: 0 20px 20px;
}

.blog-item{
    margin-bottom: 30px;
    line-height: 1.5;
}
.blog-text{
    margin-bottom: 30px;
    padding: 0 30px;
    line-height: 1.3;
    text-indent: 0.5em;
}

.blog-footer-img{
    margin-bottom: 75px;
}


/*--------------------
02-seremony
---------------------*/
.lowpage-subhead{
    line-height: 1.5;
}
.seremony-list{
    line-height: 1.5;
/*    margin-bottom: 50px;*/
/*    padding-left: 10px;*/
    margin: 0 auto;
    margin-bottom: 50px;
}
.seremony-list-card{
    line-height: 1.5;
    margin-left: 10px;
    margin-right: 10px;
    margin-bottom: 50px;
}


.seremony-block{
    display: flex;
    display: -webkit-flex;
    margin-left: -30px; 
    margin-bottom: 30px;
    width: 100%;
}

.seremony-title{
    width: 30%;
    text-align: right;
}
.seremony-details{
    width: 70%;
    padding-left: 20px;
}

.seremony-details-right{
    width: 70%;
    padding-left: 20px;
    padding-right: 20px;
}

/*--------------------
03-seremony
---------------------*/
.seremony-block.hikari{
    margin-left: 0;
    margin-bottom: 10px;
}

/*--------------------
06-seremony
---------------------*/

.video{
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}

.video iframe{
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
}

/*--------------------
07-seremony
---------------------*/
.reference{
    display: block;
    padding: 10px 0 0 0;
}


/*--------------------
08-seremony
---------------------*/
.blog-text-sub{
    margin-bottom: 10px;
    padding: 0 30px;
    line-height: 1.5;
	text-align: center;
}
.blog-text-sub:first-of-type{
    text-indent: 0.5em;
    }


.blog-text-sub:last-of-type{
    margin-bottom: 50px;
}

/*
.underline{
    text-decoration: underline;
    color: #1843A9;
}
*/
/*--------------------
09-seremony
---------------------*/
.sp-none{
    display: none;
}
.seremony-img{
    width: 200px;
    height: auto;
}

 /*------------------
    blank
--------------------*/

    .blank{
        margin-bottom: 30px;
    }



/*--------------------
    question
---------------------*/
.question-list{
    padding: 0 26px 0 46px;
    width: auto;
    margin: 0 auto;
}

.question-item{
    margin-bottom: 30px;
    line-height: 1.5;
    text-indent: -1.2em;
}

.question-item::before{
    position: relative;
    content: "Q.";
    left: -4px;
    color: #ff0000;
}



.question-detail{
    margin-bottom: 50px;
    line-height: 1.5;
    text-indent: -1em;
}

.question-section-first{
    margin-bottom: 10px;
    line-height: 1.5;
    text-indent: -1em;
}

.question-section-next{
    margin-bottom: 10px;
    line-height: 1.5;
}
.question-section-next:last-of-type{
    margin-bottom: 50px;
    line-height: 1.5;
}


.question-detail::before{
    position: relative;
    content: "A.";
    left: -3px;
    color: #00ff;
}

.question-section-first::before{
    position: relative;
    content: "A.";
    left: -3px;
    color: #00ff;
}

.question-thumbnail{
    margin-bottom: 55px;
}

.question-footer{
    padding: 55px 0 0;
}













@media screen and (min-width:640px){
    /*--------------------
    parts
    ---------------------*/
    .inner{
        max-width: 1140px;
        margin:0 auto;
        padding: 0;
    }
    .section-head{
        padding: 80px 0;
    }
    /*--------------------
    header,nav,footer
    ---------------------*/
    /* header */
    .header{
        height: 64px;
        padding: 0; 
        -webkit-transition: all .2s;
        -moz-transition: all .2s;
        -ms-transition: all .2s;
        -o-transition: all .2s;
        transition: all .2s; 
    }
    .home .header{
        position: static;
    }
    .header.fix{
        position: fixed;
        top:0;
        left:0;
        width:100;
        animation:nyuru 0.5s;
    }
    @keyframes nyuru {
        0%{
            margin-top:-64px;
        }
        100%{
            margin-top:0;
        }
    }
    .header-inner{
        display: flex;
        -webkit-display: flex;
        justify-content: space-between;
        box-sizing: border-box;
        padding: 0 20px;
    }
    .site-title{
        position: static;
        box-sizing: border-box;
        padding: 12px 0px;
    }
    /* navigation */
    .btn-trigger{
        display: none;
        position: static;
    }
    .header-nav{
        display: block;
        position: static;
/*        height: auto;*/
        width:auto;
        padding: 0;
    }
    .navigation{
        -webkit-display: flex;
        display: flex;
    }
    .nav-list{
        -webkit-display: flex;
        display: flex;
        justify-content: center;
        margin: 0 0 0 38px;
    }
    .footer .nav-list{
        margin:0 0 24px;
    }
    .header .nav-list:last-of-type{
        margin:0 0 0 38px;
    } 
    .nav-item{
        margin: 0 0 0 30px;
    }
    .header .nav-item>a{
        display: block;
        box-sizing:border-box;
        height: 62px;        
        line-height: 62px;
    }
    .nav-item.current>a{
        color:#aaa;
        border-bottom:solid 2px #aaa;
    }
    .nav-item:first-child{
        margin-left: 0;
    }
    .nav-item__sns{
        margin-left: 24px;
    }
    .sns{
        font-size: 1.8rem;
    }
    .footer{
        position: relative;
        padding:80px 0;
    }
    .footer .logo{
        margin:0 auto 64px;
    }
    .btn-pageTop{
        display: block;
        position: absolute;
        right:0;
        bottom:50px;
        background-color: #bababa;
    }
    .btn-pageTop>a{
        position: relative;
        display: block;
        overflow: hidden;        
        width: 44px;
        height: 44px;
        text-indent:100%;
        white-space:nowrap;
    }        
    .btn-pageTop>a:before{
        position: absolute;
        top:50%;
        left:0%;
        content: "\f077";
        font-family: FontAwesome;
        color:#222;
        transform:translate3d(-50%,-50%,0);
        -webkit-transition: all .2s;
        -moz-transition: all .2s;
        -ms-transition: all .2s;
        -o-transition: all .2s;
        transition: all .2s;
    }
    .btn-pageTop>a:hover:before{
        top:40%;
    }          
    /*--------------------
    hero
    ---------------------*/
    .hero{
        margin-top: 64px;
    }
    .home .hero{
        margin-top: 0;
    }
    .hero-img__sp{
        display: none;
    }
    .hero-img__pc{
        display: block;
    }
    /*--------------------
    layout
    ---------------------*/
    .main{
        padding-top: 64px;
    }

    

    /*--------------------
    works-list
    ---------------------*/
    .works-list{
        overflow: hidden;/*IE11*/
        -webkit-display: flex;
        display: flex;
        flex-wrap:wrap;
    }
    .works-list-item{
        width:33.333%;
    }
    .works-info{
        opacity:0;
    }
    .works-link:hover{
        opacity: 1;
    }
    .works-link:hover .works-info{
        opacity:1;
        -webkit-filter: blur(0px);
        filter: blur(0px);
    }
    .cover{
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translateY(-50%) translateX(-50%);
        transform: translateY(-50%) translateX(-50%);
        width: 100%;
        height: 100%;
        opacity: 0;
        background-image: linear-gradient(0deg, rgba(0,0,0,0.6), rgba(0,0,0,0.25), transparent);
        transition: all .2s;
        -webkit-transition: all .2s;
        -moz-transition: all .2s;
        -ms-transition: all .2s;
        -o-transition: all .2s;
    }
    .works-link:hover .cover{
        opacity: 0.6;
    }
    /*--------------------
    card
    ---------------------*/
    .card-list{
        display: flex;
        margin-left:-20px;
    }
    .card-item{
        width:33.333%;
        margin: 0 0 0 20px;
    }
    /*--------------------
    btn
    ---------------------*/
    .btn{
        width:240px;
    }
    .btn-maps-outer{
        padding: 8px 50px;
    }
    /*--------------------
    lowpage
    ---------------------*/
    .lowpage-title{
        margin-bottom: 24px;
        font-size:4.8rem;
    }

    /*--------------------
    access
    ---------------------*/
    .maps-outer{
        padding: 300px 0 0;
    }
    .access-detail{
        -webkit-display: flex;
        display: flex;
        justify-content: space-between;
        max-width: 946px;
        margin: 0 auto;
    }
    .access-info{
        margin: 0;
        text-align: left;
    }
    .access-info br{
        display: none;
    }
    /*--------------------
    works
    ---------------------*/
    .section-nav{
        display: flex;
        justify-content: center;
        padding-bottom: 80px;
    }
    .cat-nav{
        -webkit-display: flex;
        display: flex;
        justify-content: center;
    }
    .cat-nav-item{
        margin: 0 30px 0 0;
    }
    .cat-nav-item:last-child{
        margin-right: 0;
    }
    .cat-nav-item>a{
        margin-bottom: 30px;
        color:#aaa;
    }
    .cat-nav-item:last-child>a{
        margin-bottom: 0;
    }
    .works-category{
        display: block;
        padding-top: 20px;
        font-size: 1.4rem;
        color:#fff;
    }
    /*--------------------
    contact
    ---------------------*/
    .form{
        max-width: 710px;
        margin: 0 auto;
        padding:40px 0 0;
    }
    .form-item{
        -webkit-display: flex;
        display: flex;
        margin-bottom: 24px;
    }
    .form-title{
        width: 180px;
        margin: 0 32px 0 0;
        padding: 10px 0;
        text-align: right;
    }
    .form-parts{
        width: 460px;
    }

    /*--------------------
    blog
    ---------------------*/




    /*--------------------
    details
    ---------------------*/
    .blog-item .br{
        display:none;
    }

    .blog-head{
       	margin: 16px auto;
        text-align: center;
        display: block;
        line-height: 1.6;
                  
    }

    
/*
    .blog-list{
        padding-left: 80px;
    }
*/
    .blog-text{
        text-align: left;
        display: inline-block;
        display: flex;
        display: -webkit-flex;
        justify-content: center;
        -webkit-justify-content: center;
        
    }
  
    .blog-subtext{
/*        font-size: 1.2rem;*/
/*        margin: 16px auto;*/
        padding-top: 30px;
        text-align: center;
        display: flex;
        display: -webkit-flex;
        justify-content: center;
        -webkit-justify-content: center;
    }
    .blog-title{
        width: 30%;
        text-align: right;
    }
    .blog-detail{
        width: 100%;
    }
    
    
/*
    .garbage-img{
        margin-bottom: 30px;
    }
*/
    .table-title{
        margin: 20px;
        justify-content: center;
        -webkit-justify-content: center;
    }
    
    .table-details{
        border: solid 1px;
        font-size: 1.5rem;
        padding: 10px;
    }
    
    .harf-ditails{
        display: block;
        font-size: 0.7rem;
        padding-top: 10px;
    }
    
    
    /*--------------------
    02-seremony
    ---------------------*/
    .seremony-block{
        width: 100%;
        margin: 0 auto;
    }
    
    .seremony-title{
        width: 40%;
        
    }
    .seremony-details{
        width: 60%;
        margin-right: 20px;
    }
    

    
    .br-pc{
        display: none;
    }


    /*--------------------
    08-seremony
    ---------------------*/
    .underline a:hover {
        text-decoration: underline;
}
    
    /*--------------------
    09-seremony
    ---------------------*/
    .sp-none{
        display: inline-block;
    }




    /*--------------------
    about
    ---------------------*/
    .harf-title{
        font-size: 2.2rem;
    }

    /*--------------------
    question
    ---------------------*/
    .question-list{
        padding: 0;
        width: 600px;
        margin: 0 auto;
    }


@media screen and (min-width:1140px){
    .header-inner{
        padding: 0;
    }


}