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


/*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:linear-gradient(transparent 60%, #fff580 60%);color:#937e6d}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;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;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;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;appearance:textfield;outline-offset:-2px}img{width:auto;max-width:100%;height:auto;border-style:none;vertical-align:middle}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:#937e6d;text-shadow:none}::selection{background-color:#b3d4fc;color:#937e6d;text-shadow:none}ul,ol{list-style:none}i,em{font-style:normal}
a { color: #717171; 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.2; -webkit-font-smoothing: antialiased; color: #717171;}
#container { position: relative; width: 100%; overflow: hidden;}


/*HEADER*/
/*******************************************************************/
#header { position: relative; position: fixed; top: 0; left: 0; display: flex; justify-content: space-between; align-items: center; width: 100%; height: 56px; padding: 0 10px; background: #fdf2f5; line-height: 1; box-shadow: 4px 0 8px rgba(0,0,0,.07); z-index: 200;}
#open { position: relative; display: block; width: 26px; height: 18px; cursor: pointer; z-index: 9999;}
.open #nav { pointer-events: auto; opacity: 1; transform: translateY(0);}
#logo { width: 128px;}
#menu ul { display: flex; gap: 8px;}
#menu img { width: 30px;}
@media only screen and (max-width: 768px){
	#nav { pointer-events: none; opacity: 0; position: fixed; top: 56px; right: 0; transform: translateY(-40px); width: 100%; height: calc(100svh - 56px); background: rgba(0,0,0,.5); z-index: 1000; transition: .4s cubic-bezier(.645,.045,.355,1); overflow-y: auto; overscroll-behavior: contain;}
	#nav > ul { list-style: none;}
	#nav > ul > li a { position: relative; display: block; padding: 24px; background: #FFF url(img/common/arrow.png) right 24px center no-repeat; background-size: 7px auto; border-bottom: 1px solid #717171; font-size: 1.6rem;}
	#nav .contact { background: #fdf2f5;}
	#nav .contact::before { background: #763b4d;}
	.footer { padding: 0 32px; background: #fdf2f5; border-top: 1px dotted #717171;}
	.footer p { padding: 24px 0; text-align: center;}
	.footer p img { width: 128px;}
	.footer address { padding-bottom: 32px; text-align: center; font-size: 1.1rem; font-style: normal;}
}
@media only screen and (min-width: 769px){
	#header { gap: 24px; height: 90px; padding: 0 32px;}
	#logo { width: 225px;}
	#menu img { width: 46px;}
	#open { display: none;}
	#nav { margin-right: auto; margin-left: 40px;}
	#nav > ul { display: flex; flex-wrap: wrap; gap: 8px 16px; font-size: 1.2rem;}
	#nav .contact { display: none;}
	#nav .footer { display: none;}
}


/*FOOTER*/
/*******************************************************************/
#footer { background: #fdf2f5;}
.info { position: relative;}
.nav { display: flex; flex-wrap: wrap; border-top: 1px solid #717171;}
.nav li { width: 50%; border-bottom: 1px solid #717171;}
.nav li:nth-child(odd) { border-right: 1px solid #717171;}
.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 8px;}
#footer p { padding: 24px 0; text-align: center;}
#footer p img { width: 128px;}
#footer address { padding-bottom: 140px; text-align: center; font-size: 1.1rem; font-style: normal;}
#pagetop { position: absolute; right: 16px; bottom: 160px; z-index: 200;}
#pagetop a { display: block; width: 22px; height: 22px;}
#floating { position: fixed; bottom: 0; left: 0; width: 100%; text-align: center; padding: 8px; z-index: 100;}
#floating a { display: inline-block; max-width: 480px;}


/*CONTENTS*/
/*******************************************************************/
#main { margin-top: 56px;}
#main p { line-height: 1.6;}
article, section { position: relative;}
figure { position: relative; margin: 0;}
figure > img { width: 100%; height: auto;}
article header h1 { text-align: center; margin-bottom: 20px; font-family: "fot-tsukuardgothic-std", sans-serif; font-size: 1.9rem; color: #e98fab;}
#breadcrumb ul { display: flex; gap: 4px; padding: 8px;}
#breadcrumb li { font-size: 1rem; overflow: hidden; display: -webkit-box; text-overflow: ellipsis; -webkit-box-orient: vertical; -webkit-line-clamp: 1; line-clamp: 1;}
#breadcrumb li:not(:first-child)::before { content: '＞'; display: inline; vertical-align: baseline;}
#breadcrumb li img { width: 16px;}
#breadcrumb li a { text-decoration: underline; color: #616161;}
.sp { display: block;}
.pc { display: none;}
.in { padding: 20px;}
.w10 { width: 10%; margin-left: auto; margin-right: auto;}
.w20 { width: 20%; margin-left: auto; margin-right: auto;}
.w30 { width: 30%; margin-left: auto; margin-right: auto;}
.w40 { width: 40%; margin-left: auto; margin-right: auto;}
.w50 { width: 50%; margin-left: auto; margin-right: auto;}
.w60 { width: 60%; margin-left: auto; margin-right: auto;}
.w70 { width: 70%; margin-left: auto; margin-right: auto;}
.w80 { width: 80%; margin-left: auto; margin-right: auto;}
.w90 { width: 90%; margin-left: auto; margin-right: auto;}
.center { text-align: center;}
.right { text-align: right;}
.pc { display: none;}
.blue { color: #8fc7e4;}
.yellow { color: #feff9d;}
.orange { color: #ffae54;}
.pink { color: #ee759a;}
.green { color: #bad46b;}
.purple { color: #e98fab;}
.fs07 { position: relative; display: inline-block; font-size: 1rem; transform: scale(0.7);}
.fs08 { position: relative; display: inline-block; font-size: 1rem; transform: scale(0.8);}
.fs09 { position: relative; display: inline-block; font-size: 1rem; transform: scale(0.9);}
.fs10 { font-size: 1rem;}
.fs11 { font-size: 1.1rem;}
.fs12 { font-size: 1.2rem;}
.fs13 { font-size: 1.3rem;}
.fs14 { font-size: 1.4rem;}
.fs15 { font-size: 1.5rem;}
.fs16 { font-size: 1.6rem;}
.fs17 { font-size: 1.7rem;}
.fs18 { font-size: 1.8rem;}
.fs19 { font-size: 1.9rem;}
.fs20 { font-size: 2rem;}
.fs21 { font-size: 2.1rem;}
.fs22 { font-size: 2.2rem;}
.fs23 { font-size: 2.3rem;}
.fs24 { font-size: 2.4rem;}
.fs25 { font-size: 2.5rem;}
.fs26 { font-size: 2.6rem;}
.fs27 { font-size: 2.7rem;}
.fs28 { font-size: 2.8rem;}
.fs29 { font-size: 2.9rem;}
.fs30 { font-size: 3rem;}
.fs31 { font-size: 3.1rem;}
.fs32 { font-size: 3.2rem;}
.fs33 { font-size: 3.3rem;}
.fs34 { font-size: 3.4rem;}
.fs35 { font-size: 3.5rem;}
.fs36 { font-size: 3.6rem;}
.fs37 { font-size: 3.7rem;}
.fs38 { font-size: 3.8rem;}
.fs39 { font-size: 3.9rem;}
.fs40 { font-size: 4rem;}
.fs50 { font-size: 5rem;}
.fs72 { font-size: 7.2rem;}
.regular { font-weight: 400;}
.bold { font-weight: 700;}
.kerning { letter-spacing: 0.12em;}
.mt0 { margin-top: 0;}
.mb0 { margin-bottom: 0;}
.mt20 { margin-top: 20px;}
.mt40 { margin-top: 40px;}
.mb20 { margin-bottom: 20px;}
.mb40 { margin-bottom: 40px;}
.pt0 { padding-top: 0px;}
.pt20 { padding-top: 20px;}
.pt40 { padding-top: 40px;}
.pb0 { padding-bottom: 0;}
.pb20 { padding-bottom: 20px;}
.pb40 { padding-bottom: 40px;}
.underline { text-decoration: underline;}
.under-dotline { display: inline-block; border-bottom: 1px dotted #937e6d;}
.marker { background: linear-gradient(transparent 60%, #fff580 0%);}
.updot { padding-top: -0.2em; background-position: top left -2px; background-repeat: repeat-x; background-size: 1em .2em; background-image: radial-gradient(.10em .10em at center center,#7cc6d3,#7cc6d3 100%,transparent);}
.tsukuardgothic { font-family: "fot-tsukuardgothic-std", sans-serif;}
.fadeInUp{ animation-name: fadeInUp;}
@keyframes fadeInUp { from { opacity: 0; transform: translate3d(0, 40px, 0);} to { opacity: 1; transform: translate3d(0, 0, 0);}}
.animated { opacity: 0; animation-duration: 0.4s; animation-delay: 0.1s; animation-fill-mode: both;}
.contact { padding: 32px 20px; text-align: center; font-size: 1.5rem; color: #FFF;}
.contact::before { content: ''; position: absolute; top: 0; left: calc(50% - 50vw); width: 100vw; height: 100%; background: url(img/common/contact_bg.png) center repeat; z-index: -1;}
.contact .copy { width: 90%;}
.contact p { max-width: 460px; margin: 0 auto;}
.contact p + p { margin-top: 8px;}
.btn { margin-top: 24px;}
.btn a { position: relative; display: flex; justify-content: center; align-items: center; width: calc(100% - 16px); padding: 16px; text-align: center; background: #8fc7e4; border-radius: 56px; font-size: 2.4rem; font-family: "fot-tsukuardgothic-std", sans-serif; font-weight: bold; color: #FFF; white-space: nowrap; box-shadow: 0 5px 0 rgba(143,199,228,.16);}
.btn a::after { content: '＞'; display: flex; justify-content: center; align-items: center; width: 24px; height: 24px; margin-left: 8px; background: #FFF; border-radius: 50%; font-size: 1.3rem; color: #8fc7e4;}
.line { display: flex; justify-content: center; align-items: center; margin-top: 16px; padding: 12px 0; background: url("img/common/dot.png") left top repeat-x, url("img/common/dot.png") left bottom repeat-x; font-family: "fot-tsukuardgothic-std", sans-serif; font-weight: bold; white-space: nowrap; color: #FFF;}
.line::before { content: ''; width: 28px; height: 28px; margin-right: 8px; background: url("img/common/button_line.svg") center no-repeat;}
.line a { display: block; margin-left: 8px; padding: 10px 16px; text-align: center; background: #00b800; border-radius: 40px; letter-spacing: 0.12em; color: #FFF;}
.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: inline-block; padding: 8px 16px; background: #f39fb9; border-radius: 40px; color: #FFF;}
.box { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); padding: 20px; background: #fb975b; font-size: 1.5rem; color: #FFF;}
.box + * { margin-top: 20px;}
.fit { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw);}
.fit img { width: 100%;}


/*TOP*/
.about-t { position: relative; display: inline-block; padding: 8px 0; z-index: -1;}
.about-t::before { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 120%; height: 110%; background: url(img/top/about_t.png) center no-repeat; background-size: contain; z-index: -1;}
.about h3 { display: inline-block; margin-bottom: 24px; padding: 40px 24px 0; background: url(img/top/about_machida.png) left top no-repeat, url(img/top/serif_l.png) left bottom no-repeat, url(img/top/serif_r.png) right bottom no-repeat; background-size: 156px auto, 15px auto, 15px auto; font-weight: 400;}
.about h3 span { display: inline-block; background: #9fd3dc; color: #FFF;}
.about h3 span em { color: #feffab;}
.about .quotes img { width: 15px;}

.ok h3 { display: inline-block; padding: 0 24px; background: url(img/top/serif_l.png) left bottom no-repeat, url(img/top/serif_r.png) right bottom no-repeat; background-size: 15px auto, 15px auto;}
.ok .inexperience { display: flex; justify-content: center; align-items: center; gap: 8px;}
.ok .inexperience figure { width: 72px;}
.ok .dotline { padding: 0.5em 0; background-image: radial-gradient(circle, #717171 1px, transparent 1px), radial-gradient(circle, #717171 1px, transparent 1px); background-position: left top, left bottom; background-repeat: repeat-x, repeat-x; background-size: 6px 2px, 6px 2px;}

.access::before { content: ''; position: absolute; top: 0; left: calc(50% - 50vw); width: 100vw; height: 100%; background: url(img/top/access_bg.png) center no-repeat; background-size: cover; z-index: -1;}
.access h2 { padding: 2px 4px; background: url(img/top/access_t.png) 20% top no-repeat; background-size: auto 70%;}
.access .pinkbox { background: #f49db8; color: #FFF;}
.station .bold { position: relative; margin-top: -25px; z-index: 10;}
.station .bold span { display: inline-block; margin: 2px 0; padding: 2px 4px; background: #f49db8; color: #FFF;}

.work::before { content: ''; position: absolute; top: 0; left: calc(50% - 50vw); width: 100vw; height: 100%; background: #fef5f8; z-index: -1;}
.work .fs07 { display: inline-block; padding: 10px 20px 10px 0; background: url(img/top/work_t.png) center no-repeat; background-size: 100% 100%;}

.serif { display: inline-block; padding: 0 24px; background: url(img/top/serif_l.png) left bottom no-repeat, url(img/top/serif_r.png) right bottom no-repeat; background-size: 15px auto, 15px auto;}
.salary .bar { display: inline-block; margin: 4px 0; padding: 2px 4px; background: #FFA053; background: linear-gradient(70deg, rgba(250, 111, 163, 1) 24%, rgba(255, 160, 83, 1) 100%); color: #FFF;}
.salary figure { margin-bottom: -20px; z-index: -1;}
.bordertext { color: #fff67e; -webkit-text-stroke: 1px #717171; text-stroke: 1px #717171;}

.trouble::before { content: ''; position: absolute; top: 0; left: calc(50% - 50vw); width: 100vw; height: 100%; background: url(img/top/trouble_bg.png) center repeat; z-index: -1;}
.trouble ul { display: grid; gap: 8px;}
.trouble li { display: flex; justify-content: center; align-items: center; min-height: 5em; padding: 8px; text-align: center; background: #FFF; border-radius: 40px;}

.promise h2 strong { padding-bottom: 8px; background: url(img/top/underline.png) center bottom no-repeat; background-size: 100% auto;}
.promise ol { display: grid; gap: 40px;}
.promise li { position: relative; display: flex; flex-direction: column; align-items: center; gap: 20px; padding: 30px 20px; background: #ffeff4; border-radius: 10px; box-shadow: 3px 3px 6px rgba(220,200,207,.35);}
.promise li .num { position: absolute; top: 0; left: 50%; transform: translate(-50%,-50%); width: 30%; text-align: center;}
.promise li h3 { display: grid; align-items: center; grid-template-columns: 20% 1fr; gap: 10px;}

.review::before { content: ''; position: absolute; top: 0; left: calc(50% - 50vw); width: 100vw; height: 100%; background: #fff1e7; z-index: -1;}
.review h2 em { color: #fffb96; -webkit-text-stroke: 1px #937e6d; text-stroke: 1px #937e6d;}
.reviewlist { display: grid; gap: 40px;}
.reviewlist li { position: relative; padding: 20px; background: #FFF; border-radius: 10px;}
.reviewlist h3 { position: relative; display: block; width: 90%; max-width: 400px; margin: -40px auto 10px; padding: 16px 20px; text-align: center; background: #ffae54; border-radius: 40px; color: #FFF;}
.reviewlist h3::after { content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); width: 0; height: 0; border-style: solid; border-color: #ffae54 transparent transparent transparent; border-width: 10px 5px 0px 5px;}
.reviewlist h4 { margin-top: 10px; padding: 10px 0; border-top: 1px dotted #dbebf1;}
.read { height: 3em; overflow: hidden;}
.readbtn { margin-top: 4px; text-decoration: underline; font-size: 1.1rem; color: #e76a8d; cursor: pointer;}
.prof { display: grid; grid-template-columns: 25% 1fr; align-items: center; gap: 10px;}
.prof dl { display: flex; flex-wrap: wrap; gap: 4px; margin: 4px;}
.prof dt { padding: 1px 4px; background: #937e6d; border-radius: 40px; color: #FFF;}
.prof p span::before { content: ''; display: inline-block; margin: 0 4px; width: 0; height: 0; border-style: solid; border-color: transparent transparent transparent #fb975b; border-width: 5px 0px 5px 6px;}

.environment ol { display: grid; gap: 30px;}
.environment li { display: flex; flex-direction: column; align-items: center; gap: 10px;}
.environment li .num img { width: 37px; margin-right: 4px;}

.photo::before { content: ''; position: absolute; top: 0; left: calc(50% - 50vw); width: 100vw; height: 100%; background: url(img/top/photo_bg.png) center top no-repeat; background-size: cover; z-index: -1;}
.photo-t { padding: 10px 0 10px; text-align: center; background: url(img/top/photo_l.png) left bottom no-repeat, url(img/top/photo_r.png) right bottom no-repeat; background-size: 28% auto, 28% auto;}
#photo { color: #725e5c;}
.photo-t h2 { margin: -10px auto 10px;}
.photo-t h2 em { color: #f5c0d2;}
.photo ol { display: grid; gap: 10px;}
.photo li { position: relative; padding-left: 38%;}
.photo .contents { position: absolute; top: 50%; left: 0; transform: translateY(-50%); display: flex; flex-direction: column; gap: 10px; width: 42%; z-index: 1;}
.photo .contents h3 { background-image: radial-gradient(circle, #717171 1px, transparent 1px); background-position: left bottom; background-repeat: repeat-x; background-size: 6px 2px; color: #FFF; -webkit-text-stroke: 1px #686868; text-stroke: 1px #686868;}
.photo li:nth-child(even) { padding-left: 0; padding-right: 38%;}
.photo li:nth-child(even) .contents { left: auto; right: 0; text-align: right;}

.star { position: relative; display: inline-block; margin: 0 4px; vertical-align: baseline; font-size: 1.6rem; color: #e3e5e5;}
.star::after { content: '★★★★★'; position: absolute; top: 0; left: 0; color: #fdd728;}
.star5::after { clip-path: polygon(0 0, 10% 0, 10% 100%, 0 100%);}
.star10::after { clip-path: polygon(0 0, 20% 0, 20% 100%, 0 100%);}
.star15::after { clip-path: polygon(0 0, 30% 0, 30% 100%, 0 100%);}
.star20::after { clip-path: polygon(0 0, 40% 0, 40% 100%, 0 100%);}
.star25::after { clip-path: polygon(0 0, 50% 0, 50% 100%, 0 100%);}
.star30::after { clip-path: polygon(0 0, 60% 0, 60% 100%, 0 100%);}
.star35::after { clip-path: polygon(0 0, 70% 0, 70% 100%, 0 100%);}
.star40::after { clip-path: polygon(0 0, 80% 0, 80% 100%, 0 100%);}
.star41::after { clip-path: polygon(0 0, 82% 0, 82% 100%, 0 100%);}
.star42::after { clip-path: polygon(0 0, 84% 0, 84% 100%, 0 100%);}
.star43::after { clip-path: polygon(0 0, 86% 0, 86% 100%, 0 100%);}
.star44::after { clip-path: polygon(0 0, 88% 0, 88% 100%, 0 100%);}
.star45::after { clip-path: polygon(0 0, 90% 0, 90% 100%, 0 100%);}
.star46::after { clip-path: polygon(0 0, 92% 0, 92% 100%, 0 100%);}
.star47::after { clip-path: polygon(0 0, 94% 0, 94% 100%, 0 100%);}
.star48::after { clip-path: polygon(0 0, 96% 0, 96% 100%, 0 100%);}
.star49::after { clip-path: polygon(0 0, 98% 0, 98% 100%, 0 100%);}
.star50::after { clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);}

.infolist li { position: relative; height: auto; margin-bottom: 10px;}
.infolist li a { display: flex; justify-content: space-between; height: 100%; border-radius: 5px; background: #FFF;}
.infolist li a figure { position: relative; width: 40%; padding-top: calc(180 / 268 * 40%);}
.infolist li a figure img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover;}
.infolist li a > div { width: 60%; padding: 10px; border: 1px solid #d6d6d6;}
.infolist li p { margin: 4px 0!important; font-size: 1.1rem; font-weight: bold; line-height: 1.4; overflow: hidden; display: -webkit-box; text-overflow: ellipsis; -webkit-box-orient: vertical; -webkit-line-clamp: 3; line-clamp: 3;}
.infolist li time { display: block; text-align: right; font-size: 1rem;}
.cat { display: flex; flex-wrap: wrap; gap: 4px;}
.cat span, .cat a { display: inline-block; margin-bottom: 4px; padding: 2px 4px; background: #f39fb9; border-radius: 24px; font-size: 1rem; color: #FFF;}

.faq::before { content: ''; position: absolute; top: 0; left: calc(50% - 50vw); width: 100vw; height: 100%; background: url(img/top/faq_bg.png) center no-repeat; background-size: cover; z-index: -1;}
.faq h2 { background: url(img/top/faq.png) right top no-repeat; background-size: auto 120%;}
.faq dt { position: relative; padding: 16px 40px 16px 48px; background: #eea9bc url(../../img/common/down.webp) right 16px center no-repeat; background-size: 13px; border-radius: 10px; color: #FFF; transition: .2s ease-out; cursor: pointer;}
.faq dt:not(:first-of-type) { margin-top: 10px;}
.faq dt::before { content: 'Q'; position: absolute; top: 16px; left: 16px; display: flex; justify-content: center; align-items: center; width: 2rem; height: 2rem; background: #FFF; border-radius: 50%; font-family: fot-tsukuardgothic-std, sans-serif; font-size: 1.2rem; font-weight: 700; color: #eea9bc;}
.faq dt.on { background-image: url(../../img/common/up.webp); border-radius: 10px 10px 0 0; color: #FFF;}
.faq dd { position: relative; display: none; padding: 10px 16px 16px; background: #eea9bc; border-top: 1px dotted #FFF; border-radius: 0 0 10px 10px; color: #FFF;}

/*COMPANY*/
.company { display: grid; grid-template-columns: auto 1fr; margin-top: 40px;}
.company dt { padding: 16px 8px 16px 16px; font-weight: bold; color: #e98fab;}
.company dd { padding: 16px 16px 16px 0;}
.company dt:nth-of-type(odd), .company dd:nth-of-type(odd) { background: #fdf2f5;}

/*BLOG*/
.blogslide { padding: 10px 20px;}
.blogslide::before { content: ''; position: absolute; top: 0; left: calc(50% - 50vw); width: 100vw; height: 100%; background: #eff7ff; z-index: -1;}
.blogslide .swiper-container { overflow: visible;}
.swiper-wrapper { height: auto;}
.slide-img { position: relative; margin: 0; padding-top: calc(449 / 672 * 100%); border-radius: 15px; overflow: hidden;}
.slide-img img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover;}
.slide-caption { padding: 8px;}
.slide-caption p {  overflow: hidden; display: -webkit-box; text-overflow: ellipsis; -webkit-box-orient: vertical; -webkit-line-clamp: 2; line-clamp: 2;}
.swiper-button-next:after, .swiper-button-prev:after { display: flex; justify-content: center; align-items: center; width: 30px; height: 30px; background: #FFF; border-radius: 50%; font-size: 1.6rem; color: #78c3e2;}
.swiper-button-next { right: -24px;}
.swiper-button-prev { left: -24px;}
.swiper-button-next, .swiper-button-prev { width: 40px; top: 40%;}
.swiper-pagination { position: relative; margin-top: 16px;}
.swiper-pagination-bullet { background-color: transparent; border: 1px solid #78c3e2; opacity: 1;}
.swiper-pagination-bullet-active { background-color: #78c3e2;}

.paging { padding: 40px 0; font-weight: bold; color: #78c3e2;}
.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 #616161; border-bottom: 1px solid #616161;}
.single-nav-links a { display: flex !important; align-items: center; gap: 4px;}
.nav-numbers { padding: 16px;}
.pagination a { display: inline-block; padding: 0 4px;}
.pagination a:not(.prev):not(.next) { padding: 8px 6px; color: #78c3e2;}
.pagination a.prev, .pagination a.next { padding: 8px 12px; background-color: #78c3e2; border-radius: 50%; color: #FFF;}
.pagination a strong { display: inline-block; width: 21px; height: 21px; text-align: center; background: #78c3e2; border-radius: 50%; color: #FFF;}
.pagination a.top { display: inline-block; margin: 0 20px; padding: 0 20px !important; border-left: 1px solid #616161; border-right: 1px solid #616161;}
.pagination span { display: inline-block; padding: 8px 12px;}
.pagination span.current { background-color: #bbe1f0; border-radius: 50%; color: #FFF;}
.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 #616161; border-radius: 32px; font-size: 1rem; font-weight: bold;}

#blog header { text-align: left;}
#blog header h1 { margin-bottom: 8px; text-align: left; font-size: 2.1rem; line-height: 1.2; color: #616161;}
#blog header time { display: block; margin: 8px 0;}
.mainimg { position: relative; margin-bottom: 20px;}
.mainimg figure { border-radius: 10px; overflow: hidden;}
.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, .title { position: relative; margin: 60px 0 32px; padding: 16px 20px; background: #78c3e2; font-size: 1.5rem; line-height: 1.2; color: #FFF;}
#body h2::before, #body h2::after, .title::before, .title::after { content: ''; position: absolute; top: 2px; left: 0; width: 100%; height: 1px; background: #FFF;}
#body h2::after, .title::after { top: auto; bottom: 2px;}
#body h3 { position: relative; margin: 40px 0 20px; padding: 6px 8px 6px 16px; background: rgba(120,195,226,.1); border-left: 4px solid #78c3e2; font-size: 1.5rem; color: #78c3e2;}
#body h4 { margin-bottom: 1em; padding: 4px 0 4px 16px; background: url(img/blog/diamond.png) left center no-repeat; background-size: 8px auto; border-top: 1px dotted #78c3e2; border-bottom: 1px dotted #78c3e2; font-size: 1.5rem; color: #78c3e2;}
#body p { margin-bottom: 20px;}
#body ul { display: grid; gap: 8px; margin: 20px 0;}
#body ul li { padding-left: 20px; background: url("img/blog/check.png") left center no-repeat; background-size: 14px auto;}
#body strong { font-weight: 700; color: #f39fb9;}
.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;}

.pickup { position: relative; margin-top: 40px; margin-bottom: 20px; padding: 32px 16px 16px; background: #f1f9fc; border-radius: 20px;}
.pickup::before { content: ''; position: absolute; top: 0; left: 50%; transform: translate(-50%,-40%); width: 146px; height: 30px; background: url("img/blog/pickup.png") center no-repeat; background-size: contain;}
.pickup::after { content: ''; display: block; clear: both;}
.pickup figure { float: left; width: 45%; max-width: 135px; margin-right: 16px;}
.pickup p { margin-bottom: 4px!important; word-break: break-all; line-height: 1.2;}
.tagbox { position: relative; margin: 30px 0 20px; padding: 16px; background: #ffffef; border: 2px solid #78c3e2; border-radius: 10px;}
#body .tagbox h4 { padding-top: 0; padding-left: 0; background:  none; border-top: none; font-size: 1.7rem;}
.tagbox ul { margin: 0!important;}
#body blockquote { position: relative; margin: 2em 0; padding: 16px; border: 1px solid #78c3e2; border-radius: 10px;}

/*CONTACT*/
.contactform { width: 100%; margin: 24px 0 0;}
.contactform input, .contactform select, .contactform textarea { width: 100%; max-width: 100%; min-height: 48px; padding: 8px; vertical-align: middle; border: 1px solid #616161; 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;}
.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 #616161; border-radius: 0; box-shadow: 0 0 0 transparent inset; appearance: none;}
.contactform input[type='checkbox']:checked { background-color: #f39fb9;}
.contactform label { display: inline-block; margin: 16px 0; line-height: 1; padding: 6px; background-color: #fdf2f5; 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: #f39fb9; 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;}
.wpcf7-submit, .wpcf7-previous { width: 100%; max-width: 360px; margin: 16px auto; font-size: 1.8rem; font-weight: bold; display: block; padding: 16px; text-align: center; color: #ffffff; border-radius: 40px; background-color: #f39fb9; box-shadow: 0 5px 0 #ea7a9d; font-family: "fot-tsukuardgothic-std", sans-serif;}
.wpcf7-previous { background-color: #c5c5c5; box-shadow: 0 5px 0 #afafaf;}
.wpcf7-spinner { display: block; margin: 0 auto;}
.wpcf7-not-valid-tip { margin-top: 0.5em;}
.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: #717171;}
.contactform .wpcf7-not-valid { background-color: #fdf2f5; border-color: #f39fb9;}
.confirmed { border-top: 2px dotted #e4eef5;}
.confirmed th { padding-top: 10px; padding-bottom: 4px;}
.confirmed td { padding-bottom: 10px; border-bottom: 2px dotted #e4eef5;}
.notice span { position: relative; display: inline-block; padding: 16px 20px; text-align: center; background: #eeeeee; border-radius: 40px;}
.notice span::after { content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); width: 0; height: 0; border-style: solid; border-color: #eeeeee transparent transparent transparent; border-width: 10px 5px 0px 5px;}





@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: 80%;}
	.sp { display: none;}
	.pc { display: block;}
	.nav { justify-content: center; gap: 8px; padding-top: 24px;}
	.nav li { width: auto; border-bottom: none;}
	.nav li:nth-child(odd) { border-right: none;}
	.nav li:not(:first-child) { border-left: 1px solid #717171;}
	.nav li a { padding: 0 16px; font-size: 1rem;}

	#main { max-width: 820px; margin: 90px auto 0;}
	article.full { width: 100vw; margin: 0 calc(50% - 50vw);}
	.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;}
	.flow li { align-items: center;}

	/*TOP*/
	.trouble, .solution, .access, .station, .faq { max-width: 580px; margin-left: auto; margin-right: auto;}
	.especially { display: flex; align-items: center; gap: 40px;}
	.work { display: grid; grid-template-columns: 35% 1fr; gap: 20px;}
	.work h2 { grid-column: 1 / 3;}
	.work figure { width: 100%;}
	.promise li { display: grid; grid-template-columns: 50% 1fr; align-items: center; gap: 20px; padding: 30px 20px; background: #f1f8fa; border-radius: 10px;}
	.promise li .num { width: 15%;}
	.review { max-width: 720px; margin-left: auto; margin-right: auto;}
	.prof { grid-template-columns: 20% 1fr;}
	.environment li { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 10px 20px; padding: 30px 40px;}
	.environment li .num { position: relative; left: 0; transform: translate(0,0); margin: 0 auto;}
	.environment figure { grid-column: 2 / 3; grid-row: 1 / 4;}
	.blog .w60 { max-width: 400px;}
	.photo-t { width: 70%; margin: 0 auto; background-size: auto 100%, auto 100%;}
	.photo ol { grid-template-columns: repeat(2,1fr); gap: 40px;}
	.infolist { display: grid; grid-template-columns: repeat(2,1fr); gap: 20px;}
	.faq h2 { width: 60%; margin: 0 auto;}
	.cta h2 { width: 60%; margin: 0 auto;}


	/*BLOG*/
	.swiper-button-next:after, .swiper-button-prev:after { width: 40px; height: 40px;}

	.confirmed th { padding: 10px 0;  border-bottom: 2px dotted #e4eef5;}
	.confirmed td { padding: 10px 0;}
}





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