@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;600&family=Taviraj:ital,wght@0,100;0,200;0,300;1,100;1,200;1,300&display=swap');

/* CSS Document */
/* ==================================================
    BASE (RESET)FONT
================================================== */
html { font-size: 90%;}
body {
    background-color: #fdf5f2;
    background-size:cover;
	color: #000;
    font-family:"Times New Roman", Times, "serif";
    font-weight: nomal;
	font-size: 13px;
	font-feature-settings: "palt" 1;
	line-height: 190%;
	text-align: center;
	letter-spacing: 0.05em;
	-webkit-font-smoothing: antialiased; /* WebKitブラウザサポート */
	text-rendering: optimizeLegibility; /* Chrome、Safariサポート */
	-moz-osx-font-smoothing: grayscale; /* Firefoxサポート */
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%; /* iPhoneの文字サイズバグの回避 */
    overflow-x: hidden;
}
img {
    display: block;
    width: 100%;
}


/* ==================================================
    LINK
================================================== */
a { 
    line-height: 1.25;
    color:#000;
    transition: .2s ease-in-out;
    border-bottom: 0.75px solid #000; 
}
a:link {
    color:#000;
    text-decoration:none;
    transition: .2s ease-in-out;
}
a:visited {
    color:#000;
}
a:hover { 
    color:#666;
    transition: .2s ease-in-out;
    border-bottom: 0.75px solid #666; 
}
a:active { 
    color:#000;
}
a img { 
    opacity:1.0;
    transition: .3s ease-in-out;
}
a img:hover { 
    opacity: .7 !important;
}


/* ==================================================
    PC/SP 表示切り替え
================================================== */
.sp_only { display:inherit }
.pc_only { display:none }
.common-w {
    width:88%;
    margin: 0 auto;
}
@media screen and (min-width:1024px){
    .sp_only { display:none }
    .pc_only { display:block }
    .common-w {
        /*width:90%;*/
        /*max-width: 1280px*/
    }
}


/* ==================================================
   header
================================================== */
header {
    width: 100%;
    margin: 0em 0 5em;
    background-color: #561620;
    padding: 4em 0 5em;
}
header .top {
	width: 100%;
}
header .header_img {
    width: 85%;
    margin: 0 auto;
}
header .header_logo {
	width: 70%;
	margin: 1.5em auto 0;
}
@media screen and (min-width:1024px){
    header {
    width: 100%;
    background-color: #561620;
    padding: 3.5em 0 5em;
}
    header .top {
        max-width: 1280px;
        height: auto;
        display: flex;
        align-items: center;
        align-content: center;
        flex-wrap: wrap;
        justify-content:space-between;
        margin: 0 auto;
        padding: 0em 0;
        width: 92%;
    }
    header .header_img {
        width: 45%;
        margin: 0;
    }
    header .header_logo {
        width: 26%;
        margin: 0;
        padding-left: 4em;
    }
}

/* ==================================================
   section / gallery
================================================== */
section.gallery ul {}
section.gallery li {
    margin-bottom: 10em;
}
section.gallery li .gallery-img {
    margin-bottom: 8em
}
section.gallery li .gallery-img img {
    margin-bottom: 1em;
}
section.gallery .credit-item {
    margin-top: 3em;
    font-family: 'Taviraj', serif;
    font-weight: 300;
    font-style:italic;
    font-stretch: normal;
    font-optical-sizing: auto;
    font-size:12px;
    color:#000;
    line-height:2.2;
}
section.gallery .credit-item a {
    line-height: 2.0;
    font-family: 'Taviraj', serif;
    font-weight: 300;
    font-style: italic;
    font-stretch: normal;
    font-optical-sizing: auto;
    font-size:12px;
    color:#000;
}
section.gallery .credit-item div {
    height: 2.5em;
    font-size: 15px;
    font-weight: 300;
    font-style:normal;
    font-family:"Times New Roman", Times, "serif";
}
section.gallery .credit-item a:hover {
    line-height: 1.8;
    font-family: 'Taviraj', serif;
    font-weight: 300;
    font-style: italic;
    font-stretch: normal;
    font-optical-sizing: auto;
    font-size:12px;
    color:#666;
    transition: .2s ease-in-out;
    border-bottom: 0.75px solid #666; 
}
section.gallery li#gallery-09 .gallery-img {
        width: 75%;
        margin: 0 auto 10em;
        
}

@media screen and (min-width:1024px){
    section.gallery li {
        flex-wrap: wrap;
        justify-content:center;
        align-items:center;
        display:block;
    }
    section.gallery li {
        justify-content:center;
        margin-top: 10em;
    }
    section.gallery li .gallery-img {
        width: 45%;
        margin: 0 1em 5em;
        min-width: 600px;
    }
    section.gallery li#gallery-01 .gallery-img {
        width: 40%;
        margin: 0 auto 10em;
        
    }
    section.gallery li#gallery-02 .gallery-img {
        width: 40%;
        margin: 0 auto 10em;
        
    }
    section.gallery li#gallery-03 .gallery-img {
        width: 40%;
        margin: 0 auto 10em;
        
    }
    section.gallery li#gallery-04 .gallery-img {
        width: 40%;
        margin: 0 auto 10em;
        
    }
    section.gallery li#gallery-05 .gallery-img {
        width: 40%;
        margin: 0 auto 10em;
        
    }
    section.gallery li#gallery-06 .gallery-img {
        width: 40%;
        margin: 0 auto 10em;
        
    }
    section.gallery li#gallery-07 .gallery-img {
        width: 40%;
        margin: 0 auto 10em;
        
    }
    section.gallery li#gallery-08 .gallery-img {
        width: 40%;
        margin: 0 auto 10em;
        
    }
    section.gallery li#gallery-09 .gallery-img {
        width: 25%;
        margin: 5em auto 10em;
        min-width: 450px;
        
    }

}


