/* header */
#header{
width: 100vw;
display: block;
padding: 0 0 100px 0;
background: url(../img/bg_main.jpg) no-repeat center top;
background-size: 100vw auto;
background-color: var(--green);
position: relative;
z-index: 100;
}
.titBlock{
width: 810px;
display: flex;
justify-content: flex-start;
flex-wrap: wrap;
gap: 24px; 
padding: 0 34px 0 30px;
background-color: var(--white);
border-bottom-right-radius: 50px;
}
#header h1{
width: 500px;
height: 0;
display: block;
padding-top: 80px;
background: url(../img/h1.svg) no-repeat center center;
background-size: contain;
color: var(--green-tit2);
font-family: var(--font-family-tit);
font-size: var(--font-xxxl);
line-height: 80px;
overflow: hidden;
}
#header h1.inview_target.target_in{
opacity: 1;
animation: scale-in-animation 1s backwards 2.5s;
}
.h1_date{
width: calc(100% - 500px - 24px);
display: block;
padding: 36px 0 0 0;
color: var(--gray);
font-size: var(--font-xxs);
font-weight: 500;
line-height: 1;
text-align: center;
}
.h1_date.inview_target.target_in{
opacity: 1;
animation: scale-in-animation 1s backwards 3s;
}
.hero_box{
display: flex;
flex-direction: row-reverse;
justify-content: center;
align-items: start;
margin: 50px 0 0 0;
gap: 54px;
}
.hero_box .hero_img{
width: 700px;
display: block;
}
.hero_box .hero_img img{
width: 100%;
display: auto;
border-radius: 50px;
}
.catch01{
width: 140px;
height: 0;
display: block;
padding-top: 600px;
background: url(../img/catch01.png) no-repeat center center;
background-size: contain;
overflow: hidden;
}
.catch02{
width: 140px;
height: 0;
display: block;
padding-top: 600px;
background: url(../img/catch02.png) no-repeat center center;
background-size: 110px auto;
overflow: hidden;
}

/* about */
#about{
display: block;
margin: 60px 0 0 0;
}
#about .wrapper{
display: flex;
justify-content: space-between;
flex-wrap: wrap;
padding: 60px 50px 60px 50px;
background-color: var(--light-gray);
border-radius: 50px;
}
#about h2{
width:262px;
display: block;
background: url(../img/h2_about.svg) no-repeat left center;
background-size: contain;
color: var(--dark-green);
}
.about_txt{
width: calc(100% - 262px);
display: block;
padding: 64px 0 0 0;
text-align: left;
}

/* works */
#works{
display: block;
margin: 90px 0 0 0;
}
#works .wrapper{
text-align: left;
padding: 0 50px 0 50px;
}
#works h2{
display: block;
background: url(../img/h2_works.svg) no-repeat left center;
background-size: contain;
color: var(--dark-green);
}
.works_block{
display: flex;
justify-content: space-between;
align-items: center;
flex-wrap: wrap;
gap: 40px;
margin: 40px 0 0 0;
}
.works_block .works_photo{
width: 475px;
display: block;
}
.works_block .works_photo img{
width: 100%;
height: auto;
border-radius: 50px;
}
.works_block .works_info{
width: calc(100% - 475px - 40px);
display: block;
}
.works_block .works_info ul{
display: flex;
flex-direction: column;
gap: 20px;
}
.works_block .works_info ul li{
display: block;
}
.works_block .works_info dl{
display: flex;
justify-content: flex-start;
flex-wrap: wrap;
align-items: start;
gap: 20px;
}
.works_block .works_info dl dt{
width: 150px;
display: block;
background-color: var(--dark-green);
color: var(--white);
border-radius: 15px;
font-size: var(--font-l);
line-height: 30px;
text-align: center;
}
.works_block .works_info dl dd{
width: calc(100% - 150px - 20px);
display: block;
font-size: var(--font-xxl);
font-weight: 500;
line-height: 30px;
}
.works_att{
display: block;
color: var(--red);
font-size: var(--font-xxs);
}
.works_exp{
display: block;
margin: 80px 0 0 0;
color: var(--dark-green);
font-size: var(--font-xxxl);
font-weight: 700;
text-align: center;
}
.works_exp p{
display: block;
margin: 0 0 12px 0;
padding: 0 0 12px 0;
background: url(../img/line.png) no-repeat center bottom;
background-size: auto 1px;
line-height: 1;
}
.works_exp p.para_start{
margin-top:50px;
}
.works_exp p span.accent{
display: inline-block;
margin: 0 5px 0 5px;
font-size: var(--font-xxxxl);
letter-spacing: 2px;
}
.works_exp p span.accent2{
display: inline-block;
font-size: var(--font-h3);
letter-spacing: 1px;
}

