@charset "UTF-8";
/*
Version: 2.1.1
Creation Date: 2024.2.7
Last Updated: 2025.1.9
*/


/* Overwrite
------------------------------------------------------------ */
.header {
font-family: noto sans japanese, sans-serif;
position: fixed;
}
.spnav,
.spsubnav,
.gnav__subitem__table td a {
text-align: left;
}
.share__icon {
margin: 0;
}


/* set
------------------------------------------------------------ */
* {
margin: 0;
padding: 0;
font-style: normal;
box-sizing: border-box;
}
html {
font-size: 62.5%;
}
body {
-webkit-text-size-adjust: 100%;
background: #FFF;
font-family: ryo-gothic-plusn, sans-serif;
color: #000;
font-size: 1.8rem;
font-weight: 700;
line-height: 1.8;
text-align: center;
min-width: auto;
}
ul {
list-style: none;
}
img {
vertical-align: middle;
max-width: 100%;
height: auto;
}
video,iframe {
vertical-align: bottom;
max-width: 100%;
max-height: 100%;
border: none;
}
a {
color: inherit;
text-decoration: none;
}
.opa a:hover img {
opacity: .7;
}
:hover {
transition: .3s;
}
.smd,.smp,.flex.smd,.flex.smp {
display: none;
}
.pc {
display: block;
}
.pc.inline {
display: inline-block;
}
.flex.pc {
display: flex;
}


/* common
------------------------------------------------------------ */
/* layout */
main {
width: 100%;
margin-top: 120px;
display: block;
overflow: hidden;
}
article {
width: 100%;
position: relative;
}
main article {
margin-bottom: -1px;
}
section {
width: 1000px;
max-width: 90%;
margin: 0 auto;
padding: 8em 0 10em;
}

/* flexbox */
.flex {
display: flex;
}
.flex.wrap {
flex-wrap: wrap;
}
.col-2,
.col-3,
.col-4 {
flex-wrap: wrap;
justify-content: space-between;
}
.flex.row-end {
flex-direction: row-reverse;
}
.flex.end {
justify-content: flex-end;
}
.flex.center {
justify-content: center;
}
.flex.around {
justify-content: space-around;
}
.flex.start {
align-items: flex-start;
}
.flex.aligin-center {
align-items: center;
}
.flex.aligin-end {
align-items: flex-end;
}
.flex.column {
flex-direction: column;
}
.flex.column-end {
flex-direction: column-reverse;
}
.col-2 >* {flex-basis: 48%;}
.col-3 >* {flex-basis: 32%;}
.col-4 >* {flex-basis: 24%;}
.col-3::after {
content: "";
width: 32%;
height: 0;
display: block;
}
.col-4::before,
.col-4::after {
content: "";
width: 24%;
height: 0;
display: block;
}
.col-4::before {
order: 1;
}
.flex.end::before,
.flex.end::after {
display: none;
}

/* style */
.vwmax img {
width: 100vw;
}
main h2 {
margin-bottom: 3em;
}
main h3 {
margin-bottom: 2em;
}
.zidx1 {
position: relative;
z-index: 1;
}
.player::before,
.player::after {
content: "";
background-size: contain !important;
position: absolute;
}

/* .link */
.link {
text-align: center;
margin: 2em auto 0;
}
.link a {
background: #a69535;
color: #FFF;
font-size: 2.6rem;
line-height: 70px;
max-width: 100%;
height: 70px;
padding: 0 1em;
display: inline-block;
border-radius: 100vh;
position: relative;
z-index: 1;
transition: .5s;
}
.link a:hover {
transform: scale(1.1);
}

/* .box */
.box {
background: #FFF;
padding: 3em 4em;
border-radius: 2em;
}
.box figure {
align-items: flex-start;
text-align: left;
margin-bottom: 2em;
}
.box figure > div {
position: relative;
z-index: 1;
}
.box figure > div::after {
content: "";
background: #00ABEB;
width: 100%;
height: 100%;
border-radius: 2em;
position: absolute;
top: 10px;
left: 10px;
z-index: -1;
}
.box figure > div img {
border-radius: 2em;
}
.box figure:nth-of-type(2n) > div {
order: 1;
}
.box figcaption h3 {
color: #00ABEB;
font-size: 2.5rem;
font-weight: 700;
line-height: 1.5;
margin: 0 0 .5em;
}
.box figcaption h3 small {
font-size: 80%;
}
.box figcaption {
padding: 2em 0;
}
.box hr {
width: 30%;
margin: 3em auto;
border: none;
border-top: dotted 10px #00ABEB;
}
.col-3 >* {
max-width: 365px;
margin: 0 auto 2em;
}


