@charset "utf-8";
/*
Theme Name: ローズ
*/


/*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: #491515; 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.3rem; font-weight: 500; line-height: 1.6; -webkit-font-smoothing: antialiased; color: #491515;}
#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; background-size: 120px auto;}
#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*/
/*******************************************************************/
#header { position: relative; top: 0; left: 0; display: flex; justify-content: space-between; align-items: center; width: 100%; height: 50px; padding: 0 10px; background: #FFF; line-height: 1; box-shadow: 4px 0 8px rgba(0,0,0,.07); z-index: 100;}
#header.is-fixed { position: fixed;}
#header.is-fixed + * { margin-top: 55px;}
#header li { display: inline-block; width: 110px;}
#logo { width: 90px;}


/*FOOTER*/
/*******************************************************************/
.info { position: relative;}
.nav { display: flex; flex-wrap: wrap;}
.nav li { width: 50%; border-bottom: 1px solid #6f5a58;}
.nav li:nth-child(even) { border-left: 1px solid #6f5a58;}
.nav li a { display: block; padding: 16px 8px; text-align: center;}
.sns { display: flex; justify-content: center; margin-top: 24px;}
.sns li { width: 44px; margin: 0 16px;}
.info p { padding: 24px 0; text-align: center;}
.info p img { width: 160px;}
.info address { padding-bottom: 24px; text-align: center; font-size: 1.2rem; font-style: normal;}
#pagetop { position: absolute; right: 16px; bottom: 16px;}
#pagetop a { display: block; width: 22px; height: 22px;}
#floating { position: fixed; bottom: 0; left: 0; width: 100%; text-align: center; padding: 8px;}


/*CONTENTS*/
/*******************************************************************/
article { padding: 20px;}
article header { position: relative; margin-bottom: 16px; text-align: center;}
article header h1 { font-size: 1.9rem; color: #f12f69;}
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;}
article p:not(:last-child) { margin-bottom: 20px;}
figure { position: relative;}
figure > img { width: 100%; height: auto;}
.bg { padding: 40px 20px; background: #fff6d9;}
.bg2 { padding: 40px 20px; background: #c2efed;}
.center { text-align: center;}
.right { text-align: right;}
.pc { display: none;}
.pink { color: #f24275!important;}
.yellow { color: #F9FE70!important;}
.darkyellow { color: #ffb400!important;}
.green { color: #00B900!important;}
.purple { color: #de687e!important;}
.orange { color: #e9a340!important;}
.fs11 { display: inline-block; font-size: 1.1rem;}
.fs13 { font-size: 1.3rem;}
.fs14 { font-size: 1.4rem;}
.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;}
.pt0 { padding-top: 0px;}
.pt80 { padding-top: 80px;}
.underline { text-decoration: underline;}
.bar { background: linear-gradient(transparent 0%, #A87BBE 0%);}
.marker { background: linear-gradient(transparent 60%, #fff57e 0%);}
.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,#d47190,#d47190 100%,transparent);}
.serif { font-family: "Noto Serif JP", "serif";}
.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: #d47190;}
.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: 32px 16px; text-align: center; background: #ffdbdd; color: #00b900;}
.contact p { font-size: 1.5rem; font-weight: 700;}
.contact.alt { margin-top: 140px;}
.btn a { position: relative; display: flex; justify-content: center; align-items: center; width: calc(100% - 16px); padding: 16px; text-align: center; background: rgb(255,228,0); background: linear-gradient(0deg, rgba(255,228,0,1) 0%, rgba(249,254,112,1) 100%); border-radius: 56px; font-size: 2.7rem; font-weight: bold; box-shadow: 0 5px 0 #F6C500;}
.btn a::after { content: '＞'; width: 24px; height: 24px; margin-left: 8px; background: #FFF; border-radius: 50%; font-size: 1.6rem; color: #FFCC00;}
.btn + .line { margin-top: 16px;}
.line { display: flex; justify-content: center; align-items: center; margin-top: 16px; font-weight: bold;}
.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: 8px 16px; text-align: center; background: #00b800; border-radius: 40px; font-weight: bold; letter-spacing: 0.12em; color: #FFF;}
.line a::after { content: '＞'; margin-left: 8px;}
.line + * { margin-top: 16px;}
.more { text-align: center;}
.more a { display: flex; justify-content: center; align-items: center; padding: 16px 8px; background: #FFF; border: 2px solid #42d4d7; border-radius: 8px; font-size: 2rem; font-weight: bold; color: #42d4d7;}
.more a::before { content: ''; width: 20px; height: 20px; margin-right: 8px; background: #42d4d7 url("img/common/arr_w.svg") center no-repeat; background-size: auto 14px; border-radius: 50%;}
.more a.alt { background: #f17e9c; border: 2px solid #FFF; font-size: 2rem; font-weight: bold; color: #FFF;}
.more a.alt::before { background-color: #FFF; background-image: url("img/common/arr.svg"); border: none;}
.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%;}
.link a.alt { color: #FFF;}
.link a::before { background-color: #FFF; background-image: url("img/common/arr.svg");}
.box { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); padding: 20px; background: #34d4ba; color: #FFF;}
.box + * { margin-top: 20px;}
.box.dot, .contact.dot { background: url("img/common/dot.png") center repeat; color: #333;}
.box.alt { background: #f5b0c4; color: #333;}
.fit { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw);}
.fit img { width: 100%;}

#mv { padding: 0; text-align: center; background: #F5F5F5;}
.blog { position: relative; margin: 40px 10px 20px; background: #de687e; border-radius: 12px;}
.blog::before { content: ''; position: absolute; top: 6px; left: 6px; right: 6px; bottom: 6px; display: block; border: 1px solid #FFF; border-radius: 8px;}
.blog h2 { position: relative; margin: -40px 0 40px; z-index: 1;}
.infolist + div { text-align: center;}
.infolist li { position: relative; margin-bottom: 16px;}
.infolist li::before { content: ''; position: absolute; top: 4px; left: 4px; right: 4px; bottom: 4px; border: 1px dotted #de687e; border-radius: 4px; pointer-events: none;}
.infolist li a { display: flex; justify-content: space-between; padding: 16px; border-radius: 5px; background: #FFF;}
.infolist li a > figure { width: 30%;}
.infolist li a > div { width: calc(70% - 20px);}
.infolist li p { margin: 4px 0!important; line-height: 1.2;}
.infolist li time { display: block; font-size: 1rem;}
.cat { display: inline-block; margin-bottom: 4px; padding: 2px 4px; background: #51cad5; border-radius: 6px; font-size: 1rem; color: #FFF;}
.cat a { color: #FFF;}

.flow li { margin-bottom: 24px;}
.flow li h3 { margin-bottom: 16px;}
.flow li figure { margin-bottom: 16px; text-align: center;}
.reason li { margin-top: 60px; padding: 24px; background: #EEE5F2; border-radius: 20px;}
.reason li h3 { margin: -60px 0 20px;}

.interviewlist > li { max-width: 320px; margin: 0 auto 16px; padding: 20px; background: url("img/top/voice_bg.png") center no-repeat; background-size: 100% 100%;}
.prof { display: flex; justify-content: center; align-items: center; margin: -8px -8px 16px; padding: 4px; background: #fff6f9; font-weight: bold;}
.prof > figure img { width: 86px; height: 86px; border-radius: 50%;}
.prof > div { flex: 1; margin-left: 16px;}
.prof h3 { font-size: 2rem;}
.prof p { margin-bottom: 0!important;}
.interviewlist h4 { margin-bottom: 16px;}
.tag { text-align: center; margin-bottom: -40px;}
.tag dt { display: inline-block ;padding: 4px 8px; text-align: center; background: #2f0000; font-size: 2rem; font-weight: bold; color: #FFF;}
.tag dd { margin: -20px -20px 0; padding: 40px 16px 16px; background: #f5628b; color: #FFF;}
.check { padding: 8px 16px; border: 1px solid #FFF; border-radius: 8px; text-align: left;}
.check li { padding: 8px 0 8px 24px; background: url("img/top/check.png") left 8px no-repeat; background-size: 20px auto;}
.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);}

.heading { position: relative; margin-bottom: 16px; padding: 16px 8px 24px; text-align: center; background: url("img/common/fukidashi.png") center no-repeat; background-size: 100% 100%; font-size: 5.6vw; color: #FFF;}
.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.png") 8px 16px no-repeat; background-size: 32px auto; border-top: 3px dotted #c3c3c3; font-weight: bold;}
.answer { display: none; padding: 8px 8px 8px 56px; background: #fff3f7 url("img/faq/ans.png") 8px 8px no-repeat; background-size: 32px auto; 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;}

.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 { position: relative; margin-top: 40px; padding: 32px 16px 0; border: 2px solid #FFF; border-radius: 8px; text-align: center;}
.questionnaire::before { content: ''; position: absolute; top: 0; left: 50%; transform: translate(-50%, -50%); width: 120px; height: 37px; background: #7ed3ba url("img/voice/profile.svg") center no-repeat;}
.questionnaire dt { margin: 0 auto; padding: 4px; background: #FFF; border-radius: 40px; font-size: 1.4rem; font-weight: bold; color: #7ed3ba;}
.questionnaire dd { margin: 8px 0 16px; 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 dt { padding: 16px 24px 0; font-weight: bold; color: #f12f69;}
.company dd { padding: 0 24px 16px;}
.company dt:nth-of-type(odd), .company dd:nth-of-type(odd) { background: #ffeff0;}

.blogslide { padding: 10px 0 0;}
.slide-img { position: relative; padding-top: calc(563 / 750 * 100%); border-radius: 8px;}
.slide-img img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; border-radius: 8px;}
.slide-caption { position: absolute; bottom: 0; left: 0; width: calc(100% - 16px); padding: 8px; text-align: center; background: rgba(81,202,213,.9); border-radius: 0 0 8px 8px; color: #FFF;}
.slide-caption .cat { background: transparent; font-size: 2rem; font-weight: bold; color: #FFF;}
.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: #FFF; border-radius: 50%; font-size: 24px; color: #51cad5;}
.swiper-button-next { right: -8px;}
.swiper-button-prev { left: -8px;}
.swiper-button-next, .swiper-button-prev { width: 40px;}
.swiper-pagination { position: relative; margin-top: 16px;}
.swiper-pagination-bullet-active { background-color: #51cad5;}

.paging { margin: 48px 0; font-weight: bold; color: #FFF;}
.pagination { display: flex; justify-content: center; align-items: center; width: 100%;}
.single-nav-links { display: flex; justify-content: center; align-items: center; width: 100%; padding: 24px 0; border-top: 1px solid #2f0000; border-bottom: 1px solid #2f0000;}
.nav-numbers { padding: 16px;}
.pagination a { display: inline-block; padding: 0 4px;}
.pagination a:not(.prev):not(.next):not(.top) { padding: 6px; color: #FFF;}
.pagination a.prev, .pagination a.next { padding: 6px 12px; background-color: #ffdbdd; border-radius: 50%; color: #de687e;}
.pagination a strong { display: inline-block; width: 21px; height: 21px; text-align: center; background: #f17e9c; border-radius: 50%; color: #FFF;}
.pagination a.top { padding: 0 20px; border-left: 1px solid #333; border-right: 1px solid #333;}
.pagination span { display: inline-block; padding: 6px 12px;}
.pagination span.current { background-color: #FFF; border-radius: 50%; color: #de687e;}
.screen-reader-text { display: none;}
.category { display: flex; flex-wrap: wrap; margin: 8px -4px;}
.category li { margin: 4px;}
.category li a { display: block; padding: 4px; border: 1px solid #9C846D; border-radius: 32px; font-size: 1rem; font-weight: bold;}

#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; border: 1px solid #491515;}
#ez-toc-container .ez-toc-title-container { text-align: center;}
#ez-toc-container .ez-toc-title { margin: 0 auto 16px; padding-bottom: 16px!important; text-align: center!important; background: url("img/blog/bar.png") center bottom no-repeat; background-size: 100% 4px; font-size: 2rem!important; font-weight: bold!important;}
#ez-toc-container ul { margin-left: 1.5em; list-style: none!important;}
#ez-toc-container .ez-toc-list > li { padding-top: 16px; text-indent: -1em;}
#ez-toc-container .ez-toc-list > li::before { content: '●'; color: #de687e;}
#ez-toc-container .ez-toc-list li a { font-weight: bold; color: #de687e;}
#ez-toc-container .ez-toc-list li ul { margin-left: 1em;}
#ez-toc-container .ez-toc-list li li { margin-top: 8px;}
#ez-toc-container .ez-toc-list li li::before { content: '▶︎';}
#ez-toc-container .ez-toc-list li li a { font-size: 1.3rem; font-weight: normal; color: #491515;}
#ez-toc-container li, #ez-toc-container ul, #ez-toc-container ul li, div.ez-toc-widget-container, div.ez-toc-widget-container li { list-style: inherit; overflow: inherit;}
#ez-toc-container.counter-decimal ul.ez-toc-list li a::before, .ez-toc-widget-container.counter-decimal ul.ez-toc-list li a::before { display: none;}

#body h2 { position: relative; margin: 60px -20px 32px; padding: 8px 20px; background: #de687e; font-size: 5.6vw; color: #FFF;}
#body h3 { margin: 30px 0 20px; font-size: 1.8rem; color: #de687e;}
#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: #51cad5; 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: #51cad5;}
#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;}

.contacttitle { margin: -20px -20px 20px; padding: 20px; background: url("img/contact/bg.png") center no-repeat; background-size: cover; color: #FFF;}
.contacttitle p { padding-top: 16px;}
.contactform { width: 100%;}
.contactform input, .contactform select, .contactform textarea { width: 100%; max-width: 100%; min-height: 48px; padding: 8px; vertical-align: middle; border: 1px solid #491515; border-radius: 8px; background-color: #FFF; font-size: 17.44px;}
.contactform select { padding-right: 24px; background-image: url("img/contact/select.png"); background-position: right 8px center;}
.colorbox { border-color: #e07a93!important; background-color: #ffeff2!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 { min-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 #491515; border-radius: 0; box-shadow: 0 0 0 transparent inset; appearance: none;}
.contactform input[type='checkbox']:checked { background-color: #de687e;}
.contactform label { line-height: 1; padding: 6px; background-color: #d7cccc; 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 { display: inline-block; margin-left: 8px; padding: 2px 8px; background: #de687e; border-radius: 40px; font-size: 1.1rem; color: #FFF;}
.contactform th { padding-bottom: 20px; padding-right: 20px; text-align: left; vertical-align: top; white-space: nowrap;}
.contactform td { padding-bottom: 20px;}
.form_button { margin-top: 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: 40px; background-color: #491515; box-shadow: 0 5px 0 #2f0000;}
.wpcf7-back { background-color: #d7cccc; box-shadow: none;}
.contactform input:not([type="checkbox"]).wpcf7c-conf, .contactform select.wpcf7c-conf, .contactform textarea.wpcf7c-conf { min-height: initial!important; padding: 0!important; background: none!important; border: none!important; border-radius: 0!important; color: #6F5A58;}
.contactform .wpcf7-not-valid { background-color: #fff3f5; border-color: #de687e;}
.custom-wpcf7c-confirmed .contactform .req { display: none;}
.custom-wpcf7c-confirmed .contactform { border-top: 1px dotted #491515;}
.custom-wpcf7c-confirmed .contactform th { display: block; padding-top: 10px; padding-bottom: 4px;}
.custom-wpcf7c-confirmed .contactform td { display: block; padding-bottom: 10px; border-bottom: 1px dotted #491515;}
.custom-wpcf7c-confirmed .contactform textarea { min-height: initial;}




@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;}
.nav { justify-content: center; padding-top: 24px;}
.nav li { width: auto; border-bottom: none;}
.nav li:nth-child(even) { border-left: none;}
#main { max-width: 750px; margin: 0 auto;}
article.full { width: 100vw; margin: 0 calc(50% - 50vw);}
article header { margin: 0 0 32px;}
article header h1 { font-size: 3.8rem;}
.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%;}
.reverse { flex-direction: row-reverse;}
.infolist, .ranklist { display: flex; flex-wrap: wrap; justify-content: space-between;}
.infolist li, .ranklist li { display: flex; width: 48%;}
.flow li { align-items: center;}

.interviewlist { display: flex; flex-wrap: wrap; justify-content: space-between;}
.interviewlist li { width: 48%;}

.heading { margin: 0 0 32px; font-size: 2.4rem;}

#aside { padding-bottom: 60px;}

#body h2 { margin-left: 0; margin-right: 0; font-size: 2.4rem;}
}


@media print {
#container { width: 1024px;}
}