/* ==================================================
   section / credit
================================================== */
section.credit .credit-logo {
     margin-bottom: 5em;
}
section.credit .credit-logo .img {
    width: 70%;
    margin:0 auto 3em;
}
section.credit .credit-logo .lg {
    width: 55%;
    max-width: 400px;
    margin:0 auto;
}
.credit-staff {
    width: 100%;
    margin:3em auto 6em;
    font-family: 'Taviraj', serif;
    font-weight: 300;
    font-style:italic;
    font-stretch: normal;
    font-optical-sizing: auto;
    font-size:12px;
    color:#000;
    line-height:2.0;
}
    .credit-staff a {
    width: 100%;
    margin:3em auto 6em;
    font-family: 'Taviraj', serif;
    font-weight: 300;
    font-style:italic;
    font-stretch: normal;
    font-optical-sizing: auto;
    font-size:12px;
    color:#000;
    line-height:2.0;
}

.credit-staff .jp_title {
    font-size: 14px;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    line-height: 3;
    letter-spacing: 0.1em;
}
.credit-staff .jp {
    font-size: 12px;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}
@media screen and (min-width:1024px){
    section.credit .credit-logo .img {
        width: 40%
    }
    section.credit .credit-logo .lg {
        width:45%;
    }

    .credit-staff .jp {
    font-size: 12px;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    }
}

/* ==================================================
   section / share-button
================================================== */
section.share-button ul {
    display: flex;
    justify-content:center;
    margin-bottom: 5em;
}
section.share-button ul li a {
    margin: 0 0.25em;
    display: flex;
    align-items:center;
    justify-content: center;
    border-radius: 50%;
    border:#666 1px solid;
    line-height:1;
    width: 2.25em;
    height: 2.25em;
    background-color: transparent!important;
    text-decoration: none;
    transition: 0.3s;
}
section.share-button ul li
section.share-button ul li a,
section.share-button ul li i {
    color:#666;
    transition: 0.3s;
}
section.share-button .fab,
section.share-button .fa {
    text-align: center;
    font-size: 1.1em;
}
section.share-button ul li a:hover {
    border:#666 1px solid;
}
section.share-button ul li a:hover i {
    color: #666;
}
@media screen and (min-width:1024px){
    section.share-button ul li a {
        font-size:17px !important;
        width: 2.5em;
        height: 2.5em;
    }
}    


/* ==================================================
   footer - store_address
================================================== */
footer {
    background-color:#561620;
    color: #fff;
}
footer .store>div {
    padding: 5em 0;
}
footer .store h4 {
    font-size: 1.35em;
    margin-bottom: 0.5em;
}
footer .store p {
    font-size:0.85em;
}
footer .store .store-list {
    margin: 3em 0;
}
footer .store .store-list li {
    margin-bottom:1.5em;
}
footer .store .store-list h5 {}
footer .store .store-list a {
    margin-left: .75em;
}
footer .copyright {}
footer .copyright h6 {    
    line-height: 1;
    font-family:helvetica;
    font-size: 12px;
    padding: 0 0 5em;
}
footer .store .store-list a { 
    color:#FFF;
    text-decoration:none;
    transition: .2s ease-in-out;
}
footer .store .store-list a:link {
    color:#FFF;
    text-decoration:none;
    transition: .2s ease-in-out;
    border-bottom: 0px solid #FFF;
}
footer .store .store-list a:visited {
    color:#FFF;
}
footer .store .store-list a:hover { 
    color:#333;
    border-bottom: 0.75px solid #333; 
}
footer .store .store-list a:active { 
    color:#FFF;
}


/* ==================================================
    SCROLL UP
================================================== */
.scroll-up {
    width: 3em;
    height: 3em;
    border: 1px solid #FFFFFF;
    border-radius: 50%;
    cursor: pointer;
    background-color: rgba(0,0,0,0.1);
    transition: 0.3s;
    overflow: hidden;
    position: fixed;
    z-index:100;
	right: 1.25em; 
	top:  1.25em;
    opacity: 0;
    }
.scroll-up:hover {
    border: 1px solid rgba(255,255,255,0.3);
    background-color:rgba(255,255,255,0.3);
    opacity: 0.5;
}
.scroll-up a {
    width:100%;
    height: 100%;
	background-color:rgba(0,0,0,0.2);
    display: flex;
    justify-content: center;
    align-items: center;
    }
.scroll-up a:after {
    content:"";
    display:block;
    transform: rotate(45deg);
    width: 1em;
    height: 1em;
    margin-top: .5em;
    border-top: 1px solid #FFFFFF;
    border-left: 1px solid #FFFFFF;
}