@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@700&family=Noto+Sans+JP:wght@500;700;900&display=swap');


/*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,picture,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}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}
a { color: #222; text-decoration: none;}
@media screen and (min-width: 768px){ a { transition: opacity .2s ease-out, background .2s ease-out;} a:hover { filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=60); opacity: 0.6;}}
*:focus { outline: none;}


/*LAYOUT*/
/*******************************************************************/
html { font-size: 62.5%;}
body { -webkit-text-size-adjust: 100%; touch-action: manipulation; font-family: 'Noto Sans JP', "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif; font-size: 1.6rem; font-weight: 500; line-height: 1.4; font-feature-settings: "palt"; color: #222;}
#container { position: relative; width: 100%; overflow: hidden;}
i { font-family: 'Roboto', sans-serif; font-weight: 700; line-height: 1;}
#loading { z-index: 100000; position: fixed; top: 0; left: 0; right: 0; bottom: 0; margin: auto; background: #FFF url("../img/common/loading.svg") center no-repeat;}


/*HEADER*/
/*******************************************************************/
#header { position: relative; display: flex; justify-content: space-between; align-items: center; width: 100%; height: 400px;}
#logo { position: absolute; top: 32px; left: 32px; width: 30%; z-index: 10;}
.recruit a, .contact a { position: relative; display: flex; flex-direction: column; justify-content: center; align-items: center; width: 120px; height: 120px; font-size: 2rem; font-weight: 700; color: #FFF; z-index: 10;}
.recruit a { background: #37240F;}
.contact a { background: #015838;}
.contact a img { margin-top: 8px;}
.tel { margin-right: 40px;}
.tel a { display: inline-block; padding-left: 48px; background: url("../img/common/tel.svg") left center no-repeat; font-size: 4rem; line-height: 1; color: #FFF; white-space: nowrap;}
#mv { position: fixed; top: 0; left: 0; width: 100%; height: 400px; z-index: -10;}
#mv::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 230px; background: rgb(0,0,0); background: linear-gradient(0deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.4) 100%); z-index: 10;}
#mv h1 { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); font-size: 4rem; letter-spacing: 0.1em; color: #FFF; z-index: 10;}
#mv h1 img { height: 20vh; max-height: 157px;}
#mv::before { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 460px; height: 80px; background: #015838; z-index: 5; mix-blend-mode: multiply;}
#mv .swiper-slide { width: 100%; height: 100vh; overflow: hidden;}
@keyframes zoomUp { 0% { transform: scale(1);} 100% { transform: scale(1.1);}}
#mv .swiper-slide-active .slide-img, #mv .swiper-slide-duplicate-active .slide-img, #mv .swiper-slide-prev .slide-img { animation: zoomUp 10s linear 0s 1 normal both;}
#mv .slide-img { background-position: center; background-repeat: no-repeat; background-size: cover;}
#mv .slide-img img { width: 100%; height: 100vh; display: block;}
#mv .slide01 .slide-img { background-image: url("../img/top/slide01.jpg");}
#mv .slide02 .slide-img { background-image: url("../img/top/slide02.jpg");}
#mv .slide03 .slide-img { background-image: url("../img/top/slide03.jpg");}
#mv .swiper-caption { position: absolute; bottom: 120px; left: 3%; transform: translateX(-50px); width: 50%; z-index: 10; opacity: 0; transition: 1s cubic-bezier(.215,.61,.355,1) 2s;}
#mv .swiper-slide-active .swiper-caption, #mv .swiper-slide-duplicate-active .swiper-caption, #mv .swiper-slide-prev .swiper-caption { transform: translateX(0)!important; opacity: 1; transition-delay: 0.8s;}
#mv > figure img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover;}
.home #header { height: 100vh;}
.home #mv { height: 100vh;}
.home #mv::before { top: calc(50% - 72px); height: 30vh;}
.home #mv h1 { top: calc(50% - 72px);}
@media screen and (min-width: 1025px) {
#nav { position: static;}
.menu { position: absolute; bottom: 0; left: 0; width: 100%; display: flex; justify-content: center; background: #015838; z-index: 10;}
.menu li { flex: 1; max-width: 300px; text-align: center;}
.menu li a { display: block; padding: 24px; font-size: 2.4rem; font-weight: 700; letter-spacing: 0.1em; color: #FFF;}
.menu li.on a { background: #FFF; color: #015838}
.global { position: absolute; top: 0; right: 0; display: flex; align-items: center; z-index: 10;}
#open { display: none;}
}


/*FOOTER*/
/*******************************************************************/
#footer { position: relative; text-align: center; background: #015838; color: #FFF;}
#footer a { font-weight: 700; color: #FFF;}
#footer ul { padding: 56px 6.4vw; border-bottom: 1px solid rgba(255,255,255,.5);}
#footer li { display: inline-block; padding: 8px 16px;}
#footer dl { padding: 56px 6.4vw;}
#footer dd { margin-top: 24px; font-weight: 700;}
address { padding: 16px; text-align: center; background: #313131; font-size: 1.2rem; font-style: normal;}


/*CONTENTS*/
/*******************************************************************/
article { position: relative; padding: 96px 6.4vw;}
article::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #FFF; z-index: -5;}
article.bg::before { background: #FAFAFA;}
article header { position: relative; max-width: 1200px; margin: 0 auto 56px; text-align: center;}
article header i { position: relative; display: block; margin-bottom: 20px; font-size: 1.6rem; color: #015838;}
article header h2 { position: relative; margin-top: 24px; font-size: 3.2rem;}
article header::after { content: ''; display: inline-block; width: 50px; height: 3px; background: #015838; margin-top: 20px;}
section { position: relative; max-width: 1200px; margin: 0 auto;}
section + header, section + section { margin-top: 96px;}
section h2 { position: relative; margin-bottom: 30px; font-size: 3.2rem; line-height: 1.6;}
section * + h2 { margin-top: 50px;}
section h3 { position: relative; margin-bottom: 40px; padding-left: 20px; font-size: 2.4rem; line-height: 1.6;}
section > * + h3 { margin-top: 50px;}
section h3::before { content: ''; position: absolute; top: 0.8em; left: 0; width: 12px; height: 2px; background: #015838;}
section h4 { margin-bottom: 15px; font-size: 2rem; line-height: 1.6; color: #015838;}
section > * + h4 { margin-top: 40px;}
section table { width: 100%; border-collapse: collapse; border-top: 1px solid #D4D4D4;}
section tr { border-bottom: 1px solid #D4D4D4;}
section th { width: 28%; padding: 24px; text-align: left; vertical-align: middle; background: #F7F7F7; font-weight: 500;}
section td { padding: 24px; background: #FFF;}
section td p { margin: 0;}
section td table, section td tr { border: none;}
section td th, section td td { padding: 2px 0;}
section figure { position: relative;}
section figcaption { display: block; margin-top: 8px; font-size: 1.4rem;}
section p { margin-top: 15px; margin-bottom: 15px; line-height: 1.9;}
section table, section > ol, section > ul, section figure { margin-top: 20px; margin-bottom: 20px; line-height: 1.9;}
section *:first-child { margin-top: 0;}
section > * ~ *:last-child { margin-bottom: 0;}
section ul li { position: relative; padding-left: 1em;}
section ul li::before { content: ''; position: absolute; top: calc(50% - 2px); left: 0; width: 4px; height: 4px; background: #000; border-radius: 50%;}
section ol { margin-left: 1.5em; list-style: decimal;}
section.sep { padding-top: 96px; border-top: 1px solid #D4D4D4;}
.full { max-width: initial; margin-left: -6.4vw; margin-right: -6.4vw;}
.center { text-align: center!important;}
.right { text-align: right!important;}
.left { text-align: left!important;}
.row { display: flex; max-width: initial; margin-left: -28px; margin-right: -28px;}
.row > * { flex: 1; margin: 0 28px;}
.reverse { flex-direction: row-reverse;}
.w35 { flex: none; width: calc(35% - 56px);}
.btn { display: flex; margin: 40px -3px 0; text-align: center;}
.btn li { flex: 1; margin: 0 3px;}
.btn a { position: relative; display: inline-block; width: 100%;  padding: 23px 72px; text-align: center; background: #D8E858; border-radius: 40px; font-size: 2.3rem; font-weight: 700;}
.btn a::after { content: ''; position: absolute; top: calc(50% - 8px); right: 32px; width: 16px; height: 16px; background: url("../img/common/arr.svg") center no-repeat;}
.sp { display: none;}
.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.7s; animation-delay: 0.2s; animation-fill-mode: both;}


/*TOP*/
#news { background: #FFF url("../img/top/tree.svg") 5% bottom no-repeat;}
#news > div { position: relative; display: flex; max-width: 1200px; margin: 0 auto;}
#news header { width: 20%; text-align: left;}
#news section { flex: 1;}
.news dl { margin-top: -24px;}
.news dt { clear: left; float: left; padding: 24px;}
.news dd { padding: 24px 24px 24px 176px; border-bottom: 1px solid #D4D4D4;}
.news dd:last-of-type { padding-bottom: 0; border-bottom: none;}
#service, #recruit { padding-top: 0; padding-bottom: 0;}
.servicelist { display: flex; flex-wrap: wrap; margin: 0; list-style: none;}
.servicelist li { width: 50%; border-bottom: 1px solid #FFF;}
.servicelist li:nth-child(even) { border-left: 1px solid #FFF;}
.servicelist li a, #recruit a { position: relative; display: flex; justify-content: space-between; align-items: center; min-height: 350px; padding: 24px 6.4vw; color: #FFF;}
.servicelist li a figure, #recruit a figure { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: -1; overflow: hidden;}
.servicelist li a figure::after, #recruit a figure::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #000; opacity: .2; transition: .2s ease-out;}
.servicelist li a figure img, #recruit a figure img { width: 100%; height: 100%; object-fit: cover; transition: 1s ease-out;}
.servicelist li a h3 { margin: 0; padding-left: 0; font-size: 4.5rem;}
.servicelist li a h3::before { display: none;}
.servicelist li a p { max-width: 700px; margin-top: 24px; margin-right: 6.4vw;}
.servicelist li a .num { position: absolute; top: 50%; left: 2.4vw; transform: translateY(-50%); font-size: 1.1rem; letter-spacing: 0.1em; -ms-writing-mode: tb-rl; writing-mode: vertical-rl;}
.servicelist li a .more { display: flex; align-items: center; white-space: nowrap;}
.servicelist li a .more::after { content: ''; display: inline-block; width: 104px; height: 104px; margin-left: 16px; background: #FFF url("../img/common/arrow.svg") center no-repeat; border-radius: 50%;}
.servicelist li a:hover { opacity: 1;}
.servicelist li a:hover figure::after, #recruit a:hover figure::after { opacity: .5;}
.servicelist li a:hover figure img, #recruit a:hover figure img { transform: scale(1.05);}
#recruit a { flex-direction: column; justify-content: center; align-items: flex-start; height: 545px;}
#recruit a i { display: block; margin-bottom: 16px; font-size: 7.8rem;}
#recruit a h3 { margin: 0; padding-left: 0; font-size: 2.4rem;}
#recruit a h3::before { display: none;}
#recruit a h3 span { font-size: 3.2rem;}


/*PAGE*/
.column { columns: 4;}
.column.three { columns: 3;}
.map { flex: none; width: 60%;}
.entry { justify-content: center;}
.entry > * { display: flex; justify-content: center; align-items: center; padding: 24px; border: 1px solid #CCC; border-radius: 8px;}
.form form { max-width: 1000px; margin: 0 auto;}
.form input[type="text"], .form input[type="tel"], .form input[type="email"], .form input[type="date"] { width: calc(100% - 16px); margin: 8px; padding: 16px; background: #F7F7F7; border: 1px solid #CCC; border-radius: 4px; vertical-align: middle;}
.form textarea { width: calc(100% - 16px); min-height: 160px; margin: 8px; padding: 16px; background: #F7F7F7; border: 1px solid #CCC; border-radius: 4px;}
.submit { margin-top: 40px; text-align: center;}
.submit input[type='submit'] { display: inline-block; width: 320px; max-width: 100%; padding: 16px; text-align: center; background: #015838 url("../img/common/arr_w.svg") right 16px center no-repeat; border-radius: 8px; font-size: 2.4rem; color: #FFF;}
.submit input[type='submit']:not(.disabled):hover { opacity: 0.7;}
.form ::-webkit-input-placeholder { font-weight: 700; letter-spacing: 0.1em; color: #FFF;}
.form ::-moz-placeholder { font-weight: 700; letter-spacing: 0.1em; color: #FFF;}
.form :-ms-input-placeholder { font-weight: 700; letter-spacing: 0.1em; color: #FFF;}
.form .short { width: 25%!important;}
.must { margin-left: 24px; padding: 2px 4px; background: #015838; border-radius: 2px; font-size: 1.3rem; font-weight: bold; color: #FFF;}
.catch { text-align: center; font-size: 2.8rem; font-weight: 900; letter-spacing: 0.05em;}
.name span { font-size: 1.8rem;}
body.gaiyou #container::after { content: ''; position: fixed; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 460px; height: 460px; background: url("../img/gaiyou/logo.svg") center no-repeat; pointer-events: none; opacity: 0.5; z-index: -1;}




@media screen and (max-width: 1280px) {
.servicelist li a { min-height: 280px;}
.servicelist li a h3 { font-size: 3.2rem;}
.servicelist li a .more::after { width: 56px; height: 56px;}
}





@media screen and (max-width: 1024px) {
body { font-size: 1.4rem;}
#header { height: 240px;}
#logo { top: 24px; left: 16px; width: 64%;}
#nav { pointer-events: none; opacity: 0; transform: scale(0.9); position: fixed; top: 0; left: 0; display: flex; flex-direction: column; justify-content: center; align-items: center; width: 100%; max-width: 100%; height: 100vh; margin: 0; text-align: center; background: #015838; overflow: auto; z-index: 200; -webkit-transition: .8s cubic-bezier(.19,1,.22,1); transition: .8s cubic-bezier(.19,1,.22,1);}
#nav li { opacity: 0; -webkit-transform: translateY(-50px); transform: translateY(-50px); padding: 12px 0; text-align: center; -webkit-transition: .6s cubic-bezier(.19,1,.22,1); transition: .6s cubic-bezier(.19,1,.22,1);}
#nav li:nth-of-type(1) { -webkit-transition-delay: .14s; transition-delay: .14s;}
#nav li:nth-of-type(2) { -webkit-transition-delay: .18s; transition-delay: .18s;}
#nav li:nth-of-type(3) { -webkit-transition-delay: .22s; transition-delay: .22s;}
#nav li:nth-of-type(4) { -webkit-transition-delay: .26s; transition-delay: .26s;}
#nav li:nth-of-type(5) { -webkit-transition-delay: .30s; transition-delay: .30s;}
#nav li:nth-of-type(6) { -webkit-transition-delay: .34s; transition-delay: .34s;}
#nav li:nth-of-type(7) { -webkit-transition-delay: .38s; transition-delay: .38s;}
#nav li:nth-of-type(8) { -webkit-transition-delay: .42s; transition-delay: .42s;}
#nav li a { color: #FFF;}
.menu li a { font-size: 2rem;}

.recruit a, .contact a { width: auto; height: auto; padding: 16px; font-size: 2rem;}
.contact a { display: flex; flex-direction: row-reverse; background: rgba(255,255,255,.2);}
.contact a img { margin: 0 8px 0 0;}
.tel { margin: 0;}
.tel a { padding-left: 32px; background-size: 24px auto; font-size: 3.2rem; line-height: 1;}
#open { position: fixed; top: 24px; right: 24px;  text-align: center; transition: .2s ease-in-out; pointer-events: auto; cursor: pointer; z-index: 9999;}
#open div { position: relative; display: block; width: 36px; height: 16px;}
#open span { position: absolute; left: 0; display: block; width: 36px; height: 2px; background: #015838; transition: .2s ease-in-out;}
#open span:nth-child(1) { top: 0;}
#open span:nth-child(2) { top: 9px;}
#open span:nth-child(3) { top: 18px;}
.open #open span:nth-child(1) { top: 9px; transform: rotate(-45deg); background: #FFF;}
.open #open span:nth-child(2) { width: 0;}
.open #open span:nth-child(3) { top: 9px; transform: rotate(45deg); background: #FFF;}
.open #nav { pointer-events: auto; opacity: 1; transform: scale(1);}
.open #nav li { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0);}

#mv { height: 240px;}
#mv::before { width: 80%;}
#mv h1 { font-size: 2.8rem;}
#mv .swiper-caption { bottom: 24px; left: 24px; width: calc(100% - 48px);}
.home #mv::before { top: 50%;}
.home #mv h1 { top: 50%;}

article { padding: 64px 6.4vw;}
article header { margin-bottom: 40px;}
article header h2 { font-size: 2.8rem;}
section + section { margin-top: 48px;}
section h3 { font-size: 2rem;}
section th { display: block; width: auto; padding: 24px 0 0; background: none;;}
section td { display: block; padding: 16px 0 24px; background: none;}
article p, article dl, article table { line-height: 1.8;}
.row { display: block; margin: 0!important;}
.row > * { width: auto!important; margin: 0!important;}
.row > *:not(:first-child) { margin-top: 40px!important;}
.btn { display: block; margin: 0;}
.btn li { margin: 8px 0;}
.btn a { font-size: 1.8rem;}
.btn a::after { right: 16px;}
.sp { display: block;}
.pc { display: none;}


/*TOP*/
#news > div { display: block;}
#news header { width: auto; text-align: center;}
.news dl { margin-top: -24px;}
.news dt { float: none; padding: 24px 0 0;}
.news dd { padding: 16px 0 24px;}
.servicelist { display: block;}
.servicelist li { width: auto;}
.servicelist li:nth-child(even) { border-left: none;}
.servicelist li a, #recruit a { display: block; min-height: initial; padding: 40px;}
.servicelist li a h3 { font-size: 3.2rem;}
.servicelist li a .more { justify-content: flex-end;}
.servicelist li a .more::after { width: 56px; height: 56px;}
.servicelist li a:hover { opacity: 1;}
#recruit a { height: auto;}
#recruit a i { font-size: 4rem;}
#recruit a h3 { font-size: 1.6rem;}
#recruit a h3 span { font-size: 2rem;}


/*PAGE*/
.column { columns: 2;}
.column.three { columns: 1;}
.catch { font-size: 1.8rem;}
body.gaiyou #container::after { width: 60%; height: 60%; background-size: contain;}
}



@media print{
body { width: 980px; height: auto;}
.animated { opacity: 1;}
}