/* artist */
#artist{
display: block;
margin: 90px 0 0 0;
}
#artist .wrapper{
text-align: left;
padding: 0 50px 0 50px;
}
#artist h2{
display: block;
background: url(../img/h2_artist.svg) no-repeat left center;
background-size: contain;
color: var(--dark-green);
}
.artist_block{
display: flex;
flex-direction: row-reverse;
justify-content: space-between;
flex-wrap: wrap;
gap: 40px;
margin: 40px 0 0 0;
}
.artist_block .artist_photo{
width: 475px;
display: block;
}
.artist_block .artist_photo img{
width: 100%;
height: auto;
border-radius: 50px;
}
.artist_block .artist_info{
width: calc(100% - 475px - 40px);
display: block;
}
.artist_block .artist_info h3{
display: block;
color: var(--green-tit);
line-height: 1;
}
.artist_block .artist_info .artist_shoulder{
display: block;
margin: 10px 0 0 0;
color: var(--green-tit);
}
.artist_exp{
display: block;
margin: 40px 0 0 0;
font-size: var(--font-h4);
}
.artist_block .artist_info h4{
width: 82px;
display: inline-block;
margin: 40px 0 0 0;
background-color: var(--dark-green);
color: var(--white);
border-radius: 14px;
line-height: 28px;
text-align: center;
}
.artist_works{
display: block;
margin: 10px 0 0 0;
font-size: var(--font-xxxs);
line-height: 1.6;
}