/* main
------------------------------------------------------------ */
/* #about */
#about section {
color: #FFF;
padding: 3em 0;
position: absolute;
left: 50%;
bottom: 0;
transform: translateX(-50%);
}
#about div:not(.link) {
max-width: 35%;
position: absolute;
left: 1em;
bottom: 1em;
}
#about h2 {
margin: 1em auto;
}
#about p {
font-size: 2.4rem;
}
#about .link {
margin: 1em auto 0;
}

/* #enquete */
#enquete {
background: #FFF url("img/enquete_end.png") no-repeat bottom/100% auto;
}
#enquete section {
padding-bottom: 8em;
}
#enquete div + div {
margin-top: 3em;
}

/* #commit */
#commit {
background: #4cc4f1 url("img/commit_end.png") no-repeat bottom/100% auto;
}
#commit section {
padding-top: 2em;
}
#commit .box.player {
margin-bottom: 5em;
position: relative;
}
___#commit .box.player::before {
background: url("img/player_02.png") no-repeat top right;
width: 200px;
max-width: 20%;
height: 685px;
top: 50%;
left: -13%;
transform: translateY(-50%);
}
___#commit .box.player::after {
background: url("img/player_03.png") no-repeat bottom left;
width: 180px;
max-width: 18%;
height: 460px;
bottom: 0;
right: -13%;
z-index: 1;
}

/* #service */
#service {
background: #00abeb url("img/service_end.png") no-repeat bottom/100% auto;
}
#service section {
padding-top: 2em;
}
#service .box + h2 {
margin-top: 5em;
}
/* #schedule */
#schedule p.right {
display: none;
letter-spacing: .1em;
text-align: right;
margin-bottom: .5em;
}
@media screen and (max-width: 1100px) {
#schedule p.right {
display: block;
}
}
#schedule table {
width: 100%;
border-collapse: collapse;
margin-bottom: 2em;
display: block;
overflow-x: scroll;
white-space: nowrap;
-webkit-overflow-scrolling: touch;
}
#schedule table::-webkit-scrollbar {
height: 3px;
}
#schedule table::-webkit-scrollbar-thumb {
background: rgba(0, 0, 0, .1);
}
#schedule th {
background: #1A1A7C;
color: #FFF;
vertical-align: middle;
padding: .5rem 1.5rem;
border: 1px solid #FFF;
}
#schedule td {
background: #FFF;
font-weight: 500;
vertical-align: middle;
padding: .8rem 1.5rem;
border: 1px solid #1A1A7C;
}
#schedule td:last-child {
text-align: left;
}
#schedule p {
text-align: left;
}

/* #join */
#join {
background: #4cc4f1 url("img/join_end.png") no-repeat bottom/100% auto;
}
#join section {
padding-top: 2em;
}

