@charset "UTF-8";
/*mainblue themecolor*/
/*mainyellow*/
/*link color*/
/*10*/
/*64*/
body, html { font-size: 16px; font-family: arial, sans-serif; line-height: 1.6; }

a { text-decoration: underline; color: #0D69CE; }
a:hover { text-decoration: none; color: #00a0e9; }

a, button:hover { cursor: pointer; }

/*test-align*/
.text-center { text-align: center; }

.text-left { text-align: left; }

.text-right { text-align: right; }

/*span block*/
.span_block { display: block; }

@media only screen and (max-width: 768px) { .span_block { display: inline; } }
/*KEY COLOR*/
.bg_yellow { background-color: #FFF200; }

.bg_blue { background-color: #00A0E9; }

/*font-size*/
.txt_ss { font-size: 0.625rem; }

.txt_small { font-size: 0.75rem; }

.txt_sm { font-size: 1.25rem; }

.txt_medium { font-size: 1.5rem; }

.txt_large { font-size: 3rem; }

.txt_big { font-size: 4rem; }

.mainimg-txt { font-size: 1.8rem; text-align: center; margin-bottom: 2em; }

/*font MQ*/
@media only screen and (max-width: 768px) { html, body, p { font-size: 14px; }
  .mainimg-txt { font-size: 1.3rem; text-align: left; }
  .txt_medium, .txt_sm { font-size: 1.285rem; }
  .txt_large, .txt_big { font-size: 1.428rem; } }
/* h */
h2 { font-size: 2.4rem; line-height: 2; margin: 2em 0; text-align: center; border-top: 2px solid #333; border-bottom: 2px solid #333; }

h3 { font-size: 1.2rem; border-left: 3px solid #00A0E9; padding: .1em 1em; margin: .5em 0; text-align: left; }

@media only screen and (max-width: 768px) { h2 { font-size: 1.666rem; line-height: 1.6; margin: 20px 0 10px; }
  h3 { font-size: 1rem; padding-left: .4rem; } }
/* meinvisual */
.videoimg { background: url(../haitatsu/img/movie01.jpg) no-repeat top center; background-size: cover; }
.videoimg img { width: 100%; height: auto; margin: 0 auto; text-align: center; }

/*chirashi*/
.chirashiimg_area figure { text-align: center; padding-top: 2em; }
.chirashiimg_area figure img { max-width: 100%; height: auto; margin: 0 auto; }

@media only screen and (max-width: 767px) { .chirashiimg_area { padding-bottom: 1rem; } }
/* hanbaijyo link */
.hanbaijyo { text-align: center; }

/*page-work*/
#page-work .shokusyu { padding-top: 2em; }
#page-work ul { margin: 0; padding-left: 0; }
#page-work ul li { list-style: none; padding-left: 0; }
#page-work ul p { margin-top: 0; }
#page-work h3.pagetitle { border-left: none; padding: 0; }
#page-work h3.pagetitle::before { content: "● "; color: #00A0E9; }
#page-work .gyomu h3.pagetitle::before { content: "● "; color: #FFF200; }

/* schedule
----------------------------------------- */
#schedule h3 { /*width:8em; */ text-align: center; background-color: #00A0E9; position: relative; margin: 0 0 1em 0; padding: 0.6em; font-size: 18px; font-weight: bold; }

/* sankaku */
#schedule h3:before { content: ""; position: absolute; bottom: -10px; left: 50%; margin-left: -6px; width: 0; height: 0; border-top: 10px solid #00a0e9; border-left: 6px solid transparent; border-right: 6px solid transparent; }

@media only screen and (max-width: 768px) { #schedule h3 { font-size: 14px; } }
.sc-ph { text-align: center; }

.sc-ph img { border: 2px solid #222; height: auto; margin: 0 auto; }

.sc-ph + p { text-align: center; }

/* message
----------------------------------------- */
.message-box { border-bottom: 2px dotted #CCC; margin-bottom: 3em; background-color: #BED988; }

.message-box dl { background-color: #FFF; }
.message-box dl dd { margin-left: 0; }

.people { text-align: center; padding: 1em; position: relative; margin-top: 15px; border-radius: 10px; text-align: center; }
.people img { margin: 0 auto; max-width: 200px; height: auto; }

/* sankaku */
.people:before { content: ""; position: absolute; bottom: -20px; left: 50%; margin-left: -10px; width: 0; height: 0; border-top: 20px solid #FFF; border-left: 10px solid transparent; border-right: 10px solid transparent; }

.message-box .circle-box { /*height: 50%;*/ height: auto; width: 50%; overflow: hidden; -webkit-border-radius: 100px; -moz-border-radius: 100px; border-radius: 100px; background-color: #FFFFFF; text-align: center; }

h4.mess-title { font-size: 18px; line-height: 1.6; text-align: left; }

@media only screen and (max-width: 768px) { h4.mess-title { font-size: 14px; } }
/* data 
----------------------------------------- */
.graph-png { text-align: center; }

/* Q&A
----------------------------------------- */
/* Q&A
----------------------------------------- */
#q-a { /*change toggle*/ }
#q-a ul.accordion { padding-left: 0; margin: 0 0 22px 0; border-bottom: 1px solid #e9e9e9; }
#q-a ul.accordion > li { list-style: none; margin: 0; padding: 0; }
#q-a ul.accordion > li h5, #q-a ul.accordion > li p { padding-right: 1.2em; }
#q-a ul.accordion > li > div.title { cursor: pointer; padding: 14px; margin: 0; position: relative; border-top: 1px solid #e9e9e9; background-color: #FAFAFA; }
#q-a ul.accordion > li > div.title h5 { margin: 0; font-weight: 400; font-size: 16px; }
#q-a ul.accordion > li.active > div.title { background-color: #cfecff; border-top: 1px solid #a0daff; }
#q-a ul.accordion > li .content { display: none; padding: 15px; border-top: 1px solid #e9e9e9; }
#q-a ul.accordion > li.active .content { background-color: #f3f3f3; }
#q-a ul.accordion > li.active .content { display: block; }

/*#q-a icon*/
#q-a .accordion h5 { padding-left: 36px; background: url(../haitatsu/img/qu.png) no-repeat left 3px; }
#q-a ul.accordion > li.active .content p:first-letter { background: url(../haitatsu/img/an.png) no-repeat top left; padding-left: 28px; }

/* #q-a after:: toggle mark */
#q-a ul.accordion > li > div.title:after { content: ""; display: block; width: 0; height: 0; border: solid 6px; border-color: transparent #9d9d9d transparent transparent; position: absolute; right: 15px; top: 21px; }
#q-a ul.accordion > li.active .title:after { content: ""; display: block; width: 0; height: 0; border: solid 6px; border-color: #9d9d9d transparent transparent transparent; }

/* #q-a transition */
#q-a ul.accordion > li.active .title, #q-a ul.accordion > li.active .content { transition: .4s; }

/* foundation accordion END*/
@media only screen and (max-width: 768px) { #q-a ul.accordion > li h5, #q-a ul.accordion > li p { font-size: 14px !important; } }
/* PAGE kitei */
#kitei h1 { font-size: 1.6rem; text-align: left; }
#kitei h2 { border: none; font-size: 1.2rem; text-align: left; font-weight: 400; }

@media only screen and (max-width: 768px) { #kitei h1 { font-size: 1.4rem; }
  #kitei h2 { font-size: 1rem; } }
/*----------------------
go-to-top
----------------------*/
#page_top { width: 50px; height: 50px; position: fixed; right: 20px; bottom: 20px; background: #222; opacity: 0.5; border-radius: 50%; z-index: 100; }

#page_top a { position: relative; display: block; width: 50px; height: 50px; text-decoration: none; }

#page_top a::before { font-family: "font Awesome 5 Free"; content: '\f106'; font-size: 25px; color: #fff; position: absolute; width: 25px; min-height: 25px; top: 4px; bottom: 0; right: 0; left: 0; margin: auto; text-align: center; font-weight: 900; /**/ }

/* SP pagetop_button_ichi */
@media only screen and (max-width: 460px) { #page_top { width: 40px; height: 40px; right: 5px; }
  #page_top a { width: 40px; height: 40px; }
  #page_top a::before { width: 20px; min-height: 20px; top: 0; } }
/*youtube*/
.movie { margin: 2em auto; }

#youtube_area { margin: 0 auto; }

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

.youtube iframe { text-align: center; position: absolute; top: 0; right: 0; width: 100%; height: 100%; }

/* fixedsticky area */
#fixedsticky_area { text-align: center; }
#fixedsticky_area p { margin: 0; padding: 0; }
#fixedsticky_area a { border-bottom: 0; text-decoration: none; }
#fixedsticky_area .btn-normal { background-color: #e8418d; border: none; color: #FFF; padding: 10px 20px; width: 100%; display: block; border-radius: 25px; }
#fixedsticky_area a.button:hover { opacity: .8; }

@media only screen and (max-width: 460px) { #fixedsticky_area a { font-size: 12px; }
  #fixedsticky_area a .btn-normal { background-color: #e8418d; border: none; color: #FFF; padding: 6px; } }
/* -45度斜めから25%、50%、75%、100%とボーダーが交互に色違いとなるように指定 */
.formbuttonarea { width: 100%; margin-top: 3em; padding: 10px 6rem; background-image: linear-gradient(-45deg, #fff 25%, #fce3ee 25%, #fce3ee 50%, #fff 50%, #fff 75%, #fce3ee 75%, #fce3ee); background-size: 8px 8px; }

@media only screen and (max-width: 460px) { .formbuttonarea { margin-top: 2em; padding: 6px 50px; } }
/*.fixedsticky*/
.fixedsticky { position: -webkit-sticky; position: -moz-sticky; position: -ms-sticky; position: -o-sticky; position: sticky; }

/* When position: sticky is supported but native behavior is ignored */
.fixedsticky-withoutfixedfixed .fixedsticky-off, .fixed-supported .fixedsticky-off { position: static; }

.fixedsticky-withoutfixedfixed .fixedsticky-on, .fixed-supported .fixedsticky-on { position: fixed; }

.fixedsticky-dummy { display: none; }

.fixedsticky-on + .fixedsticky-dummy { display: block; }

.fixedsticky { bottom: 0; }