/* overview */
.overview_box{
display: block;
margin: 0 0 -50px 0;
padding: 180px 0 180px 0;
background:url(../img/bg_overview.jpg) no-repeat center top;
background-size: 100vw auto;
background-color: var(--dark-green);
text-align: center;
position: relative;
top: -50px;
z-index: 5000;
}
.overview_box h2{
display: block;
background: url(../img/h2_overview.svg) no-repeat center center;
background-size: contain;
color: var(--white);
}
.overview_box .wrapper{
display: block;
margin: 40px auto 0 auto;
padding: 60px 50px 60px 50px;
background-color: var(--white);
border-radius: 50px;
}
.overview_catch{
display: inline-block;
padding: 0 30px 0 30px;
background-color: var(--dark-green);
color: var(--white);
border-radius: 25px;
font-size: var(--font-xxxl);
font-weight: 500;
line-height: 50px;
letter-spacing: 2px;
}
.overview_exp{
display: block;
margin: 30px 0 0 0;
font-weight: 500;
}
.overview_exp ul{
display: flex;
justify-content: center;
flex-wrap: wrap;
}
.overview_exp ul li{
width: calc((100% - 90px)/2);
display: block;
color: var(--dark-green);
margin: 20px 0 0 0;
padding: 0 0 0 1em;
font-weight: 700;
text-align: left;
position: relative;
}
.overview_exp ul li:before{
content: "・";
width: 1em;
display: block;
position: absolute;
top: 0;
left: 0;
}
.overview_list{
display: flex;
flex-direction: column;
margin: 40px 0 0 0;
padding: 30px 0 0 0;
border-top: 1px solid var(--light-gray);
}
.overview_list > li{
display: block;
margin: 0 0 30px 0;
padding: 0 10px 30px 10px;
border-bottom: 1px solid var(--light-gray);
}
.overview_list li dl{
width: 100%;
display: flex;
justify-content: space-between;
}
.overview_list li dt{
width: 200px;
display: block;
color: var(--dark-green);
font-weight: 500;
text-align: left;
}
.overview_list li dd{
width: calc(100% - 200px);
display: block;
text-align: left;
}
.overview_link{
display: block;
font-size: var(--font-xxxl);
font-weight: bold;
}
.overview_link a{
display: inline-block;
margin: 0 5px 0 5px;
color: var(--green);
text-decoration: underline;
text-decoration-thickness: 2px;
text-underline-offset: 8px;
}
.overview_sub{
display: inline-block;
margin: 0 10px 0 0;
font-weight: 700;
}
.overview_att,
.overview_point{
display: block;
padding: 0 0 0 1.2em;
position: relative;
}
.overview_att:before{
content: "※";
width: 1.2em;
display: block;
position: absolute;
top:0;
left: 0;
}
.overview_point:before{
content: "・";
width: 1.2em;
display: block;
position: absolute;
top:0;
left: 0;
}
.overview_list li dd > ol{
display: flex;
flex-direction: column;
gap:0;
}
.overview_list li dd > ol li{
display: block;
padding: 0 0 0 1.5em;
position: relative;
}
.overview_list li dd > ol li:before{
width: 1.5em;
display: block;
position: absolute;
top:0;
left: 0;
}
.overview_list li dd > ol li:nth-child(1):before{
content: "1.";
}
.overview_list li dd > ol li:nth-child(2):before{
content: "2.";
}
.overview_list li dd > ol li:nth-child(3):before{
content: "3.";
}
.overview_list li dd > ol li:nth-child(4):before{
content: "4.";
}
.overview_list li dd > ol li:nth-child(5):before{
content: "5.";
}
.overview_list li dd > ol li:nth-child(6):before{
content: "6.";
}
.overview_list li dd > ol li:nth-child(7):before{
content: "7.";
}
.overview_list li dd > ol li:nth-child(8):before{
content: "8.";
}
.overview_list li dd > ol li:nth-child(9):before{
content: "9.";
}
.overview_list li dd > ol.ol2 li:nth-child(1):before{
content: "1)";
}
.overview_list li dd > ol.ol2 li:nth-child(2):before{
content: "2)";
}
.overview_list li dd > ol.ol2 li:nth-child(3):before{
content: "3)";
}
.overview_list li dd > ol.ol2 li:nth-child(4):before{
content: "4)";
}
.overview_list li dd > ol.ol2 li:nth-child(5):before{
content: "5)";
}
.overview_list li dd > ol.ol2 li:nth-child(6):before{
content: "6)";
}
.overview_list li dd > ol.ol2 li:nth-child(7):before{
content: "7)";
}
.overview_list li dd > ol.ol2 li:nth-child(8):before{
content: "8)";
}
.overview_list li dd > ol.ol2 li:nth-child(9):before{
content: "9)";
}

/* apply */
#apply{
display: block;
margin: 0 0 -50px 0;
padding: 60px 0 110px 0;
background-color: var(--white);
border-radius: 50px;
text-align: center;
position: relative;
top: -50px;
z-index: 5000;
}
#apply h2{
height: 66px;
padding-top: 0;
color: var(--dark-green);
}
#apply h2 span:nth-of-type(2){
height: 0;
display: block;
padding-top: 32px;
background: url(../img/h2_apply.svg) no-repeat center bottom;
background-size: auto 32px;
color: var(--dark-green);
}
#apply h2 span:nth-of-type(1){
height: 0;
display: block;
margin: 0 0 15px 0;
padding-top: 19px;
background: url(../img/h2_apply_shoulder.svg) no-repeat center top;
background-size: auto 19px;
font-size: var(--font-xl);
overflow: hidden;
}

.apply_range{
display: block;
margin: 20px 0 0 0;
color: var(--green-tit);
font-size: var(--font-xl);
font-weight: 500;
text-align: center;
}
.apply_form{
width: 640px;
display: block;
margin: 40px auto 0 auto;
text-align: center;
}
.apply_form img{
width: 637px;
height: auto;
}
.apply_form iframe{
width: 100%;
height: auto;
}