/* #voice */
#voice {
background: #FFF url("img/voice_end.png") no-repeat bottom/100% auto;
}
#voice section {
width: 1150px;
padding-top: 2em;
}
#voice ul li {
background: 
url("img/voice_top.jpg") no-repeat top/100% auto,
url("img/voice_btm.jpg") no-repeat bottom/100% auto,
url("img/voice_bg.jpg") repeat-y center/100% auto;
max-width: 365px;
margin: 0 auto 1em;
padding: 70px 2em 35px;
}
#voice ul li:nth-child(even) {
margin-top: 2em;
}
#voice ul li div {
background: #00abeb;
color: #FFF;
line-height: 1.3;
width: 70px;
height: 70px;
margin: -50px auto 0 -20px;
padding-top: 10px;
border-radius: 50%;
position: relative;
z-index: 1;
}
#voice ul li div em {
font-size: 2.2rem;
}
#voice ul li p {
text-align: left;
background-image:
linear-gradient(90deg, transparent 0%, transparent 50%, #fff 50%, #fff 50%),
linear-gradient(180deg, transparent 0%, transparent 96%, #b2e6f9 96%, #b2e6f9 100%);
background-size: 8px 100%, 100% 1.8em;
}

/* #price */
#price {
background: #00abeb;
}
#price section {
padding: 2em 0 6em;
position: relative;
z-index: 1;
}
.price {
background: #FFF;
margin-bottom: 3rem;
padding: 5rem 3rem 3rem;
border-radius: 2rem;
border: 3px solid #1A1A7C;
position: relative;
}
.price.mount {
margin-top: 100px;
}
.price.mount::before {
content: "";
background: url("img/price_mount.png") no-repeat bottom/contain;
width: 160px;
height: 65px;
position: absolute;
top: -74px;
left: 50%;
transform: translateX(-50%);
}
.price::after {
content: "";
background: #1A1A7C;
width: calc(100% + 12px);
height: calc(100% + 6px);
border: 3px solid #1A1A7C;
border-radius: 2rem;
position: absolute;
top: -9px;
left: -15px;
z-index: -1;
}
.price dt {
flex-basis: 25%;
text-align: right;
margin-bottom: 2rem;
}
.price dd {
flex-basis: 70%;
text-align: left;
margin-bottom: 2rem;
}
.price dd ul li {
line-height: 1.4;
padding: 0 0 1rem 2rem;
position: relative;
}
.price dd ul li::before {
content: "・";
position: absolute;
top: 0;
left: 0;
}


/* footer
------------------------------------------------------------ */
footer {
background: #000;
}
footer section {
padding: 6rem 0;
}
footer h1 {
width: 188px;
margin: 0 auto 3rem;
}
footer p {
color: #FFF;
font-size: 1.2rem;
line-height: 1.3;
}
footer p + p {
font-size: 1.1rem;
margin-top: 1rem;
}

/* #sns */
#sns {
background: #FFF;
}





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

/* set
------------------------------------------------------------ */
html {
font-size: 58%;
}
.pc,.pc.inline,.flex.pc {
display: none;
}
.smd,
.smd-block {
display: block;
}
.flex.smd {
display: flex;
}

/* common
------------------------------------------------------------ */
/* layout */
main {
margin-top: 60px;
}

/* .link */
.link a {
font-size: 1.8rem;
line-height: 60px;
height: 60px;
}

/* .box */
.box {
padding: 3em;
border-radius: 1em;
}
.box hr {
margin: 1em auto 3em;
}

/* main
------------------------------------------------------------ */
/* #enquete */
#enquete section {
padding-top: 4em;
}

/* #commit */
#commit .box.player::before,
#commit .box.player::after {
display: none;
}

/* #voice */
#voice ul li:nth-child(even) {
margin-top: 1em;
}

}


@media screen and (max-width: 430px) {

/* set
------------------------------------------------------------ */
.smd,.flex.smd,.smp-none {
display: none;
}
.smp,
.smp-block {
display: block;
}
.flex.smp {
display: flex;
}
br.smp {
font-size: 0;
}

/* common
------------------------------------------------------------ */
/* layout */
section {
padding: 4em 0 5em;
}

/* flexbox */
.col-2 {display: block;}
.col-3 >* {flex-basis: 48%;}
.col-4 >* {flex-basis: 48%;}
.col-3:after,
.col-4:before,
.col-4:after {
display: none;
}

/* style */
main h2 {
margin-bottom: 1.5em;
}
main h2 img {
width: 100%;
}
main h3 {
margin-bottom: 1em;
}

/* .box */
.box {
padding: 1em;
}
.box figure {
margin-bottom: 1em;
}

/* main
------------------------------------------------------------ */
/* #about */
#about figure.vwmax {
display: none;
}
#about {
background: rgba(66,33,11,.3) url("img/about_bg.jpg") no-repeat center/cover;
background-blend-mode: multiply;
}
#about section {
position: static;
transform: translateX(0);
}
#about p {
font-size: 2rem;
}

/* #enquete */
#enquete section {
padding: 2em 0;
}
#enquete div + div {
margin-top: 1em;
}

/* #commit */
#commit h2::before {
display: none;
}
#commit .box.player {
margin-bottom: 2em;
}

/* #price */
.price {
padding: 5rem 2rem 2rem;
}
.price dt {
text-align: center;
padding-bottom: 1rem;
border-bottom: 1px solid #1A1A7C;
}
.price dd {
margin-bottom: 3rem;
}

}