@charset "utf-8";
/* レイアウト*/
body{
    font-family: "Zen Old Mincho", serif;
	color: #0f3921 ;
    background-color: #DBE6E2;
	font-size: 0.95rem;
	line-height: 2;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%; 
	word-wrap: break-word;
    height: 100%;
}
@media screen and (max-width: 580px) {
    body{
        font-size: 0.8rem;
	}
}
*{box-sizing: border-box;}
ul{
	margin:0;
	padding: 0;
	list-style: none;
}
a{
	text-decoration: none;
    outline: none;
}
a.hover:hover{
    opacity: .7;
}
img{
    width: 100%;
    height: auto;
}
/* font */
.bold{
    font-weight: 700;
}
.green{
    color: #197242;
}
.cream{
    color: #faf2ce;
}
.white{
    color: #fff;
}
.gothic {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-style: normal;
}
.cinzel{
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-style: normal;
}
.font-120{
    font-size: 120%;
}
/* top-bg */
#fixed-bg{
    width: 100%;
    height: 100vh;
    background: url("../images/fixed_bg.png");
    background-size: cover;
    background-position: center center;
    position: fixed;
}
@media screen and (max-width: 1024px) {
    #fixed-bg{
        background-position-x: -260px;
    }
}
/* regular-btn */
.btn a,
.submit-btn{
    width: 80%;
    max-width: 350px;
    height: 50px;
    background-color: #197242;
    border: 1px solid #faf2ce;
    color: #faf2ce;
    font-weight: 700;
    border-radius: 50px;
    padding: 8px 5px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-self: center;
    justify-content: center;
    line-height: 1.3;
    margin: 0 auto;
    transition: all .2s;
}
.submit-btn{
    max-width: 250px;
    height: 40px;
    margin-top: 30px;
    flex-direction: unset;
}
.btn a:hover,
.submit-btn:hover{
    background-color: #faf2ce;
    border: 1px solid #197242;
    color: #197242;
}
/* common */
#wrapper{
    width: 100%;
    max-width: 580px;
    margin: 0 auto;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    background-color: rgba(219, 230, 226, .7);
}
/* mv */
#mv{
    position: relative;
    margin-bottom: -8px;
}
.line-qr{
    position: absolute;
    right: 40px;
    top: 400px;
    width: 160px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
}
@media screen and (max-width: 500px) {
    .line-qr{
        right: 8%;
        top: calc(50% - 10px);
        width: 130px;
        gap: 10px;
    }
}
/* section common*/
.section-title{
    margin-bottom: 40px;
}
.gold-feather{
    width: 35px;
}
.text-box{
    text-align: center;
}
.text-box p{
    margin-bottom: 30px;
}
.text-box p:last-of-type{
    margin-bottom: 0;
}
#soul-message h3,
#create-together h3,
#inner-shift h3{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: .5rem;
    margin-bottom: 30px;
}
@media screen and (max-width: 580px) {
    #soul-message h3,
    #create-together h3,
    #inner-shift h3{
        gap: .3rem;
    }
}
/* about */
#about{
    text-align: center;
}
#about h3{
    margin-bottom: 30px;
}
.about-list li{
    margin-bottom: 60px;
}
#about h4{
    margin-bottom: 20px;
}
/* soul-message */
.soul-message-list li{
    margin-bottom: 60px;
}
/* profile */
.profile-list{
    margin-bottom: 60px;
}
.profile-list li{
    background-color: rgba(21, 95, 68, 0.9);
    padding: 50px 5% 30px;
    margin: 40px 8%;
}
@media screen and (max-width: 580px) {
    .profile-list li{
        margin: 40px 5%;
    }
}
.image-wrap{
    margin: 0 auto;
    position: relative;
    box-shadow: 15px 15px 0 0 #8FAD9B;
    max-width: 300px;
    width: 85%;
    height: 85%;
    aspect-ratio: 4 / 3;
}
.image-wrap::before{
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    border: 1px solid #fff;
    top: -15px;
    left: -15px;
    z-index: 2;
}
.name-en{
    display: block;
    width: 100%;
    max-width: 300px;
    margin: -10px auto 10px;
    position: relative;
    z-index: 1;
}
.prof-name{
    text-align: center;
    margin-bottom: 20px;
    line-height: 1.3;
}
.prof-text{
    font-size: 90%;
    line-height: 1.8;
}
/* safety */
#safety{
    text-align: center;
}
.safety-list{
    padding: 40px 20px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 15px;
}
.safety-list li{
    width: 165px;
}
#safety .text-box:last-of-type{
    margin-bottom: 60px;
}
@media screen and (max-width: 580px) {
    .safety-list li{
        width: 28%;
    }
}
@media screen and (max-width: 400px) {
    .safety-list li{
        width: 40%;
    }
}
/* create-together */
.create-list{
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    line-height: 1.4;
    color: #145f44;
    width: 98%;
    max-width: 520px;
    margin: 0 auto 60px;
    text-align: center;
}
.create-list li{
    background-color: rgba(255, 255, 255, .7);
    border: 1px solid #145f44;
    border-radius: 25px;
    padding: 20px 10px;
    width: 45%;
    height: 100px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.create-list li:last-of-type{
    background-color: inherit;
    border: none;
}
@media screen and (max-width: 580px) {
    .create-list li{
        height: 80px;
    }
}
@media screen and (max-width: 430px) {
    .create-list li{
        width: 250px
    }
}
/*---スライダー---*/
.slider {
    width: 100%;
    margin: 0 auto 60px;
}
.slider .slick-slide {
    margin: 0 10px;
}
.slick-slide img {
    width: 80%;
    margin: 0 auto;
}
figcaption{
    text-align: center;
}
/*戻る、次へ矢印の位置*/
.slick-prev, 
.slick-next {
    position: absolute;
    top: 45%;
    z-index: 1;
    cursor: pointer;
    outline: none;
    border-top: 2px solid #197242;
    border-right: 2px solid #197242;
    height: 15px;
    width: 15px;
}
.slick-prev {
    left: 30px;
    transform: rotate(-135deg);
}
.slick-next {
    right: 30px;
    transform: rotate(45deg);
}
@media screen and (max-width: 480px) {
    .slick-slide img {
        width: 90%;
    }
    .slick-prev {
        left: 10px;
    }
    .slick-next {
        right: 10px;
    }
}
/* voice */
#voice .section-title{
    margin-bottom: 80px;
}
.voice-box{
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 40px;
    margin: -65px auto 30px;
    text-align: center;
}
.voice-list{
    width: 90%;
    max-width: 520px;
    margin: 0 auto 60px;
    line-height: 1.6;
}
.voice-list li{
    background-color: #fff;
    padding: 40px 20px;
    margin-bottom: 60px;
}
.voice-number{
    background-color: #145f44;
    color: #fff;
    padding: 5px;
    text-align: center;
    width: 80%;
    margin: 0 auto 30px;
}
.job-line{
    border-bottom: 1px dashed #0f3921;
    margin: 10px auto;
}
.voice-img{
    transform: rotate(5deg);
    position: relative;
}
.voice-img::before{
    content: '';
    width: 100%;
    height: 100%;
    border: 1px solid #0f3921;
    transform: rotate(5deg);
    position: absolute;
}
.job-name{
    font-size: 95%;
    line-height: 1.4;
}
p.job-name::after{
    content:'様';
    margin-left: .25rem;
}
.voice-text-box{
    padding: 0 10px;
}
.voice-text-box p{
    margin-bottom: 20px;
}
.voice-text-box p:last-of-type{
    margin-bottom: 0;
}
@media screen and (max-width: 580px) {
    .voice-box{
        gap: 20px;
        margin: -60px auto 30px;
    }
}
@media screen and (max-width: 480px) {
    .voice-box{
        flex-direction: column;
    }
    .voice-name img{
        width: 200px;
    }
    .voice-img{
        width: 220px;
        margin: 15px auto;
        transform: rotate(0deg);
    }
    .voice-text-box{
        padding: 0;
    }
}
/* inner-shift */
.merit-list{
    width: 90%;
    max-width: 480px;
    margin: 0 auto 30px;
    color: #145f44;
}
.merit-list tr{
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 10px;
}
.merit-list th{
    background-color: #145f44;
    color: #fff;
    padding: 10px;
    width: 25%;
}
.merit-list td{
    background-color: #fff;
    border: 1px solid #145f44;
    padding: 10px 10px 10px 1.5rem;
    width: 75%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.meirt-number{
    display: flex;
    gap: .2rem;
    align-items: center;
    justify-content: center;
    font-weight: 400;
    font-size: 95%;
}
.meirt-number span:last-of-type{
    font-size: 180%;
}
#inner-shift .text-box{
    margin-bottom: 60px;
}
/* faq */
.accordion-area{
    margin-bottom: 60px;;
}
.accordion-area dl{
    background-color: #ADC4BB;
    color: #145f44;
    margin: 0 auto 20px;
    width: 90%;
    max-width: 480px;
    line-height: 1.5;
}
.question{
    position: relative;
    display: flex;
    padding: 20px;
    font-size: 110%;
    align-items: center;
}
.question span:first-of-type{
    margin-right: 1rem;
    font-size: 130%;
}
.question span:last-of-type{
    width: 75%; 
}
.question::before,
.question::after{
    position: absolute;
    content:'';
    width: 15px;
    height: 1px;
    background-color: #145f44;
    transition: all .2s;
}
.question::before{
    top: 2.3rem;
    right: 2rem;
    transform: rotate(0deg);
}
.question::after{
    top: 2.3rem;
    right: 2rem;
    transform: rotate(90deg);
}
.question.close::before{
	transform: rotate(180deg);
}
.question.close::after{
    display: none;
}
.answer{
    display: none;
    align-items: center;
    gap: 1.5rem;
    background-color: #fff;
    padding: 20px;
}
.answer p{
    position: relative;
}
/* closing */
#closing{
    background: url("../images/closing_bg.png");
    background-size: cover;
    background-repeat: no-repeat;
    background-position-x: center;
    padding-bottom: 60px;
}
#closing .text-box{
    margin-bottom: 40px;
}
/* footer */
.footer{
    background-color: #0f3921;
    color: #fff;
    font-size: 90%;
    text-align: center;
    padding: 20px 6% 100px;
}
.footer-contents{
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px;
}
.back-link{
    text-decoration: underline;
    margin-bottom: 15px;
    display: block;
}
.sns-list{
    display: flex;
    gap: 20px;
    justify-content: center;
}
.icon{
    display: block;
    width: 35px;
}
.footer-right p{
    margin-bottom: 5px;
    text-align: center;
}
.trust-banner{
    display: block;
    width: 180px;
    margin: 0 auto;
}
.joyfulbirthgift-logo{
    width: 95px;
    margin: 0 auto 10px;
}