/* -- */
/* -- */
/* SP */
/* -- */
/* -- */
@media screen and (max-width: 768px) {
/* */
/* */


/* header */
#header{
padding: 0 0 100px 0;
background: url(../img/bg_main.jpg) no-repeat center top;
background-size: cover;
background-color: var(--green);
position: relative;
z-index: 100;
}
.titBlock{
width: calc(100vw - 100px);
min-width: 238px;
max-width: auto;
height: 90px;
flex-direction: column;
gap: 8px;
padding: 0 24px 0 20px;
background-color: var(--white);
border-bottom-right-radius: 50px;
}
#header h1{
width: 100%;
margin-top: 10px;
padding-top: 45px;
background: url(../img/h1_sp2.svg) no-repeat left center;
background-size: contain;
font-size: var(--font-xxxl-sp);
line-height: 50px;
}
#header h1.inview_target.target_in{
opacity: 1;
animation: scale-in-animation 1s backwards 2.5s;
}
.h1_date{
width: 100%;
padding: 0 0 0 0;
font-size: var(--font-xxxs);
line-height: 1;
text-align: left;
}
.h1_date.inview_target.target_in{
opacity: 1;
animation: scale-in-animation 1s backwards 3s;
}
.hero_box{
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
margin: 50px 0 0 0;
gap: 44px;
}
.hero_box .hero_img{
width: 95vw;
}
.hero_box .hero_img img{
border-radius: 30px;
}
.catch01{
width: 95vw;
height: 0;
display: block;
padding-top: 10.3%;
background: url(../img/catch01_sp.png) no-repeat center center;
background-size: contain;
overflow: hidden;
}
.catch02{
width: 95vw;
height: 0;
display: block;
padding-top: 20.3%;
background: url(../img/catch02_sp.png) no-repeat center center;
background-size: contain;
overflow: hidden;
}

/* about */
#about{
margin: 0 0 0 0;
}
#about .wrapper{
flex-direction: column;
gap: 30px;
padding: 50px 20px 50px 20px;
background-color: var(--light-gray);
border-radius: 30px;
}
#about h2{
width:100%;
background: url(../img/h2_about.svg) no-repeat left center;
}
.about_txt{
width: 100%;
padding: 0 0 0 0;
}

/* works */
#works{
margin: 80px 0 0 0;
}
#works .wrapper{
padding: 0;
}
#works h2{
background: url(../img/h2_works.svg) no-repeat left center;
background-size: contain;
}
.works_block{
flex-direction: column;
gap: 30px;
margin: 30px 0 0 0;
}
.works_block .works_photo{
width: auto;
}
.works_block .works_photo img{
border-radius: 30px;
}
.works_block .works_info{
width: 100%;
}
.works_block .works_info ul{
gap: 20px;
}
.works_block .works_info ul li{
}
.works_block .works_info dl{
flex-direction: column;
align-items: center;
gap: 10px;
}
.works_block .works_info dl dt{
width: 150px;
border-radius: 12px;
font-size: var(--font-l-sp);
line-height: 24px;
}
.works_block .works_info dl dd{
width: 100%;
font-size: var(--font-xxl-sp);
line-height: 1.4;
text-align: center;
}
.works_att{
margin: 5px 0 0 0;
color: var(--red);
font-size: var(--font-xxs-sp);
}
.works_exp{
margin: 72px 0 0 0;
font-size: var(--font-xl-sp);
text-align: left;
}
.works_exp p{
display: block;
margin: 0 0 12px 0;
padding: 0 0 12px 0;
background: url(../img/line.png) no-repeat center bottom;
background-size: 100% 1px;
line-height: 1.4;
}
.works_exp p.para_start{
margin-top:20px;
clear: both;
}
.works_exp p span.accent{
display: inline;
margin: 0 5px 0 5px;
font-size: var(--font-xxxl-sp);
letter-spacing: 2px;
}
.works_exp p span.accent2{
display: inline;
font-size: var(--font-xxxl-sp);
letter-spacing: 1px;
}

