@charset "utf-8";
/*
Theme Name: CHARLES
*/


/*reset*/
/*******************************************************************/
html{box-sizing:border-box;overflow-y:scroll;-webkit-text-size-adjust:100%}*,:after,:before{background-repeat:no-repeat;box-sizing:inherit}:after,:before{text-decoration:inherit;vertical-align:inherit}*{padding:0;margin:0}audio:not([controls]){display:none;height:0}hr{overflow:visible}article,aside,details,figcaption,figure,footer,header,main,menu,nav,section,summary{display:block}summary{display:list-item}small{font-size:80%}[hidden],template{display:none}abbr[title]{border-bottom:1px dotted;text-decoration:none}a{background-color:transparent;-webkit-text-decoration-skip:objects}a:active,a:hover{outline-width:0}code,kbd,pre,samp{font-family:monospace,monospace}b,strong{font-weight:bolder}dfn{font-style:italic}mark{background-color:#ff0;color:#000}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}input{border-radius:0}[role=button],[type=button],[type=reset],[type=submit],button{cursor:pointer}[disabled]{cursor:default}[type=number]{width:auto}[type=search]{-webkit-appearance:textfield}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}textarea{overflow:auto;resize:vertical}button,input,optgroup,select,textarea{font:inherit}optgroup{font-weight:700}button{overflow:visible}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:0;padding:0}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button:-moz-focusring{outline:1px dotted ButtonText}[type=reset],[type=submit],button,html [type=button]{-webkit-appearance:button}button,select{text-transform:none}button,input,select,textarea{background-color:transparent;border-style:none;color:inherit}select{-moz-appearance:none;-webkit-appearance:none}select::-ms-expand{display:none}select::-ms-value{color:currentColor}legend{border:0;color:inherit;display:table;max-width:100%;white-space:normal}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}img{width:auto;max-width:100%;height:auto;border-style:none;vertical-align:middle;-webkit-backface-visibility:hidden}i{vertical-align:middle}progress{vertical-align:baseline}svg:not(:root){overflow:hidden}audio,canvas,progress,video{display:inline-block}@media screen{[hidden~=screen]{display:inherit}[hidden~=screen]:not(:active):not(:focus):not(:target){position:absolute!important;clip:rect(0 0 0 0)!important}}[aria-busy=true]{cursor:progress}[aria-controls]{cursor:pointer}[aria-disabled]{cursor:default}::-moz-selection{background-color:#b3d4fc;color:#000;text-shadow:none}::selection{background-color:#b3d4fc;color:#000;text-shadow:none}ul,ol{list-style:none}i{font-style:normal}picture{display:block}
a { color: #333; transition: all .2s ease-out; text-decoration: none;}
*:focus { outline: none;}


/*LAYOUT*/
/*******************************************************************/
html { font-size: 62.5%;}
body { -webkit-text-size-adjust: 100%; -webkit-overflow-scrolling: touch; height: 100%; font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif"; font-size: 1.5rem; font-weight: 500; line-height: 1.6; color: #333;}
#container { position: relative; width: 100%; overflow: hidden;}
#loading { z-index: 100000; position: fixed; top: 0; left: 0; right: 0; bottom: 0; margin: auto; background: #FFF url("img/common/logo.svg") center center no-repeat;}
#loading::after { content: ''; position: absolute; top: calc(50% - 38px - 40px); left: 50%; transform: translateX(-50%); width: 38px; height: 38px; background: url("img/common/loading.svg") center no-repeat;}


/*HEADER*/
/*******************************************************************/
#container > h1 { padding: 2px; background: #292929; font-size: 1.1rem; color: #FFF;} 
#header { position: relative; top: 0; left: 0; display: flex; justify-content: space-between; align-items: center; width: 100%; height: 48px; background: #FFF; line-height: 1; box-shadow: 0 3px 40px rgba(0,0,0,.07); z-index: 100;}
#header.is-fixed { position: fixed;}
#header.is-fixed + * { margin-top: 48px;}
#logo { width: calc(100% - 144px); padding: 0 16px 0 8px;}
#logo img { height: 34px;}
#contact img, #line img { height: 48px;}
#nav { pointer-events: none; opacity: 0; position: fixed; top: -40px; left: 0; display: flex; flex-direction: column; justify-content: center; align-items: center; width: 100%; height: 100vh; margin: 0; padding: 40px 4vw; background: rgba(11,11,11,.9); overflow: auto; z-index: 200; -webkit-transition: .8s cubic-bezier(.19,1,.22,1); transition: .8s cubic-bezier(.19,1,.22,1);}
#nav li { padding: 12px 0; text-align: center;}
#nav a { font-size: 2rem; font-weight: bold; letter-spacing: 0.2em; color: #FFF;}
#open { display: block; width: 48px; height: 48px; text-align: center; z-index: 300; cursor: pointer;}
#open div { position: relative; display: block; width: 26px; height: 26px; margin: 6px 12px; transition: .2s linear;}
#open span { position: absolute; left: 0; display: block; width: 26px; height: 3px; background: #000; transition: .2s linear;}
#open span:nth-child(1) { top: 8px;}
#open span:nth-child(2) { top: 16px;}
#open span:nth-child(3) { top: 24px;}
.open #open span:nth-child(1) { top: 16px; background: #FFF; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); transform: rotate(45deg);}
.open #open span:nth-child(2) { width: 0; left: -24px;}
.open #open span:nth-child(3) { top: 16px; background: #FFF; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); transform: rotate(-45deg);}
.open #nav { pointer-events: auto; opacity: 1; top: 0;}
.open #nav li { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0);}


/*FOOTER*/
/*******************************************************************/
.info { position: relative; background: #292929; color: #FFF;}
.info ul { display: flex; flex-wrap: wrap;}
.info li { width: 50%; border-bottom: 1px solid #545454;}
.info li:nth-child(even) { border-left: 1px solid #545454;}
.info li a { display: block; padding: 16px 8px; text-align: center; color: #FFF;}
.info p { padding: 24px 0; text-align: center;}
.info p img { height: 34px;}
.info address { padding-bottom: 24px; text-align: center; font-size: 1.2rem; font-style: normal; color: #969696;}
#pagetop { position: absolute; right: 16px; bottom: 16px;}
#pagetop a { display: block; width: 22px; height: 22px;}


/*CONTENTS*/
/*******************************************************************/
article { padding: 20px;}
article header { position: relative; margin-bottom: 16px; text-align: center;}
article header h2 { font-size: 6vw; color: #5ac1b5;}
article header figure + h2 { position: absolute; top: 50%; left: 0; transform: translateY(-50%); width: 100%; color: #5ac1b5;}
article header.centerbar { display: flex; justify-content: center; align-items: center;}
article header.centerbar::before, article header.centerbar::after { content: ''; width: 8vw; height: 1px; margin: 0 8px; background: #686868;}
section + section { margin-top: 40px;}
section p { margin-bottom: 20px;}
figure { position: relative;}
figure > img { width: 100%; height: auto;}
.center { text-align: center;}
.right { text-align: right;}
.pc { display: none;}
.yellow { color: #ffef34!important;}
.darkyellow { color: #ffb400!important;}
.green { color: #3ebcad!important;}
.blue { color: #38a2cc!important;}
.pink { color: #e389a5!important;}
.orange { color: #e9a340!important;}
.fs13 { font-size: 1.3rem;}
.fs16 { font-size: 1.6rem;}
.fs20 { font-size: 2rem;}
.fs30 { font-size: 3rem;}
.fs40 { font-size: 4rem;}
.mb0 { margin-bottom: 0;}
.mb20 { margin-bottom: 20px;}
.pt80 { padding-top: 80px;}
.marker, .merit strong { background: linear-gradient(transparent 60%, #fffc80 60%); font-weight: bold;}
.updot { padding-top: .4em; background-position: top left -2px; background-repeat: repeat-x; background-size: 1.1em .3em; background-image: radial-gradient(.12em .12em at center center,#5ac1b5,#5ac1b5 100%,transparent);}
.fukidashi { display: flex; justify-content: center; align-items: flex-end;}
.fukidashi::before, .fukidashi::after { content: ''; display: inline-block; transform: rotate(45deg); width: 1px; height: 1.3em; margin: 0 12px; background: #5ac1b5;}
.fukidashi::before { transform: rotate(-45deg);}
.fadeInUp{ -webkit-animation-name: fadeInUp; animation-name: fadeInUp;}
@-webkit-keyframes fadeInUp { from { opacity: 0; -webkit-transform: translate3d(0, 10%, 0); transform: translate3d(0, 10%, 0);} to { opacity: 1; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0);} }
@keyframes fadeInUp { from { opacity: 0; -webkit-transform: translate3d(0, 10%, 0); transform: translate3d(0, 10%, 0);} to { opacity: 1; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0);} }
.animated { opacity: 0; -webkit-animation-duration: 1s; animation-duration: 1s; -webkit-animation-fill-mode: both; animation-fill-mode: both;}
.contact { padding: 16px; text-align: center; background: url("img/common/diagonal.png") 0 0 repeat;}
.btn a { display: flex; justify-content: center; align-items: center; width: calc(100% - 16px); padding: 16px; text-align: center; background: rgb(56,162,204); background: linear-gradient(0deg, rgba(56,162,204,1) 0%, rgba(111,206,244,1) 100%); border-radius: 56px; font-size: 1.8rem; font-weight: bold; letter-spacing: 0.12em; color: #FFF; box-shadow: 0 5px 0 #1a90bf;}
.btn a::after { content: ''; width: 10px; height: 17px; margin-left: 8px; background: url("img/common/arr_w.svg") center no-repeat; background-size: 10px 17px;}
.btn a.alt { background: rgb(224,111,146); background: linear-gradient(0deg, rgba(224,111,146,1) 0%, rgba(241,175,195,1) 100%); box-shadow: 0 5px 0 #d85880;}
.btn + .line { margin-top: 16px;}
.line { display: flex; justify-content: center; align-items: center; font-weight: bold; color: #53b535;}
.line::before { content: ''; width: 32px; height: 32px; margin-right: 8px; background: url("img/common/line.svg") center no-repeat;}
.line a { display: flex; justify-content: center; align-items: center; margin-left: 8px; padding: 10px 16px; text-align: center; background: #53b434; border-radius: 8px; font-weight: bold; letter-spacing: 0.12em; color: #FFF;}
.line a::after { content: ''; width: 10px; height: 17px; margin-left: 8px; background: url("img/common/arr_w.svg") center no-repeat; background-size: 10px 17px;}
.line + * { margin-top: 16px;}
.more { text-align: center;}
.more a { display: flex; justify-content: center; align-items: center; padding: 8px; border: 3px solid #5ac1b5; font-size: 2rem; font-weight: bold; color: #5ac1b5;}
.more a::before { content: ''; width: 20px; height: 20px; margin-right: 8px; background: #5ac1b5 url("img/common/arr_w.svg") center no-repeat; background-size: auto 14px; border-radius: 50%;}
.more a.alt { background-color: #FFF; border-color: #e389a5; color: #e389a5;}
.more a.alt::before { background-color: #e389a5;}
.link a { display: flex; justify-content: flex-end; align-items: center; font-weight: bold; text-decoration: underline; color: #3597d5;}
.link a::before { content: ''; width: 16px; height: 16px; margin-left: 8px; background: #3597d5 url("img/common/arr_w.svg") center no-repeat; background-size: 6px 13px; border-radius: 50%;}
.box { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); padding: 20px; background: #5ac1b5; color: #FFF;}
.box + * { margin-top: 20px;}
.box.dot, .contact.dot { background: url("img/common/dot.png") center repeat; color: #333;}
.box.alt { background: #f8e4ea; color: #333;}
.fit { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw);}
.fit img { width: 100%;}
.polkadot { background: url("img/common/polkadot.png") center repeat;}


#mv { padding: 0; text-align: center; background: #F5F5F5;}
#mv div { width: 100%; padding: 8px; background: #292929; font-size: 4vw; font-weight: bold; color: #FFF;}
.infolist li { margin-bottom: 16px; padding-bottom: 16px; border-bottom: 3px dotted #d6d6d6;}
.infolist li a { display: flex; justify-content: space-between;}
.infolist li a > figure { width: 30%;}
.infolist li a > div { width: calc(70% - 20px);}
.infolist li p { margin: 0!important; font-size: 1.6rem; line-height: 1.2;}
.infolist li time { display: block; text-align: right;}
.cat { display: inline-block; margin-bottom: 4px; padding: 2px 4px; background: #5ac1b5; font-size: 1.3rem; color: #FFF;}
.cat a { color: #FFF;}

.ranklist li { margin-bottom: 16px; padding-bottom: 16px; border-bottom: 3px dotted #d6d6d6;}
.ranklist li a { display: flex; justify-content: space-between; align-items: flex-end;}
.ranklist li a > figure { width: 40%;}
.ranklist li a > figure figcaption { width: 70%; margin: 0 auto 16px;}
.ranklist li a > div { width: calc(60% - 20px);}
.ranklist h3 { margin-bottom: 8px; color: #e389a5;}
.ranklist .area { display: flex; align-items: center;}
.ranklist .area dt { padding: 0 4px; background: #e389a5; border-radius: 4px; color: #FFF; white-space: nowrap;}
.ranklist .area dd { flex: 1; padding-left: 8px;}
.star { position: relative; display: inline-block; font-size: 3.2rem; color: #e6e6e6; white-space: nowrap;}
.star .rate { position: absolute; top: 0; left: 0; display: inline-block; width: 0%; color: #e389a5; white-space: nowrap; overflow: hidden;}
.rating span { font-size: 1.8rem; font-weight: bold; color: #e389a5;}
.voice { padding-left: 32px; background: url("img/common/voice.png") left center no-repeat; background-size: 26px 21px;}
.voice span { font-size: 1.8rem; font-weight: bold; color: #5ac1b5;}

.flow li { position: relative; margin: 0 calc(50% - 50vw) 40px; padding: 20px; background: #dcedf4;}
.flow li:not(:last-child)::after { content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); width: 0; height: 0; border-style: solid; border-width: 20px 25px 0 25px; border-color: #dcedf4 transparent transparent transparent;}
.flow li h3 { margin-bottom: 16px; text-align: center; font-size: 2rem; color: #5ac1b5;}
.flow li figure { margin-bottom: 16px; text-align: center;}
.reason { margin-top: 40px; background: rgb(90,193,181); background: linear-gradient(0deg, rgba(90,193,181,1) 0%, rgba(90,155,193,1) 100%);}
.reason ul { display: flex; flex-wrap: wrap; justify-content: center; margin-top: 16px;}
.reason li { width: 30%; margin: 1.5%;}
#pu { pointer-events: none; opacity: 0; transition: opacity 0.3s ease-out; position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; display: flex; justify-content: center; align-items: center; background: rgba(0,0,0,.2); z-index: 50;}
#pu.active { pointer-events: auto;  opacity: 1;}
#pu img { max-height: calc(90vh - 48px);}
.interviewlist > li { margin-bottom: 16px; padding-bottom: 16px; border-bottom: 3px dotted #FFF;}
.prof { display: flex; justify-content: space-between; margin-bottom: 16px;}
.prof > figure img { width: 56px; height: 56px; border-radius: 50%;}
.prof > div { flex: 1; margin-left: 16px;}
.prof h3 { font-size: 1.3rem; color: #e389a5;}
.prof h3 strong { font-size: 1.7rem;}
.prof li { display: inline-block; padding: 1px 4px; background: #e389a5; border-radius: 4px; font-size: 1.3rem; font-weight: bold; color: #FFF;}
.prof dt { font-size: 1.2rem; font-weight: bold;}
.prof dd { margin-bottom: 4px; font-weight: bold; color: #e389a5}
.prof dd a { text-decoration: underline; color: #e389a5}
.prof dd span { display: inline-block;}
.prof .star { font-size: 2.4rem; color: #CCC;}
.prof .star .rate { color: #ffb400;}
.interview { padding: 16px; background: #FFF; border-radius: 8px;}
.interview dt { margin-bottom: 8px; font-weight: bold; color: #e389a5;}
.interview dd p { margin-bottom: 0;}
.interview dd a { text-decoration: underline; color: #e389a5;}
.tag dt { padding: 4px; text-align: center; background: #e9a340; border-radius: 8px 8px 0 0; font-size: 2rem; font-weight: bold; color: #FFF;}
.tag dd { margin-bottom: 24px; padding: 16px; background: #FFF; border: 3px solid #e9a340; border-radius: 0 0 8px 8px; box-shadow: 0 10px 14px rgba(225,195,152,.4);}
.tag.alt dt { background: #5ac1b5;}
.tag.alt dd { border-color: #5ac1b5;}
.case dd { text-align: center;}
.case p { height: 4.8em; text-align: left; overflow: hidden;}
.case .moretext { display: inline-block;}
.case .moretext::after { content: ''; display: inline-block; width: 18px; height: 10px; margin-left: 8px; background: url("img/common/down.svg") right center no-repeat;}
.case dd.active p { height: 100%;}
.case dd.active .moretext::after { transform-origin: center; transform: rotate(180deg);}
.interviewlist.alt li > a { display: block; padding-right: 16px; background: url("img/common/arr_pink.svg") right center no-repeat;}
.interviewlist.alt .prof { margin-bottom: 0;}
.interviewlist.alt .prof figure img { width: 88px; height: 88px; border-radius: 0;}
.interviewlist.alt .prof figure.large { width: 46%;}
.interviewlist.alt .prof figure.large img { width: 100%; height: auto; border-radius: 0;}
.interviewlist.alt .prof p { margin: 8px 0 0; font-weight: bold;}
.interviewlist h4 { font-size: 2.2rem; line-height: 1.4; margin-bottom: 8px; color: #e389a5;}

#pagenav { display: flex;}
#pagenav ul { display: flex; justify-content: space-between; width: 100%; margin: 4px;}
#pagenav li { display: flex; flex: 1; margin: 4px;}
#pagenav li a { display: flex; justify-content: center; align-items: center; width: 100%; padding: 12px 4px; background: #f0f0f0; border: 1px solid #bfbebf; border-radius: 4px; font-size: 2.8vw;}

.heading { position: relative; margin: 0 calc(50% - 50vw) 32px; padding: 8px; text-align: center; background: #5ac1b5; font-size: 5.6vw; color: #FFF;}
.heading::after { content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); width: 0; height: 0; border-style: solid; border-width: 16px 20px 0 20px; border-color: #5ac1b5 transparent transparent transparent;}
.heading.alt { background-color: #e389a5;}
.heading.alt::after { border-top-color: #e389a5;}
.heading.alt2 { background-color: #6fc5db;}
.heading.alt2::after { border-top-color: #6fc5db;}

.answer_body { position: relative; cursor: pointer;}
.answer_body::after { content: ''; position: absolute; top: 50%; right: 8px; transform: rotate(45deg); display: block; width: 10px; height: 10px; border-bottom: 2px solid #949494; border-right: 2px solid #949494;}
.answer_body.on::after { position: relative; transform: rotate(-135deg); margin: 0 auto 8px;} 
.question { margin-bottom: 8px; padding: 16px 24px 8px 56px; background: url("img/faq/que.svg") 8px 16px no-repeat; border-top: 3px dotted #c3c3c3; font-weight: bold;}
.answer { display: none; padding: 8px 8px 8px 56px; background: #e6f3f2 url("img/faq/ans.svg") 8px 8px no-repeat; border-radius: 4px;}
.question span, .answer span { display: none;}
.hide { display: none;}

.select { position: relative;}
.select::after { content: ''; position: absolute; top: calc(50% - 8px); right: 16px; transform: rotate(45deg); display: block; width: 10px; height: 10px; border-bottom: 2px solid #949494; border-right: 2px solid #949494;}
.anchor { width: 100%; padding: 8px; text-align: center; border: 1px solid #2c2c2c; border-radius: 5px;}

.areaname a { display: flex; justify-content: space-between; align-items: center; margin: 0 calc(50% - 50vw); padding: 8px 20px; background: #5ac1b5; color: #FFF;}
.areaname a span { margin-left: auto; font-size: 1.3rem;}
.areaname a::after { content: ''; display: inline-block; transform: rotate(-45deg); display: block; width: 7px; height: 7px; border-bottom: 1px solid #FFF; border-right: 1px solid #FFF;}
.shoplist { margin: 0 calc(50% - 50vw); padding-bottom: 8px; background: #e9e9e9;}
.shoplist li { margin-bottom: 16px; padding: 20px; background: #FFF;}
.shoplist li .explanation { font-size: 1.3rem;}
.shoplist li figure { margin: 8px 0;}
.shoplist li h3 { font-size: 2rem;}
.shoplist li h3 span { display: inline-block; margin-right: 8px; padding: 1px 8px; vertical-align: middle; background: #5ac1b5; border-radius: 4px; font-size: 1.6rem; color: #FFF;}
.shoplist li .meta { display: flex; flex-wrap: wrap;}
.shoplist li .meta div { margin: 8px 8px 0 0; padding: 1px 4px; background: #f0f0f0; border-radius: 4px; font-size: 1.2rem;}

#shop { padding: 0;}
#shop section { padding: 0 20px;}
#shop section h3 { font-size: 2rem;}
#shop section h3 span { font-size: 1.3rem;}
#shop section div a { font-size: 1.3rem; text-decoration: underline; color: #6fc5db;}
#shop section .star { margin: 0 4px; font-size: 2rem;}
#shop section .star .rate { color: #ffb400;}
.swiper-container { margin: 0 -20px 16px;}
.swiper-pagination { margin-top: 16px; position: relative;}

.movie { margin: 0 calc(50% - 50vw); padding: 16px 20px 16px 64px; background: #6fc5db url("img/shop/movie.png") 20px center no-repeat; background-size: 34px 24px; font-size: 5.6vw; font-weight: bold; color: #FFF;}
.youtube { position: relative; margin: 0 calc(50% - 50vw) 20px; padding-top: 56.25%;}
.youtube iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%;}
.teach { display: block; padding-bottom: 16px; background: url("img/shop/teach.svg") center bottom no-repeat;}

.merittitle { margin-bottom: 16px; text-align: center;}
.merittitle div img { height: 22px;}
.merittitle .st { margin-top: 8px; font-size: 2rem; color: #6fc5db;}
.merittitle .st strong { display: inline-block; padding: 1px 8px; vertical-align: middle; background: url("img/common/wave.png") center bottom repeat-x; border: 1px solid #6fc5db; font-size: 2.4rem; color: #2e2e2e;}
.merit strong { color: #6fc5db;}

.proftext { margin-bottom: 16px; text-align: center; letter-spacing: 0.5em;}
.shop { padding: 0; text-align: center; background: #d0ecf4;}
.shop h2 { padding: 8px 20px; background: #6fc5db; color: #FFF;}
.shop section { padding: 20px;}
.shoplink a { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; padding-right: 16px; background: url("img/common/arr_blue.svg") right center no-repeat;}
.shoplink a > figure { width: 46%;}
.shoplink a > div { flex: 1; margin-left: 16px; text-align: left; font-size: 1.3rem;}
.shoplink a > div h3 { margin-bottom: 8px;}
.shoplink a > div h3 strong{ font-size: 2rem;}
.shoplink a > div div { font-weight: bold; color: #6fc5db;}
.shoplink a > div .star { margin-right: 4px; font-size: 2rem; color: #FFF;}
.shoplink a > div .star .rate { color: #ffb400;}
.questionnaire { padding-top: 8px; border-top: 3px dotted #e389a5;}
.questionnaire dt { font-size: 1.3rem; font-weight: bold; color: #e389a5;}
.questionnaire dd { margin: 4px -20px; padding: 8px 20px; background: #fff2f6; font-size: 1.8rem;}
.times { font-family: "Times New Roman", Times, "serif"; font-size: 7.2rem; font-weight: normal; line-height: 1.2; color: #fffec6;}
.times span { font-size: 5.6rem; color: #FFF;}
.normal { font-weight: normal;}
.qa li { display: flex; justify-content: space-between; margin-bottom: 20px;}
.qa li figure { width: 60px;}
.qa li figure img { border-radius: 50%;}
.qa li figure figcaption { text-align: center; font-size: 1rem; letter-spacing: -0.1em;}
.qa li div { position: relative; flex: 1; margin-left: 16px; padding: 8px; background: #e389a5; border: 2px solid #e389a5; border-radius: 12px; color: #FFF;}
.qa li div::after { content: ''; position: absolute; top: 16px; left: -14px; width: 14px; height: 19px; background: url("img/voice/serif.png") 0 0 no-repeat; background-size: 14px 19px;}
.qa li div p { margin-bottom: 0;}
.qa li.staff { flex-direction: row-reverse;}
.qa li.staff div { margin-left: 0; margin-right: 16px; background: transparent; color: #333;}
.qa li.staff div::after { left: auto; right: -14px; background-image: url("img/voice/serif_border.png");}
.company { border-top: 1px dashed #333;}
.company dt { padding-top: 16px; font-weight: bold;}
.company dd { padding-bottom: 16px; border-bottom: 1px dashed #333;}

.blogslide { padding: 10px 20px 0;}
.slide-caption { position: absolute; bottom: 0; left: 0; width: calc(100% - 16px); padding: 8px; background: rgba(51,51,51,.75); color: #FFF;}
.slide-caption .cat { background: transparent; font-weight: bold; color: #5ac1b5;}
.slide-caption p { margin-bottom: 0; font-size: 1.2rem;}
.swiper-button-next:after, .swiper-button-prev:after { display: flex; justify-content: center; align-items: center; width: 40px; height: 40px; background: #5ac1b5; border-radius: 50%; font-size: 14px; color: #FFF;}
.swiper-button-next { right: -6px;}
.swiper-button-prev { left: -6px;}
.swiper-button-next, .swiper-button-prev { width: 40px;}

.pagination { display: flex; margin: 20px -20px; text-align: center; line-height: 1; font-family: Arial, Helvetica, YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif"; font-weight: bold;}
.pagination li { flex: 1; background: #eee; border: 1px solid #bfbebf; color: #a7a7a7;}
.pagination li:first-child, .pagination li:last-child { max-width: 60px;}
.pagination li a, .pagination li span { display: block; padding: 16px 8px;}
.pagination li a { background: #888; color: #FFF;}
.category { display: flex; flex-wrap: wrap; margin: 8px -4px;}
.category li { margin: 4px;}
.category li a { display: block; padding: 4px; background: #e9e9e9; border-radius: 32px; font-size: 1rem; font-weight: bold;}

.aboutshop { margin: 0 -20px; padding: 20px; border-top: 1px solid #bfbebf;}
.aboutshop > div { padding: 20px; border: 2px solid #bfbebf; border-radius: 12px;}
.aboutshop .row { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; margin-bottom: 8px;}
.aboutshop .row > figure { width: 56px;}
.aboutshop .row > figure img { width: 56px; height: 56px; border-radius: 50%;}
.aboutshop .row > div { margin-left: 16px; font-size: 1.3rem;}
.aboutshop .row .star { font-size: 1.6rem;}
.aboutshop .row .star .rate { color: #ffb400;}
.aboutshoplink a { display: block; padding: 8px; text-align: center; background: #0d0200; font-weight: bold; color: #FFF;}

#blog header { text-align: left;}
#blog header h2 { line-height: 1.2; color: #333;}
#blog header time { display: block; text-align: right;}
.mainimg { position: relative; margin-bottom: 20px;}
.mainimg figcaption { position: absolute; bottom: 4px; left: 4px; display: flex; align-items: center; font-weight: bold; color: #FFF; z-index: 10;}
.mainimg figcaption span { margin-right: 8px;}
.mainimg figcaption span img { width: 56px; height: 56px; border-radius: 56px;}
#ez-toc-container { width: 100%; margin-bottom: 20px; padding: 16px; background: #f9f9f9; border-top: 5px solid #5ac1b5; box-shadow: 0 3px 7px rgba(0,0,0,.1);}
#ez-toc-container .ez-toc-title-container { text-align: center;}
#ez-toc-container .ez-toc-title { text-align: center!important; font-size: 2rem; font-weight: bold; color: #5ac1b5;}
#ez-toc-container ul { margin-left: 1em; list-style: disc;}
#ez-toc-container .ez-toc-list > li { margin-top: 16px;}
#ez-toc-container .ez-toc-list li a { font-weight: bold; color: #5ac1b5;}
#ez-toc-container .ez-toc-list li li a { font-size: 1.3rem; font-weight: normal;}

#body h2 { position: relative; margin: 60px calc(50% - 50vw) 32px; padding: 8px 20px; background: #dbf2ef; font-size: 5.6vw;}
#body h2::after { content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); width: 0; height: 0; border-style: solid; border-width: 16px 20px 0 20px; border-color: #dbf2ef transparent transparent transparent;}
#body h3 { margin: 30px 0 20px; border-bottom: 3px solid #5ac1b5; font-size: 1.8rem;}
#body h4 { margin: 20px 0;}
#body ul:not(.ez-toc-list):not(.ez-toc-list-level-1):not(.ez-toc-list-level-2):not(.ez-toc-list-level-3):not(.ez-toc-list-level-4):not(.ez-toc-list-level-5) { margin: 20px 0;}
#body ul:not(.ez-toc-list):not(.ez-toc-list-level-1):not(.ez-toc-list-level-2):not(.ez-toc-list-level-3):not(.ez-toc-list-level-4):not(.ez-toc-list-level-5) li { display: table; margin: 4px 0; padding: 2px 8px 2px 4px; background: #df5794; font-size: 1.8rem; font-weight: bold;  color: #FFF;}
#body ul:not(.ez-toc-list):not(.ez-toc-list-level-1):not(.ez-toc-list-level-2):not(.ez-toc-list-level-3):not(.ez-toc-list-level-4):not(.ez-toc-list-level-5) li::before { content: '・';}
#body strong { color: #df5794;}
#body .marker { background: linear-gradient(transparent 60%, #ffe5ef 60%);}
.alignright { float: right; margin-left: 3em; margin-bottom: 2em;}
.alignleft { float: left; margin-right: 3em; margin-bottom: 2em;}
.aligncenter { display: block; margin-left: auto; margin-right: auto; text-align: center;}
.size-thumbnail { max-width: 250px;}

.contactform input, .contactform select, .contactform textarea { width: 100%; max-width: 100%; min-height: 48px; padding: 8px; vertical-align: middle; border: 2px solid #acacac; border-radius: 8px; background-color: #FFF; font-size: 17.44px;}
.colorbox { border-color: #5ac1b4!important; background-color: #f6fefd!important;}
.contactform select { width: auto;}
.contactform select.birth_year, .contactform select.birth_month, .contactform select.birth_day, .contactform select.month, .contactform select.time, .contactform select.day { display: inline-block; padding: 0 24px 0 12px;}
.contactform select.area { display: inline-block; margin-right: 8px;}
.contactform input.shopname { display: inline-block; width: 60%;}
.contactform textarea { height: 180px;}
.contactform input[type='checkbox'] { line-height: 1; display: inline-block; vertical-align: middle; width: 16px; height: 16px; min-height: initial; margin-right: 4px; padding: 0; border: 1px solid #5ac1b5; border-radius: 0; box-shadow: 0 0 0 transparent inset; appearance: none;}
.contactform input[type='checkbox']:checked { background-color: #5ac1b5;}
.contactform label { line-height: 1; padding: 6px; background-color: #e9e9e9; border-radius: 8px;}
.contactform span.unit { display: inline-block; padding: 0 8px; font-weight: bold;}
.contactform ::-webkit-input-placeholder { font-weight: 400; color: #ababab;}
.contactform ::-moz-placeholder { font-weight: 400; color: #ababab;}
.contactform :-ms-input-placeholder { font-weight: 400; color: #ababab;}
.wpcf7-list-item.first { margin-left: 0;}
.wpcf7-list-item + .wpcf7-list-item { margin-left: 4px;}
.wpcf7-response-output { display: none !important;}
.contactform .req { float: right; display: inline-block; margin-right: 8px; padding: 0 4px; background: #f68dae; font-size: 1.3rem; color: #FFF;}
.contactform th { padding-bottom: 20px; text-align: left; vertical-align: top; white-space: nowrap;}
.contactform td { padding-bottom: 20px;}
.form_button input.button.submit, .wpcf7-submit, .wpcf7-confirm, .wpcf7-back, .backbtn a { width: 100%; font-size: 1.8rem; font-weight: bold; display: block; padding: 16px; text-align: center; color: #ffffff; border-radius: 8px; background-color: #5ac1b5;}
.wpcf7-back { background-color: #dedede;}
.contactform input:not([type="checkbox"]).wpcf7c-conf, .contactform select.wpcf7c-conf, .contactform textarea.wpcf7c-conf { padding: 8px 4px!important; background: none!important; border-left: none!important; border-top: none!important; border-right: none!important; border-bottom: 1px solid #acacac!important; border-radius: 0!important;}


@media only screen and (max-width: 768px){
.contactform select.area { margin-bottom: 8px;}
.contactform th, .contactform td { display: block; text-align: left;}
.contactform th { padding-bottom: 8px;}
}



@media only screen and (min-width: 769px){
html { font-size: 70%;}
.sp { display: none;}
.pc { display: block;}
.info ul { justify-content: center; padding-top: 24px;}
.info li { width: auto; border-bottom: none;}
.info li:nth-child(even) { border-left: none;}
#main { max-width: 880px; margin: 0 auto;}
article.full { width: 100vw; margin: 0 calc(50% - 50vw);}
article header { width: 100%; margin: 0 0 32px;}
article header figure { max-width: 560px; margin: 0 auto;}
article header h2 { font-size: 3.6rem;}
article:not(.full) { margin-bottom: -40px;}
article:not(.full) section { margin-bottom: 40px;}
section + section { margin-top: 0;}
.btn a { max-width: 400px; margin: 0 auto;}
.box, .fit { margin-left: 0; margin-right: 0;}
.row { display: flex; flex-wrap: wrap; justify-content: space-between;}
.row.align-center { align-items: center;}
.row > * { width: 48%;}

.infolist, .ranklist { display: flex; flex-wrap: wrap; justify-content: space-between;}
.infolist li, .ranklist li { width: 48%;}
.flow li {  margin: 0 0 40px;}
.reason li { width: 17%;}

#pagenav li a { font-size: 2rem;}

.heading { margin: 0 0 32px; font-size: 2.4rem;}
.areaname a { margin: 0;}
.shoplist { margin: 0; padding: 20px 20px 4px;}
.shoplist::after { content: ''; display: block; width: 31%;}
.shoplist li { width: 31%;}
.shoplist li h3 { font-size: 1.6rem;}
.shoplist li h3 span { font-size: 1.1rem;}
#shop { margin: 0 20px; background: #F8F8F8;}
#shop header { margin-bottom: 0;}
.swiper-container { margin: 0;}
.movie { margin: 0; font-size: 2.4rem;}
.youtube { margin: 0 0 20px;}
.shop { margin: 0 20px 20px;}
.qa li figure { width: 100px;}

#aside { padding-bottom: 60px;}

#body h2 { margin-left: 0; margin-right: 0; font-size: 2.4rem;}

.form dt { float: none; width: auto;}
.form dd { padding: 0;}
.form label { display: block; margin-bottom: 16px;}
table.formTable th { display: block; width: auto; padding: 16px 0 0;}
table.formTable td { display: block; padding: 8px 0 16px;}
}


@media print {
#container { width: 1024px;}
}