/* artist */
#artist{
margin: 80px 0 0 0;
}
#artist .wrapper{
padding: 0;
}
#artist h2{
background: url(../img/h2_artist.svg) no-repeat left center;
background-size: contain;
}
.artist_block{
flex-direction: column;
gap: 30px;
margin: 30px 0 0 0;
}
.artist_block .artist_photo{
width: 100%;
}
.artist_block .artist_photo img{
border-radius: 30px;
}
.artist_block .artist_info{
width: 100%;
}
.artist_block .artist_info h3{
color: var(--green-tit);
}
.artist_block .artist_info .artist_shoulder{
margin: 10px 0 0 0;
color: var(--green-tit);
}
.artist_exp{
margin: 30px 0 0 0;
font-size: var(--font-h4);
}
.artist_block .artist_info h4{
width: 82px;
display: inline-block;
margin: 30px 0 0 0;
border-radius: 14px;
line-height: 28px;
}
.artist_works{
font-size: var(--font-xxxs);
}

/* overview */
.overview_box{
margin: 0 0 -50px 0;
padding: 150px 0 150px 0;
background:url(../img/bg_overview.jpg) no-repeat center top;
background-size: auto 80vh;
background-color: var(--dark-green);
}
.overview_box h2{
background: url(../img/h2_overview.svg) no-repeat center center;
background-size: contain;
}
.overview_box .wrapper{
margin: 30px auto 0 auto;
padding: 50px 5.5vw 50px 5.5vw;
border-radius: 30px;
}
.overview_catch{
padding: 10px 10px 10px 10px;
border-radius: 10px;
font-size: var(--font-xxl-sp);
line-height: 1.6;
letter-spacing: 2px;
}
.overview_exp{
margin: 30px 0 0 0;
text-align: left;
}
.overview_exp ul{
flex-direction: column;
gap: 5px;
margin: 20px 0 0 0;
}
.overview_exp ul li{
width: 100%;
margin: 0 0 0 0;
padding: 0 0 0 1em;
}
.overview_exp ul li:before{
content: "・";
width: 1em;
display: block;
position: absolute;
top: 0;
left: 0;
}
.overview_list{
flex-direction: column;
margin: 30px 0 0 0;
padding: 24px 0 0 0;
border-top: 1px solid var(--light-gray);
}
.overview_list li{
margin: 0 0 24px 0;
padding: 0 2px 24px 2px;
border-bottom: 1px solid var(--light-gray);
}
.overview_list li dl{
width: 100%;
flex-direction: column;
}
.overview_list li dt{
width: 100%;
}
.overview_list li dd{
width: 100%;
}
.overview_link{
font-size: var(--font-xxxl-sp);
}
.overview_link a{
margin: 0 3px 0 3px;
text-decoration: underline;
text-decoration-thickness: 2px;
text-underline-offset: 6px;
}
.overview_sub{
display: block;
margin: 4px 0 0 0;
}
.overview_list li dd > ol{
}
.overview_list li dd > ol li{
margin: 0;
border: none;
}

/* apply */
#apply{
margin: 0 0 -50px 0;
padding: 50px 0 80px 0;
border-radius: 30px;
top: -50px;
}
#apply h2{
height: 59px;
padding-top: 0;
}
#apply h2 span:nth-of-type(2){
padding-top: 32px;
background: url(../img/h2_apply.svg) no-repeat center bottom;
background-size: auto 32px;
}
#apply h2 span:nth-of-type(1){
margin: 0 0 15px 0;
padding-top: 12px;
background: url(../img/h2_apply_shoulder.svg) no-repeat center top;
background-size: auto 12px;
font-size: var(--font-xl);
overflow: hidden;
}

.apply_range{
margin: 20px 0 0 0;
font-size: var(--font-l-sp);
line-height: 1.6;
}

.apply_form{
width: 100%;
margin: 30px auto 0 auto;
}
.apply_form img{
width: 100%;
height: auto;
}
.apply_form iframe{
width: 100%;
height: auto;
}

/* */
/* */
}
/* -- */
/* -- */
/* SP */
/* -- */
/* -- */


@media screen and (max-width: 460px) {
.titBlock{
width: calc(100vw - 90px);
min-width: 238px;
max-width: 240px;
height: 100px;
flex-direction: column;
gap: 8px;
padding: 0 24px 0 20px;
background-color: var(--white);
border-bottom-right-radius: 50px;
}
#header h1{
width: 100%;
margin-top: 10px;
padding-top: 60px;
background: url(../img/h1_sp.svg) no-repeat left center;
background-size: contain;
font-size: var(--font-xxxl-sp);
line-height: 50px;
}
}
