@charset "utf-8";
@import url(https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.9.0/css/all.min.css);
/*@import url( "form.css" );*/

/**--------------------------------------- PC ---------------------------------------**/
/**-------------------------- header --------------------------**/
header {
    position: fixed;
    z-index: 998;
    width: 100%;
    height: 50px;
    background: rgba(255,255,255,.85);
}
#head-magazine {
    position: fixed;
    top: 0;
    left: 0;
}
#logo {
    width: 320px;
    height: 50px;
    background: #02311d;
    line-height: 35px;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 999;
}
#logo img {
    width: 257px;
}
#top-head {
    text-align: right;
    top: 0px;
}
#mobile-head {
    width: 100%;
    height: 60px;
    top: 0px;
    position: absolute;
}
#nav-toggle {
    display: none;
}
#global-nav ul {
    font-weight: 500;
}
#global-nav li {
    padding: 0 10px;
    height: 50px;
    line-height: 50px;
    display: inline-block;
    position: relative;
}
#global-nav li span .i-icon {
    font-size: 8px;
    margin-left: 7px;
    padding-bottom: 2px;
    transform: rotate(0deg);
    transition: .35s ease-in-out;
}
#global-nav li span.active .i-icon {
    transform: rotate(180deg);
}
#global-nav li span {
    display: block;
}
#global-nav li span:hover {
    cursor: pointer;
}
#global-nav li a {
    color: #000;
    transition: .35s ease-in-out;
    display: block;
}
#global-nav li ul {
    position: absolute;
    top: 50px;
    left: 0px;
    display: none;
    background: #173d29;
}
#global-nav li ul li {
    display: block;
    text-align: left;
    width: 200px;
    padding: 0;
    text-indent: 20px;
    border-bottom: 0.5px solid rgba(255,255,255,.40);
}
#global-nav li ul li a {
    color: #FFF;
}
#global-nav li ul li:hover {
    background: rgba(128,128,128,.50);
}
#global-nav li ul li .i-icon {
    font-size: 10px;
    margin-left: 7px;
    padding-bottom: 1px;
    display: inline-block;
}
/* Toggle Button */
#nav-toggle {
    position: absolute;
    right: 20px;
    top: 15px;
    width: 25px;
    height: 20px;
    cursor: pointer;
    z-index: 1002;
}
#nav-toggle div {
    position: relative;
}
#nav-toggle span {
    display: block;
    position: absolute;
    height: 2.5px;
    width: 100%;
    background: #000;
    left: 0;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
}
#nav-toggle span:nth-child(1) {
    top: 0;
    right: 0;
    left: auto;
    width: 70%;
}
#nav-toggle span:nth-child(2) {
    top: 8px;
}
#nav-toggle span:nth-child(3) {
    top: 16px;
    width: 70%;
}
.open #nav-toggle span:nth-child(1) {
    top: 9px;
    width: 100%;
    transform: rotate(315deg);
}
.open #nav-toggle span:nth-child(2) {
    width: 0;
    left: 50%;
}
.open #nav-toggle span:nth-child(3) {
    top: 9px;
    width: 100%;
    transform: rotate(-315deg);
}
/* #global-nav スライドアニメーション */
.open #global-nav {
    /* transform: translateY(2000px); */

    /* ヘッダー分調整 */
    transform: translateY(2050px);
    padding: 55px 0 20px;
    z-index: 997;
}

/**-------------------------- contents --------------------------**/
/**--------- contents ---------**/
#contents {
    position: relative;
    overflow-y: hidden;
}

/**--------- パンくずリスト ---------**/
.breadcrumbs {
    margin: 3em auto 6em;
    text-align: left;
    width: 1100px;
    color: #999999;
}
.breadcrumbs span {
    color: #999999;
}
.bc-blank .breadcrumbs {
    margin-top: 70px;
}
.news-bc-blank .breadcrumbs {
    margin-top: 10px;
}
.magazine-box .breadcrumbs {
    margin: 4em auto 2em;
    width: auto;
}
.magazine-bc-blank .breadcrumbs {
    margin: 1em auto 2em;
}




#mainimage {
    position: relative;
}
#mainimage .news {
    position: absolute;
    right: 0px;
    bottom: -40px;
    width: 75%;
    background: #FFF;
    padding: 10px 0;
    text-align: left;
    box-shadow: 1px 1px 3px 1px #bfbfbf;
}
#mainimage h1 {
    position: absolute;
    left: 50px;
    top: 37%;
    margin-top: -1em;
    font-size: 50px;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    z-index: 997;
    color: #FFF;
    text-shadow:1px 1px 5px #000000;
}
.news h2,
.news ul,
.news span {
    display: inline-block;
    vertical-align: middle;
}
.news h2 {
    font-size: 0.8em;
    padding: 10px 20px;
    letter-spacing: 0.05em;
    font-weight: bold;
}
.news h2:after {
    content: "";
    width: 1px;
    height: 40px;
    display: inline-block;
    background: #999;
    vertical-align: middle;
    margin-left: 20px;
}
.news ul {
    width: 70%;
}
.news li time {
    font-size: 0.8em;
    margin-top: 2px;
    display: inline-block;
    vertical-align: top;
}
.news li {
    text-overflow: ellipsis;
    white-space: nowrap;
    vertical-align: top;
    overflow: hidden;
}
.news li a {
    margin-left: 20px;
    margin-top: 2px;
    color: #000;
}
.news span {
    position: absolute;
    right: 3%;
    top: 30px;
    background: #01321d;
}
.news span img {
    margin-bottom: 9px;
    margin-right: 10px;
}
.news span a img {
    transition: .35s ease-in-out;
}
.news span a:hover img {
    margin-right: 5px;
}
.news span a {
    font-size: 10px;
    font-weight: 600;
    color: #FFF;
    letter-spacing: 0.05em;
    padding: 0 7px;
}
.b-g {
    background: #f4f7f9;
}
/*.topbox {
}*/
.topbox h2 {
    font-size: 44px;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    line-height: 1.4em;
}
.topbox h2 span {
    font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
    font-size: 16px;
    font-weight: 500;
    display: inline-block;
    vertical-align: middle;
    margin-left: 20px;
}
#lead {
    padding: 80px 0 100px;
    overflow: hidden;
}
#lead figure {
    width: 50%;
    margin: 0 auto;
}
#lead h2 {
    font-size: 30px;
    padding: 30px 0 30px;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    font-weight: bold;
}
#lead p {
    width: 720px;
    margin: auto;
    text-align: left;
    padding-bottom: 30px;
}
#lead p span {
    display: block;
}
.w-con {
    width: 880px;
    margin: 0 auto;
}
#recbox {
    position: relative;
    padding-bottom: 140px;
}
#recbox h2 {
    text-align: left;
    margin-top: -40px;
    margin-left: 10%;
    padding-bottom: 30px;
}
#recbox section {
    width: 46%;
    margin: 0 1.5%;
    display: inline-block;
    vertical-align: top;
    position: relative;
    z-index: 1;
}
#recbox section div {
    width: 90%;
    margin: -30px auto 0;
    position: relative;
    z-index: 2;
    background: rgba(255,255,255,1.00);
    padding: 20px 0;
    box-shadow: 1px 1px 2px 1px #bfbfbf;
}
#recbox section div h3 {
    width: 90%;
    margin: 0 auto;
    font-size: 20px;
    font-weight: bold;
    color: #333;
    transition: .35s ease-in-out;
    padding-bottom: 10px;
}
#recbox section div p {
    font-size: 1em;
    width: 90%;
    margin: 0 auto;
    text-align: left;
    line-height: 1.3em;
}
#recbox section div ul li {
    padding: 20px 0 10px;
}
#recbox section div ul li a {
    display: block;
    width: 210px;
    margin: 0 auto;
    font-weight: 500;
    color: #FFF;
    background: #01321d;
    letter-spacing: 0.1em;
    padding: 8px 0;
    border-radius: 3px;
    transition: .35s ease-in-out;
    box-shadow: 1px 1px 2px 1px #bfbfbf;
}
#recbox section div ul li a img {
    display: inline-block;
    vertical-align: middle;
    margin: 0 10px 3px;
    transition: .35s ease-in-out;
    width: 20px;
}
#recbox section:last-of-type {
    width: 60%;
    margin: 30px auto 0;
    display: block;
    padding: 30px 0;
    background: rgba(255,255,255,1.00);
    box-shadow: 1px 1px 2px 1px #bfbfbf;
}
#recbox section:last-of-type h3 {
    width: 60%;
    margin: 0 auto;
    display: block;
    width: 90%;
    font-size: 20px;
    font-weight: bold;
}
#recbox section:last-of-type h3 span a {
    display: inline-block;
    width: 150px;
    margin: 0 auto;
    font-weight: 500;
    color: #FFF;
    background: #01321d;
    letter-spacing: 0.1em;
    padding: 8px 0;
    border-radius: 3px;
    transition: .35s ease-in-out;
    box-shadow: 1px 1px 2px 1px #bfbfbf;
    font-size: 16px;
    margin-left: 20px;
}
#recbox section:last-of-type h3 span a img {
    display: inline-block;
    vertical-align: middle;
    margin: 0 10px 3px;
    transition: .35s ease-in-out;
    width: 20px;
}
#rec-it {
    padding: 60px 0 170px;
}
#rec-it figure {
    width: 80%;
    margin: 0 auto;
}
#rec-it figure a img {
    opacity: 1;
    transition: .35s ease-in-out;
    border: 1px solid #ccc;
}
#rec-it figure a:hover img {
    opacity: 0.9;
    border: 1px solid #666;
}
#service-box {
    padding-bottom: 30px;
}
#service-box .w-con {
    position: relative;
}
#service-box h2 {
    position: absolute;
    right: 10%;
    top: -40px;
}
#service-box div div {
    width: 48%;
    display: inline-block;
    text-align: center;
    margin: 60px 1% 0 0;
}
#service-box div div:nth-of-type(2) {
    margin-right: 0;
}
#service-box div div figure img {
    width: 97%;
}
#service-box div div section {
    width: 92%;
    position: relative;
    background: #f4f7f9;
    margin-top: -60px;
    margin-left: 7%;
    padding-bottom: 30px;
    transition: .35s ease-in-out;
    text-align: left;
}
#service-box div div:nth-of-type(2) section {
    margin-left: 0%;
}
#service-box div div section a {
    display: block;
}
#service-box div div section a h3 {
    font-size: 20px;
    font-weight: bold;
    padding-top: 20px;
    color: #333;
    letter-spacing: 0.2em;
    transition: .35s ease-in-out;
    padding-left: 20px;
}
#service-box div div section:hover a h3 {
    color: #666;
}
#service-box div div section a h3 img {
    display: inline-block;
    vertical-align: middle;
    margin: 0 7px 3px;
    transition: .35s ease-in-out;
    width: 15px;
}
#service-box div div section:hover a span {
    background: #999;
}
#service-box div div section a h3 span {
    font-size: 11px;
    font-weight: 500;
    color: #FFF;
    background: #01321d;
    letter-spacing: 0.1em;
    padding: 8px 10px;
    border-radius: 3px;
    position: absolute;
    right: 10px;
    top: 37px;
    transition: .35s ease-in-out;
}
#service-box div div section a p {
    color: #333;
    padding-left: 20px;
    font-size: 0.9em;
}
#service-box div div section:hover {
    background: #fff;
}
.w80 {
    width: 80%;
    margin: 0 auto;
}
.search {
    padding: 0 0 120px;
}
.search .w80 {
    padding: 40px 0;
    background: #FFF;
}
.search h2 {
    padding: 0 0 15px;
    font-weight: bold;
    font-size: 18px;
}
.search h2 .i-icon {
    margin-right: 10px;
}
form select {
    border: none;
    padding: 15px 40px 15px 20px;
    background: #edf1f3;
    position: relative;
}
form p {
    display: inline-block;
    margin: 0 2% 20px;
    position: relative;
}
.f-select p {
    display: inline-block;
    margin: 0 2% 20px;
    position: relative;
}
select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
form select:hover {
    cursor: pointer;
}
form p:after {
    font-family: "Font Awesome 5 Free";
    content: '\f0dd';
    font-weight: 900;
    position: absolute;
    right: 15px;
    bottom: 15px;
    pointer-events: none;
}
.terms button {
    width: 260px;
    border: none;
    padding: 10px 0;
    background: #0b321d;
    border: 0.3px solid #333;
    transition: .35s ease-in-out;
    color: #FFF;
    border-radius: 3px;
    box-shadow: 1px 1px 2px 1px #bfbfbf;
}
.terms button .i-icon {
    margin-right: 10px;
    color: #FFF;
    transition: .35s ease-in-out;
}
.terms button:hover {
    cursor: pointer;
    background: #E8E8E8;
    color: #000;
}
.terms button:hover .i-icon {
    color: #000;
}
#care-other {
    padding: 70px 0 140px;
    font-size: 0;
}
#care-other section {
    width: 47%;
    margin-right: 5%;
    display: inline-block;
    font-size: 15px;
}
#care-other section:nth-of-type(2) {
    margin-right: 0;
}
#care-other section a figure {
    overflow: hidden;
    width: 100%;
    height: 250px;
}
#care-other section a figure img {
    display: block;
    transition: .35s ease-in-out;
}
#care-other section a:hover figure img {
    transform: scale(1.1);
    transition: .35s ease-in-out;
}
#care-other section a p {
    padding: 10px 0 0;
    color: #333;
}
#care-other section a h2 {
    color: #333;
    font-weight: bold;
    transition-duration: 0.5s;
    font-size: 18px;
}
#care-other section a h2 img {
    display: inline-block;
    vertical-align: middle;
    margin-bottom: 4px;
    margin-right: 13px;
    transition: .35s ease-in-out;
}
#care-other section a:hover h2 img {
    margin-right: 8px;
    margin-left: 5px;
}
#care-other section a:hover h2 {
    color: #666;
}
#magazine {
    padding: 60px 0 40px;
    position: relative;
}
#magazine h2 {
    text-align: left;
    padding-bottom: 20px;
    position: absolute;
    left: 0px;
    top: -40px;
}
#magazine article {
    width: 29%;
    margin-right: 5%;
    display: inline-block;
    text-align: left;
    vertical-align: top;
}
#magazine article:nth-of-type(3) {
    margin-right: 0%;
}
#magazine article figure {
    width: 100%;
    height: 250px;
    background-position: center center;
    background-size: cover;
}
#magazine article a figure {
    transition: .35s ease-in-out;
}
#magazine article a:hover figure {
    transform: scale(1.1);
    transition: .35s ease-in-out;
}
#magazine article div {
    background: #FFF;
    position: relative;
    margin-top: -30px;
    width: 85%;
}
#magazine article a div {
    background: #FFF;
    transition-duration: 0.5s;
}
#magazine article a:hover div {
    background: rgba(255,255,255,.80)
}
#magazine article a h3 {
    color: #333;
    font-weight: 500;
    padding: 10px 7px 5px;
    line-height: 1.4em;
    transition-duration: 0.5s;
}
#magazine article a:hover h3 {
    color: #000;
}
#magazine article a p {
    color: #333;
    font-size: 0.8em;
    padding: 0 7px;
}
.morelink {
    display: block;
    text-align: right;
    padding: 10px 0;
}
.morelink a img {
    display: inline-block;
    margin-right: 15px;
    margin-bottom: 8px;
    transition: .35s ease-in-out;
}
.morelink a:hover img {
    margin-right: 10px;
}
.morelink a {
    display: inline-block;
    font-weight: 500;
    color: #FFF;
    background: #01321d;
    letter-spacing: 0.1em;
    padding: 8px 10px;
    border-radius: 3px;
    transition: .35s ease-in-out;
    box-shadow: 1px 1px 2px 1px #bfbfbf;
    font-size: 12px;
}
.morelink a img {
    display: inline-block;
    vertical-align: middle;
    margin: 0 10px 3px;
    transition: .35s ease-in-out;
    width: 20px;
}
.morelink a:hover {
    color: #666;
}

#reclinks {
    display: flex;
    padding: 60px 0;
}
#reclinks div:nth-of-type(2) {
    padding: 0 2%;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 40%;
}
#reclinks.itlinks div:nth-of-type(2) {
    min-width: 395px;
}

#reclinks div:nth-of-type(3) {
    margin-right: 2%;
}
#reclinks div h2 {
    font-size: 18px;
    font-weight: bold;
    padding-bottom: 10px;
}
#reclinks div p {
    line-height: 1.4em;
}
#reclinks div ul {
    padding: 20px 0;
}
#reclinks div ul li {
    width: 240px;
    margin: 0 auto;
    margin-top: 30px;
}
#reclinks div ul li a {
    display: block;
    font-weight: 500;
    color: #FFF;
    background: #01321d;
    letter-spacing: 0.1em;
    padding: 8px 10px;
    border-radius: 3px;
    transition: .35s ease-in-out;
    box-shadow: 1px 1px 2px 1px #bfbfbf;
    font-size: 14px;
}
#reclinks div ul li a img {
    display: inline-block;
    vertical-align: middle;
    margin: 0 10px 3px;
    transition: .35s ease-in-out;
    width: 20px;
}
#reclinks div ul li a:hover {
    background: #E8E8E8;
}
#reclinks div ul li a:hover img {
    margin-right: 10px;
    margin-left: 5px;
}
/**--------- station ---------**/
#search-box {
    position: fixed;
    right: 0px;
    top: 120px;
    z-index: 996;
}
#search-box h2 {
    writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    width: 45px;
    line-height: 45px;
    background: #FFF;
    box-shadow:0px 0px 6px 1px #bfbfbf;
    padding: 10px 0;
    font-size: 14px;
    z-index: 998;
    transition: .35s ease-in-out;
}
#search-box h2 .i-icon {
    margin-bottom: 4px;
}
#search-box h2:hover {
    cursor: pointer;
    background: #E8E8E8;
}
.search-hidden {
    position: fixed;
    right: -610px;
    transition: .35s ease-in-out;
    background: rgba(255,255,255,.95);
    top: 70px;
    z-index: -1;
    width: 600px;
    padding: 20px 0;
    box-shadow:0px 0px 6px 1px #bfbfbf;
}
#search-box .open {
    transform: translateX(-610px);
}
#side_searchbox.terms {
    position: relative;
    width: 550px;
    margin: 0 0 0 20px;
}
.search-hidden .f-select {
    text-align: left;
}
.f-select select {
    border: none;
    padding: 15px 40px 15px 20px;
    background: #edf1f3;
    position: relative;
}
.f-select select:hover {
    cursor: pointer;
}
.f-select p:after {
    font-family: "Font Awesome 5 Free";
    content: '\f0dd';
    font-weight: 900;
    position: absolute;
    right: 15px;
    bottom: 15px;
    pointer-events: none;
}
.search-hidden p {
    text-align: left;
    width: 230px;
    background: #edf1f3;
    margin: 0 20px 10px 0;
}
.search-hidden p:after {
    bottom: 10px;
    right: 5%;
}
.search-hidden select {
    padding: 10px 14% 10px 10%;
}
.search-hidden h3 {
    text-align: left;
    font-weight: bold;
    padding: 10px 0 5px;
}
.search-hidden ul {
    text-align: left;
    padding-bottom: 20px;
}
.search-hidden ul li {
    display: inline-block;
    margin-bottom: 6px;
}
.checkbox-input {
    display: none;
}
.checkbox-parts {
    padding-left: 20px;
    position:relative;
    margin-right: 20px;
}
.checkbox-parts::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 15px;
    height: 15px;
    border: 1px solid #999;
    border-radius: 4px;
}
.checkbox-input:checked + .checkbox-parts {
    color: #05311b;
}
.checkbox-input:checked + .checkbox-parts::after {
    content: "";
    display: block;
    position: absolute;
    top: -1px;
    left: 4px;
    width: 7px;
    height: 10px;
    transform: rotate(40deg);
    border-bottom: 2px solid #05311b;
    border-right: 2px solid #05311b;
}
.station-wrap {
    background: #eef1f3;
    padding-top: 80px;
}
.station-box {
    width: 90%;
    margin: 0 auto;
    padding-bottom: 30px;
}
.station-box h1,
.station-box h2,
.station-recbox h1 {
    font-size: 26px;
    font-weight: bold;
}
.station-recbox h2 {
    font-size: 20px;
    padding: 10px 20px;
    border-top: 1px solid #999;
    border-bottom: 1px solid #999;
    display: inline-block;
    margin: 20px 0;
}
.station-recbox h2 img {
    width: 60px;
    display: block;
    margin: 0 auto;
}
.station-recbox .date {
	text-align:right;
	width:1100px;
	max-width:96%;
	margin:0px auto;
}


.s-type {
    padding: 20px 0;
}
.s-type p {
    height: 45px;
    line-height: 45px;
    padding: 0 0 0 60px;
    display: inline-block;
    margin: 0 10px 10px;
    border: 1px solid #999;
    background: #FFF;
    position: relative;
}
.s-type p span {
    display: inline-block;
    padding: 0px 20px;
}
.s-type p:before {
    display: block;
    content: "";
    width: 60px;
    height: 45px;
    position: absolute;
    left: 0px;
}
.type-attendant:before {
    background: url("../image/css/main/icon-attendant.svg") no-repeat;
}
.type-in-home:before {
    background: url("../image/css/main/icon-in-home.svg") no-repeat;
}
.type-dayservice:before {
    background: url("../image/css/main/icon-dayservice.svg") no-repeat;
}
.type-shortstay:before {
    background: url("../image/css/main/icon-shortstay.svg") no-repeat;
}
.type-specific-facility:before {
    background: url("../image/css/main/icon-specific-facility.svg") no-repeat;
}
.type-residence:before {
    background: url("../image/css/main/icon-residence.svg") no-repeat;
}
.type-equipment:before {
    background: url("../image/css/main/icon-equipment.svg") no-repeat;
}
#gmap_pc {
    width: 100% !important;
}
.station-box .address {
    width: 80%;
    margin: 0 auto;
    padding: 20px 0 30px;
    background: #FFF;
}
.station-box .address figure {
    display: inline-block;
    margin-right: 20px;
    width: 140px;
    height: 140px;
    border-radius: 50%;
    vertical-align: middle;
    background-position: center center;
    background-size: cover;
}
.station-box .address figure span {
    display: block;
    padding-top: 145px;
}
.station-box .address div {
    width: 70%;
    display: inline-block;
    text-align: left;
    vertical-align: middle;
}
.station-box .address div p {
    line-height: 1.3em;
    padding-bottom: 7px;
}
.station-box .address div ul {
    padding-bottom: 10px;
}
.station-box .address div ul li a {
    color: #000;
    padding-right: 20px;
}
.station-box .map {
    padding: 0 0 30px;
}
.near-station {
    padding: 40px 0;
}
.near-station h2 {
    font-size: 20px;
    font-weight: bold;
    padding-bottom: 20px;
}
.near-box {
    width: 980px;
    margin: 0 auto 20px;
    border: 1px solid #999;
    text-align: left;
    position: relative;
}
.near-box a {
    text-align: left;
    color: #000;
    display: block;
}
.near-box h3 {
    display: table-cell;
    vertical-align: middle;
    width: 270px;
    height: auto;
    padding: 20px;
    background: #e0e0e0;
    font-weight: bold;
}
.near-box .near-type {
    display: table-cell;
    vertical-align: middle;
    width: 120px;
    padding: 10px 15px;
}
.near-box .near-type li {
    border: 1px solid #999;
    background: #FFF;
    display: table;
    margin: 10px 0;
    padding: 5px 10px;
    line-height: 1.2em;
}
.near-box .hide-area {
    display: table-cell;
    vertical-align: middle;
    width: 400px;
    padding: 20px;
}
/* 検索結果ページの1事業所当たりの幅を既存の検索結果より広げる */

.near-box.job .hide-area {
    display: table-cell;
    vertical-align: middle;
    width: 550px;
    padding: 20px;
}
/* ここまで */
.near-box .links {
    width: 40px;
    position: absolute;
    top: 5%;
    right: 0px;
    height: 90%;
    border-left: 1px solid #999;
    padding-left: 10px;
}
.near-box .links span {
    position: absolute;
    top: 50%;
    display: flex;
    margin-top: -1em;
}
.near-box .links li {
    margin: 0;
}
.near-box .links li:first-of-type {
    margin: 0 5px 0 10px;
}
.near-box .links li a {
    width: 35px;
    height: 35px;
    background: #00301b;
    color: #FFF;
    border-radius: 50%;
    display: block;
    text-align: center;
    line-height: 35px;
}
.near-box .links li:last-of-type a {
    background: #FFF;
    color: #00301b;
    font-size: 24px;
    padding-left: 0px;
}
.hide-open {
    display: none;
}
.recruit-station {
    border: 1px solid #999;
    position: relative;
    width: 80%;
    margin: 60px auto 0;
    font-size: 0px;
    margin-bottom: 60px;
}
.recruit-station h2 {
    position: absolute;
    text-align: center;
    width: 100%;
    top: -17px;
}
.recruit-station h2 span {
    background: #FFF;
    padding: 10px 20px;
    margin: 0 auto;
    font-size: 16px;
}
.recruit-station h2 em {
    font-weight: bold;
    display: inline-block;
    margin-right: 10px;
    font-size: 20px;
}
.recruit-station figure {
    width: 46%;
    display: inline-block;
    vertical-align: middle;
}
.recruit-station div {
    width: 48%;
    padding: 0 3%;
    display: inline-block;
    vertical-align: middle;
    font-size: 16px;
}
.recruit-station div p {
    text-align: left;
    line-height: 1.3em;
}
.recruit-station div p a {
    display: block;
    font-weight: 500;
    color: #FFF;
    background: #eb5a24;
    padding: 15px 2%;
    margin: 20px 0;
    position: relative;
    width: 90%;
}
.recruit-station div p a .i-icon {
    position: absolute;
    right: 2%;
}
.aside-number {
    font-size: 12px;
}
.station-recbox {
    background: #FFF;
    padding-top: 80px;
}
.station-recbox .mainimages {
    position: relative;
    width: 100%;
    padding: 20px 0 0;
    font-size: 0;
}
.station-recbox .mainimages figure {
    display: inline-block;
    vertical-align: middle;
    z-index: -1;
}
.station-recbox .mainimages figure img {
    width: 90%;
}
.station-recbox .mainimages figure:first-of-type {
    text-align: left;
    width: 30%;
}
.station-recbox .mainimages figure:last-of-type {
    text-align: right;
    width: 70%;
}
.station-recbox .mainimages h3 {
    position: absolute;
    background: #FFF;
    font-size: 24px;
    padding: 20px;
    top: 50%;
    margin-top: -4em;
    left: 20%;
    font-weight: bold;
    line-height: 1.3em;
    text-align: left;
    z-index: 2;
}
.station-recbox .mainimages h3 span {
    display: block;
}
.station-recbox .catch {
    font-size: 20px;
    font-weight: bold;
    padding: 20px 0 10px;
    width: 90%;
    margin: 0 auto;
}
.station-recbox .mainimages p {
    display: block;
    font-size: 18px;
    padding: 30px 0;
    width: 90%;
    margin: 0 auto;
    font-weight: 500;
    line-height: 1.3em;
}
.station-recbox .mainimages p span {
    display: block;
}
.station-recbox .rec-outline {
    display: inline-block;
    vertical-align: top;
    width: 500px;
    padding: 40px 0;
    text-align: left;
    font-size: 16px;
}
.station-recbox .rec-outline dl dt {
    width: 100px;
    padding: 3px 15px;
    display: inline-block;
    background: #f1f1f1;
    font-weight: 500;
    vertical-align: top;
}
.station-recbox .rec-outline dl dd {
    width: 340px;
    padding: 3px 10px;
    display: inline-block;
    margin-bottom: 10px;
}
.station-recbox .rec-outline ul li {
    display: inline-block;
    padding: 4px 10px;
    border: 1px solid #999;
    margin: 5px;
}
.entry {
    background: #ececec;
    padding: 30px 0;
}
.entry ul li {
    display: inline-block;
    text-align: center;
    line-height: 0.3em;
}
.entry ul li a {
    padding: 30px 60px 20px;
    color: #FFF;
    font-weight: bold;
    background: #eb5a24;
    display: block;
    font-size: 24px;
}
.entry ul li a .i-icon {
    display: block;
    margin: 0 auto;
    font-size: 30px;
}
.rec-station-wrap {
    background: #eef1f3;
    padding-top: 30px;
}
.rec-station-wrap .station-box .address div {
    width: 90%;
}
.station-reason {
    padding: 60px 0;
}
.station-reason figure {
    position: relative;
    text-align: left;
}
.station-reason figure img {
    width: 75%;
}
.station-reason figure span {
    position: absolute;
    display: block;
    padding: 20px;
    z-index: 995;
    background: #FFF;
    font-size: 24px;
    top: 50%;
    margin-top: -1em;
    left: 63%;
    font-weight: bold;
}
.station-reason section {
    padding-top: 60px;
    width: 80%;
    margin: 0 auto;
    text-align: left;
}
.station-reason section h2 {
    font-size: 20px;
    font-weight: bold;
    position: relative;
}
.station-reason section h2 span {
    font-size: 38px;
    font-weight: 500;
    position: absolute;
    top: -0.8em;
    left: -1.4em;
    margin-right: 10px;
}
.station-reason section h2:before {
    content: "";
    width: 1px;
    height: 70px;
    background: #000;
    transform: rotate(45deg);
    position: absolute;
    left: -1em;
    top: -1em;
}
.station-reason section h3 {
    font-size: 18px;
    font-weight: bold;
    color: #eb5a24;
    padding: 10px 0 15px;
}
.station-reason section p {
    font-weight: bold;
}
.rec-occu {
    background: #eef1f3;
    padding: 40px 0;
}
.rec-occu h2 {
    font-size: 20px;
    font-weight: bold;
}
.rec-occu h2 span {
    margin-right: 1em;
}
.rec-occu h2 .i-icon {
    display: inline-block;
    margin-left: 10px;
}
.rec-occu ul {
    padding: 30px 0 0;
    display: flex;
    text-align: center;
    margin: 0 auto;
    justify-content: center;
    align-items: center;
}
.rec-occu ul li {
    background: #FFF;
    position: relative;
    margin: 0 10px;
}
.rec-occu ul li a {
    display: flex;
    color: #000;
    font-weight: bold;
    padding: 0 30px;
    transition: .35s ease-in-out;
    height: 80px;
    justify-content: center;
    align-items: center;
}
.rec-occu ul li a span {
    display: block;
}
.rec-occu ul li a .i-icon {
    display: block;
    position: absolute;
    right: 8px;
    top: 50%;
    margin-top: -0.5em;
    transition: .35s ease-in-out;
}
.rec-occu ul li:hover {
    cursor: pointer;
}
.rec-occu ul li:hover .i-icon {
    right: 3px;
}
#recform-link {
    position: fixed;
    right: 0px;
    top: 300px;
    z-index: 996;
}
#recform-link h2 {
    writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    width: 45px;
    line-height: 45px;
    background: #eb5a24;
    box-shadow:0px 0px 6px 1px #bfbfbf;
    z-index: 998;
}
#recform-link h2 a {
    display: block;
    width: 45px;
    line-height: 45px;
    background: #eb5a24;
    padding: 10px 0;
    font-size: 14px;
    color: #FFF;
    transition: .35s ease-in-out;
}
#recform-link h2 a .i-icon {
    display: inline-block;
    margin-top: 6px;
    margin-left: 4px;
    font-size: 18px;
}
#recform-link h2 a:hover {
    color: #000;
    cursor: pointer;
    background: #E8E8E8;
}
.rec-detail {
    background: #f1f1f1;
    padding: 30px 0;
}
.rec-detail h2 {
    background: #f1f1f1;
    font-size: 20px;
    font-weight: bold;
    padding-bottom: 20px;
}
.rec-detail div {
    width: 90%;
    margin: 0 auto;
    background: #FFF;
    text-align: left;
    padding: 10px 0 60px;
    font-size: 16px;
}
.rec-detail div dl {
    width: 90%;
    margin: 0 auto;
}
.rec-detail div dl dt {
    font-size: 18px;
    margin-top: 30px;
    padding-bottom: 5px;
}
.rec-detail div dl dd {
    padding: 10px 15px;
    border-top: 1px solid #999;
    border-bottom: 1px solid #999;
    background: #f6f6f6;
}
/**--------- sec-main ---------**/
.sec-main .sec-images {
    position: relative;
    z-index: 1;
}
.sec-images div {
    position: absolute;
    z-index: 2;
}
.sec-images h1,
.sec-images h2,
.sec-images p {
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    padding: 5px 20px;
    text-align: left;
    background: rgba(255,255,255,.80);
    display: table;
}
.sec-images h1,
.sec-images p {
    font-size: 26px;
    margin-bottom: 10px;
}
#sdesk {
    font-size: 36px;
}
.sec-images h2 {
    font-size: 36px;
}
.cap-left div {
    left: 0px;
    top: 40%;
    margin-top: -1em;
}
.sec-in {
    padding: 60px 0;
}
.sec-in .w880 {
    width: 880px;
    margin: 0 auto;
}
.sec-in h2 {
    font-size: 20px;
    font-weight: bold;
}
.sec-in .lead {
    padding-top: 20px;
    width: 90%;
    margin: 0 auto;
    line-height: 1.3em;
}
.sec-in .lead span {
    display: block;
}
.sec-in .sub-txt {
    width: 90%;
    margin: 0 auto;
    line-height: 1.3em;
}
/**--------- rec-kaigo ---------**/
.management-in {
    padding: 30px 0;
}
.management-in figure {
    width: 175px;
    display: inline-block;
    vertical-align: top;
}
.management-in div {
    width: 665px;
    display: inline-block;
    vertical-align: top;
    text-align: left;
    margin-left: 30px;
}
.management-in div h3 {
    border-bottom: 1px solid #999;
    margin-left: -34px;
    padding-left: 34px;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    font-size: 20px;
}
.management-in div h4 {
    font-size: 14px;
    padding: 20px 0;
}
.management-in div h4 span {
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    font-size: 20px;
    margin-left: 15px;
}
.management-in .tenkai {
    padding: 5px 20px;
    background: #0b321d;
    color: #FFF;
    display: inline-block;
    border-radius: 5px;
    font-size: 14px;
}
.management-in .tenkai .i-icon {
    margin-left: 10px;
    transition: .35s ease-in-out;
}
.management-in .tenkai.active .i-icon {
    transform: rotate(180deg);
}
.management-in .tenkai:hover {
    cursor: pointer;
}
.management-in .message-in {
    margin-top: 10px;
    background: #f4f7f9;
    padding: 2.5% 0;
    margin-left: 0px;
    display: none;
}
.message-in h5 {
    font-weight: bold;
    font-size: 18px;
    padding-bottom: 10px;
    width: 95%;
    margin: 0 auto;
}
.message-in p {
    width: 95%;
    margin: 0 auto;
    line-height: 1.4em;
}
.sec-in.bg-g {
    background: #f4f7f9;
}
.rec-description div {
    padding: 30px 0;
}
.rec-description div h3 {
    background : linear-gradient(90deg, rgba(51, 201, 255, 1) 0%, rgba(0, 51, 0, 1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#33C9FF',endColorstr='#003300' , GradientType=1);
    font-size: 18px;
    color: #FFF;
    font-weight: 500;
    margin: 0 0 20px;
    padding: 5px 0;
}
.rec-description div p {
    line-height: 1.4em;
}
.rec-description div p span {
    display: block;
}
.rec-description div figure {
    width: 660px;
    margin: 0 auto;
}
.rec-description div dl {
    background: #FFF;
    padding: 10px 2%;
    text-align: left;
    width: 44.7%;
    margin-right: 2%;
    margin-bottom: 2%;
    font-size: 0;
    display: inline-block;
    vertical-align: top;
}
.rec-description div dl:nth-of-type(2) {
    margin-right: 0%;
}
.rec-description div dl dt {
    font-size: 16px;
    font-weight: bold;
    margin-top: 10px;
}
.rec-description div dl dt span {
    font-size: 30px;
    position: relative;
    margin-right: 35px;
    vertical-align: bottom;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
}
.rec-description div dl dt span:after {
    content: "";
    width: 1px;
    height: 60px;
    border-left: 1px solid #666;
    display: inline-block;
    transform: rotate(45deg);
    position: absolute;
    bottom: -20px;
    left: 1em;
}
.rec-description div dl dd {
    font-size: 14px;
    line-height: 1.4em;
    padding: 20px 0;
}
.rec-description div dl:nth-of-type(3) {
    width: 96%;
    margin-right: 0%;
    margin-bottom: 2%;
}
.rec-reason {
    padding: 30px 0;
}
.rec-reason div {
    display: flex;
    z-index: 0;
    margin-top: 20px;
}
.rec-reason div:nth-of-type(even) {
    flex-direction: row-reverse;
}
.rec-reason div figure {
    width: 140px;
}
.rec-reason div figure span {
    font-size: 12px;
    display: block;
}
.rec-reason div p {
    width: 700px;
    margin-left: 10px;
    text-align: left;
    line-height: 1.4em;
    background:#FFFFFF;
    border-radius: 20px;
    position:relative;
    filter:drop-shadow(1px 1px 2px rgba(0, 0, 0, 0.2));
    z-index: 1;
    display: table;
    padding: 20px;
}
.rec-reason div p:after {
    border: solid transparent;
    content:'';
    height:0;
    width:0;
    pointer-events:none;
    position:absolute;
    border-color: rgba(255, 255, 255, 0);
    border-top-width:9px;
    border-bottom-width:9px;
    border-left-width:28px;
    border-right-width:28px;
    margin-top: -9px;
    border-right-color:#FFFFFF;
    right: 99%;
    top:40%;
    z-index: 2;
}
.rec-reason div:nth-of-type(even) p {
    margin-left: -10px;
    margin-right: 10px;
}
.rec-reason div:nth-of-type(even) p:after {
    border: solid transparent;
    content:'';
    height:0;
    width:0;
    pointer-events:none;
    position:absolute;
    border-color: rgba(255, 255, 255, 0);
    border-top-width:9px;
    border-bottom-width:9px;
    border-left-width:28px;
    border-right-width:28px;
    margin-top: -10px;
    border-left-color:#FFFFFF;
    left: 99%;
    top:40%;
}
.qa {
    width: 880px;
    margin: 0 auto;
    padding: 30px 0;
}
.qa div {
    width: 45%;
    margin-right: 4%;
    margin-top: 40px;
    display: inline-block;
    vertical-align: top;
    box-shadow:1px 1px 4px -1px #8e8f81;
    border-radius: 20px;
    background: #FFF;
}
.qa div:nth-of-type(even) {
    margin-right: 0%;
}
.qa div h3 {
    background: #0071ac;
    position: relative;
    color: #FFF;
    text-align: left;
    border-radius: 20px 20px 0 0;
    padding: 20px 3% 15px;
    width: 94%;
    line-height: 1.2em;
}
.qa div h3 span {
    font-weight: bold;
    font-size: 24px;
    position: absolute;
    width: 40px;
    height: 40px;
    line-height: 40px;
    border-radius: 50%;
    display: block;
    background: #0071ac;
    text-align: center;
    left: 50%;
    margin-left: -12.5px;
    top: -20px;
}
.qa div div {
    width: 95%;
    margin: 0 auto;
    border-radius: 0 0 20px 20px;
    box-shadow: none;
    text-align: left;
    padding: 15px 0 20px;
}
.qa div div div {
    padding: 0;
}
.qa div div span {
    padding: 3px 10px;
    background: #e58900;
    color: #FFF;
    font-size: 12px;
    font-weight: bold;
    margin-bottom: 10px;
    display: inline-block;
}
.qa div div span .i-icon {
    margin-left: 6px;
    display: none;
}
.qa div div p {
    padding: 5px 10px 10px;
    line-height: 1.3em;
}
.qa div div span.links {
    text-align: center;
    display: table;
    margin: 10px auto;
    background: #0b321d;
    border-radius: 5px;
    color: #FFF;
    padding: 0;
}
.qa div div span.links a {
    color: #FFF;
    display: block;
    padding: 10px 20px;
}
.qa div div span.links a img {
    vertical-align: middle;
    margin-right: 10px;
    margin-bottom: 3px;
    width: 25px;
}
/*.essentials {
}*/
.essentials h3 {
    font-size: 18px;
    font-weight: bold;
    margin: 30px auto 30px;
    border-bottom: 1px solid #666;
}
.essentials-detail ul li {
    width: 23.1%;
    display: inline-block;
    margin-right: 2%;
    line-height: 1.3em;
    text-align: center;
    background: #faf3ed;
    min-height: 5em;
    position: relative;
    font-weight: bold;
}
.essentials-detail ul li:hover {
    cursor: pointer;
}
.essentials-detail ul li:last-of-type {
    margin-right: 0%;
}
.essentials-detail ul li.current {
    background: #FFF;
}
.essentials-detail ul li span {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    display: block;
    width: 90%;
    margin: 0 auto;
}
.essentials-detail ul li .i-icon {
    display: block;
    margin: 0 auto;
}
.essentials-detail div {
    background: #FFF;
    margin-top: -8px;
    text-align: left;
    padding: 30px 0;
    display: none;
}
.essentials-detail div dl {
    width: 90%;
    margin: 0 auto;
}
.essentials-detail div dl dt {
    padding-bottom: 5px;
}
.essentials-detail div dl dd {
    padding: 10px;
    border-top: 1px solid #ccc;
    border-bottom: 1px solid #ccc;
    background: #f4f7f9;
    margin-bottom: 20px;
}
.banner {
    width: 880px;
    margin: 0 auto;
    padding: 60px 0;
}
/**--------- rec-IT ---------**/
.rec-jinbutsu section {
    display: inline-block;
    width: 46%;
    margin-right: 3%;
    margin-top: 30px;
    background: #FFF;
    position: relative;
    vertical-align: top;
    padding: 0 0 30px;
    min-height: 600px;
}
.rec-jinbutsu section:last-of-type {
    margin-right: 0%;
}
.rec-jinbutsu section h3 {
    font-size: 18px;
    font-weight: bold;
    padding: 10px 0;
    width: 100%;
}
.rec-jinbutsu div {
    padding: 30px 0 0;
    display: flex;
    z-index: 0;
}
.rec-jinbutsu div:nth-of-type(even) {
    flex-direction: row-reverse;
}
.rec-jinbutsu div figure {
    width: 90px;
    margin-left: 20px;
}
.rec-jinbutsu div:nth-of-type(even) figure {
    margin-left: 0px;
    margin-right: 20px;
}
.rec-jinbutsu div figure span {
    font-size: 12px;
    display: block;
    line-height: 1em;
    padding-top: 9px;
    text-align: center;
}
.rec-jinbutsu div p {
    width: 220px;
    font-size: 14px;
    text-align: left;
    line-height: 1.4em;
    border-radius: 10px;
    position:relative;
    filter:drop-shadow(1px 1px 2px rgba(0, 0, 0, 0.2));
    z-index: 1;
    display: table;
    padding: 15px 20px;
}
.rec-jinbutsu div p:after {
    border: solid transparent;
    content:'';
    height:0;
    width:0;
    pointer-events:none;
    position:absolute;
    border-color: rgba(255, 255, 255, 0);
    border-top-width:9px;
    border-bottom-width:9px;
    border-left-width:28px;
    border-right-width:28px;
    margin-top: -10px;
    top: 40px;
    z-index: 2;
}
.rec-jinbutsu div:nth-of-type(odd) p {
    margin-left: 10px;
}
.rec-jinbutsu div:nth-of-type(odd) p:after {
    right: 100%;
}
.rec-jinbutsu div:nth-of-type(even) p {
    margin-right: 10px;
}
.rec-jinbutsu div:nth-of-type(even) p:after {
    left: 100%;
}
.rec-jinbutsu section:first-of-type h3,
.rec-jinbutsu section:first-of-type div p {
    background: #c4e1f1;
}
.rec-jinbutsu section:first-of-type div:nth-of-type(odd) p:after {
    border-right-color:#c4e1f1;
}
.rec-jinbutsu section:first-of-type div:nth-of-type(even) p:after {
    border-left-color:#c4e1f1;
}
.rec-jinbutsu section:last-of-type h3,
.rec-jinbutsu section:last-of-type div p {
    background: #cde4d3;
}
.rec-jinbutsu section:last-of-type div:nth-of-type(odd) p:after {
    border-right-color:#cde4d3;
}
.rec-jinbutsu section:last-of-type div:nth-of-type(even) p:after {
    border-left-color:#cde4d3;
}
.rec-reason-it {
    padding: 40px 0 0;
    text-align: left;
}
.rec-reason-it section {
    width: 48.7%;
    margin: 0 2% 30px 0;
    background: #FFF;
    filter:drop-shadow(1px 1px 2px rgba(0, 0, 0, 0.2));
    display: inline-block;
    vertical-align: top;
    position: relative;
}
.rec-reason-it section:nth-of-type(even) {
    margin-right: 0%;
}
.rec-reason-it section figure {
    width: 190px;
    display: inline-block;
    vertical-align: top;
    margin-right: 10px;
}
.rec-reason-it section div {
    display: inline-block;
    width: 210px;
    text-align: left;
    padding: 10px 0;
}
.rec-reason-it section a div {
    color: #000;
}
.rec-reason-it section div span {
    font-size: 12px;
    color: #FFF;
    padding: 5px;
    background: #0b321d;
}
.rec-reason-it section div h3 {
    font-weight: bold;
    padding: 6px 0 3px;
    font-size: 14px;
}
.rec-reason-it section div h4 {
    font-size: 13px;
    line-height: 1.3em;
}
.rec-reason-it section div p {
    font-size: 14px;
    line-height: 1.3em;
    background: #eaf2e1;
    padding: 5px;
    margin-top: 10px;
}
.rec-reason-it section div p.detail {
    position: absolute;
    font-size: 13px;
    font-weight: bold;
    background: #FFF;
    padding: 0px;
    margin-top: 0px;
    bottom: 7px;
    right: 10px;
}
.rec-reason-it section div p.detail img {
    vertical-align: middle;
    margin-left: 7px;
}
#ajax-wrap {
    position: relative;
    margin:10px auto;
    max-width: 700px;
    background: #fff;
    padding: 20px;
}
#ajax-wrap h2 {
    font-weight: bold;
    font-size: 18px;
    margin: 0 0 10px;
}
.modalcontent {
    position: relative;
    margin: 10px auto;
    width: 800px;
    background: #fff;
    padding: 20px 10px;
}
.modalcontent figure {
    width: 230px;
    display: inline-block;
    vertical-align: top;
    margin: 0 20px 0 10px;
}
.modalcontent figure img {
    width: 100%;
}
.modalcontent figure aside {
    padding-top: 15px;
}
.modalcontent figure aside span {
    font-size: 12px;
    color: #FFF;
    padding: 5px;
    background: #0b321d;
}
.modalcontent figure aside h4 {
    font-weight: bold;
    padding: 6px 0 3px;
    font-size: 14px;
}
.modalcontent figure aside p {
    font-size: 13px;
    line-height: 1.3em;
}
.modalcontent div {
    width: 520px;
    display: inline-block;
}
.modalcontent div h3 {
    font-weight: bold;
    padding: 10px 0 30px;
    font-size: 18px;
    line-height: 1.3em;
}
.modalcontent div p {
    line-height: 1.3em;
    padding-bottom: 20px;
}
.mfp-bg {
    opacity: 0;
    transition: all 0.15s ease-out;
}
.mfp-bg.mfp-ready {
    opacity: 0.8;
}
.mfp-bg.mfp-removing {
    opacity: 0;
}
.mfp-wrap .mfp-content {
    opacity: 0;
    transition: all 0.3s ease-out;
}
/* content animate it */
.mfp-wrap.mfp-ready .mfp-content {
    opacity: 1;
}
/* content animate out */
.mfp-wrap.mfp-removing .mfp-content {
    opacity: 0;
}
.mfp-fade.mfp-bg.mfp-ready {
    opacity: 0.8;
}
.mfp-fade.mfp-bg.mfp-removing {
    opacity: 0;
}
.mfp-fade.mfp-wrap .mfp-content {
    opacity: 0;
    transition: all 0.3s ease-out;
}
.mfp-close-btn-in .mfp-close {
    background: #000 !important;
    color: #FFF !important;
    opacity: 1 !important;
}
.it-career {
    padding: 50px 0 0;
}
.it-career h3 {
    border-bottom: 1px solid #999;
    font-weight: bold;
    padding-bottom: 10px;
    font-size: 18px;
    margin-bottom: 20px;
}
.career-w {
    padding-bottom: 50px;
}
.career-w p {
    text-align: left;
    padding: 10px;
    background: #FFF;
    margin-top: 20px;
}
.career-lead {
    text-align: left;
    line-height: 1.4em;
}
.it-career dl {
    width: 48%;
    margin-right: 2.9%;
    display: inline-block;
    vertical-align: top;
    background: #FFF;
    margin-top: 30px;
    padding-bottom: 15px;
    min-height: 460px;
    margin-bottom: 30px;
}
.it-career dl:last-of-type {
    margin-right: 0;
}
.it-career dl dt {
    font-size: 16px;
    font-weight: bold;
    padding: 10px 0 15px;
}
.it-career dl dt img {
    padding-top: 10px;
}
.it-career dl dd {
    font-size: 14px;
    width: 90%;
    margin: 0 auto;
    text-align: left;
    text-indent: -1em;
    padding-left: 1em;
}
.it-honne {
    padding-top: 20px;
}
.it-honne dl {
    text-align: left;
}
.it-honne dl dt {
    text-align: left;
    position: relative;
    background: #c4e1f1;
    border-radius:10px;
    display: inline-block;
    padding: 7px 20px;
    margin-bottom: 20px;
}
.it-honne dl dt:after {
    border: solid transparent;
    content:'';
    height:0;
    width:0;
    pointer-events:none;
    position:absolute;
    border-color: rgba(0, 153, 255, 0);
    border-top-width:26px;
    border-bottom-width:26px;
    border-left-width:12px;
    border-right-width:12px;
    margin-left: -12px;
    border-top-color:#c4e1f1;
    top: 50%;
    left: -10px;
    transform: rotate(50deg);
}
.it-honne dl dd {
    margin-bottom: 40px;
}
.it-honne dl:last-of-type dd {
    margin-bottom: 0px;
}
.it-honne dl dd span {
    text-align: left;
    position: relative;
    background: #0b321d;
    border-radius:10px;
    display: inline-block;
    padding: 7px 20px;
    color: #FFF;
    width: 690px;
    vertical-align: top;
    margin-right: 20px;
}
.it-honne dl dd span:after {
    border: solid transparent;
    content:'';
    height:0;
    width:0;
    pointer-events:none;
    position:absolute;
    border-color: rgba(0, 153, 255, 0);
    border-top-width:26px;
    border-bottom-width:26px;
    border-left-width:12px;
    border-right-width:12px;
    margin-left: -12px;
    border-top-color:#0b321d;
    bottom: -33px;
    right: -20px;
    transform: rotate(-50deg);
}
.it-honne dl dd img {
    width: 120px;
    display: inline-block;
    margin-top: 10px;
}
.it-five {
    padding: 30px 0 0;
}
.it-five dl {
    background: #FFF;
    padding: 10px 2%;
    text-align: left;
    margin-right: 2%;
    margin-bottom: 2%;
    display: inline-block;
    vertical-align: top;
}
.it-five dl dt {
    font-weight: bold;
    margin-top: 10px;
}
.it-five dl dt span {
    font-size: 30px;
    position: relative;
    margin-right: 35px;
    vertical-align: bottom;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
}
.it-five dl dt span:after {
    content: "";
    width: 1px;
    height: 60px;
    border-left: 1px solid #666;
    display: inline-block;
    transform: rotate(45deg);
    position: absolute;
    bottom: -20px;
    left: 1em;
}
.it-five dl dd {
    font-size: 14px;
    line-height: 1.4em;
    padding: 20px 0 20px;
    width: 90%;
    margin: 0 auto;
}
.essentials-detail .flow p {
    width: 90%;
    margin: 0 auto;
    line-height: 1.3em;
    padding-bottom: 20px;
}
.essentials-detail .flow section {
    width: 90%;
    margin: 0 auto;
    padding-top: 20px;
}
.essentials-detail .flow section span {
    display: inline-block;
    vertical-align: top;
    width: 35px;
}
.essentials-detail .flow section span .i-icon {
    font-size: 30px;
}
.essentials-detail .flow section dl {
    display: inline-block;
    vertical-align: top;
    width: auto;
}
.essentials-detail .flow section dl dt {
    font-weight: bold;
    position: relative;
    margin-left: 10px;
    display: inline-block;
    vertical-align: top;
}
.essentials-detail .flow section dl dt span {
    font-size: 30px;
    position: absolute;
    font-family: 'Roboto', sans-serif;
    left: 1.5em;
    top: -0.4em;
}
.essentials-detail .flow section dl dd {
    display: inline-block;
    background: none;
    border-bottom: none;
    border-top: none;
    width: 637px;
    vertical-align: top;
    line-height: 1.3em;
    margin-top: -0.4em;
    margin-left: 20px;
    padding: 7px 0 0 20px;
    border-left: 1px solid #999;
    min-height: 4em;
}
.essentials-detail .flow .add {
    margin-top: 20px;
    padding: 20px;
    background: #e6eaed;
}
/**--------- kaigo ---------**/
.mind-in {
    display: flex;
    padding-top: 30px;
    align-items: center;
}
.mind-in:nth-of-type(even) {
    flex-direction: row-reverse;
}
.mind-in figure {
    width: 50%;
}
.mind-in div {
    width: 50%;
    text-align: left;
    margin-left: 30px;
}
.mind-in:nth-of-type(even) div {
    margin-left: 0px;
    margin-right: 30px;
}
.mind-in div p {
    font-size: 14px;
    line-height: 1.5em;
}
.mind-in div h3 {
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    font-size: 18.8px;
    font-weight: 500;
    padding-bottom: 10px;
}
.feature section {
    width: 31%;
    margin-right: 3%;
    vertical-align: top;
    display: inline-block;
    padding-top: 30px;
}
.feature section:last-of-type {
    margin-right: 0%;
}
.feature section h3 {
    padding: 15px 0 5px;
    border-bottom: 1px solid #999;
    font-weight: bold;
    font-size: 16px;
}
.feature section p {
    text-align: left;
    padding-top: 10px;
    line-height: 1.4em;
}
.promise {
    padding-top: 50px;
}
.promise section {
    width: 31%;
    margin-right: 3%;
    vertical-align: top;
    display: inline-block;
    position: relative;
    border-radius: 15px;
    box-shadow: 0px 0px 3px 1px #bfbfbf;
}
.promise section:last-of-type {
    margin-right: 0%;
}
.promise section span {
    font-weight: bold;
    font-size: 1.5em;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    margin: -25px auto 0;
    color: #FFF;
    background: #02311d;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    line-height: 50px;
    display: block;
}
.promise section h3 {
    text-align: left;
    padding: 10px 15px;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    font-weight: bold;
    line-height: 1.4em;
    font-size: 16px;
}
.promise section p {
    text-align: left;
    padding: 10px 15px 20px;
    line-height: 1.4em;
}
.service-box {
    font-size: 0;
    padding-top: 60px;
}
/*.service-box:first-of-type {
}*/
.service-box figure {
    display: inline-block;
    vertical-align: top;
    width: 50%;
}
.service-box div {
    display: inline-block;
    width: 50%;
    font-size: 16px;
    text-align: left;
}
.service-box div h3 {
    background: #02311d;
    color: #FFF;
    font-weight: bold;
    font-size: 16px;
    padding: 10px 15px;
}
.service-box div h4 {
    padding: 20px 5px 15px 20px;
    font-size: 15px;
    font-weight: bold;
}
.service-box div p {
    padding: 5px 5px 15px 20px;
    line-height: 1.4em;
}
.service-box section {
    font-size: 14px;
    background: #FFF;
    text-align: left;
}
.service-box section h3 {
    padding: 10px 0 5px;
    font-size: 15px;
    font-weight: bold;
    width: 95%;
    margin: 0 auto;
    border-bottom: 1px solid #999;
}
.service-box section section {
    display: inline-block;
    width: 43%;
    margin: 0 3%;
    vertical-align: top;
}
.service-box section section h4 {
    font-size: 14px;
    font-weight: bold;
    padding-top: 15px;
}
.service-box section section h4 span {
    display: none;
}
.service-box section section h4 .i-icon {
    font-size: 24px;
    vertical-align: middle;
    margin-right: 7px;
}
.service-box section section ul {
    padding: 15px 0;
    font-size: 14px;
}
.service-box section section ul li {
    text-indent: -2.5em;
    padding-left: 2.5em;
    line-height: 1.3em;
    padding-bottom: 5px;
}
.contact-box {
    padding: 15px 0;
    border-top: 5px solid #f4f7f9;
    text-align: center;
    background: #FFF;
}
.contact-box li {
    display: inline-block;
    margin: 0 20px;
}
.contact-box li a {
    font-size: 14px;
    background: #0b321d;
    color: #FFF;
    padding: 5px 20px;
    border-radius: 5px;
    display: block;
    box-shadow: 0px 0px 3px 1px #bfbfbf;
}
.contact-box li a img {
    vertical-align: middle;
    margin-right: 7px;
    margin-bottom: 3px;
    width: 20px;
}
#kaigo-service {
    position: fixed;
    right: 10px;
    bottom: 150px;
    width: 200px;
    background: #FFF;
    box-shadow: 0px 0px 3px 1px #bfbfbf;
}
#kaigo-service nav ul {
    text-align: left;
    padding: 15px 0;
}
#kaigo-service nav ul li {
    font-size: 13px;
    padding: 10px 20px 10px 0;
    margin-left: 20px;
    border-bottom: 1px dashed #999;
    line-height: 1.2em;
}
#kaigo-service nav ul li:last-of-type {
    border-bottom: none;
}
#kaigo-service nav ul li a {
    color: #000;
}
#kaigo-service nav ul li .active {
    position: relative;
}
#kaigo-service nav ul li .active:before {
    font-family: "Font Awesome 5 Free";
    content: '\f0da';
    font-weight: 900;
    position: absolute;
    left: -10px;
}
/**--------- IT ---------**/
.style {
    padding: 30px 0 60px;
}
.style section {
    width: 45%;
    margin: 0 2%;
    display: inline-block;
    vertical-align: top;
}
.style section h3 {
    font-size: 18px;
    font-weight: bold;
    border-bottom: 1px solid #999;
    padding-bottom: 5px;
}
.style section p {
    text-align: left;
    padding: 15px 0 0;
    line-height: 1.3em;
}
.it-feature {
    padding: 40px 0 0;
}
.it-feature section {
    width: 45%;
    margin: 0 2% 60px;
    display: inline-block;
    vertical-align: top;
    border-radius: 20px;
    background: #FFF;
    box-shadow: 0px 0px 3px 1px #bfbfbf;
    min-height: 430px;
}
.it-feature section span {
    font-weight: bold;
    font-size: 1.5em;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    margin: -25px auto 0;
    color: #FFF;
    background: #02311d;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    line-height: 50px;
    display: block;
}
.it-feature section h3 {
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    font-size: 18px;
    padding: 20px 0 10px;
}
.it-feature section p {
    text-align: left;
    padding: 15px 0 20px;
    line-height: 1.3em;
    width: 90%;
    margin: 0 auto;
}
.it-ex {
    padding: 30px 0 0;
}
.it-ex h3 {
    font-weight: bold;
    padding: 0 0 20px;
    font-size: 18px;
}
.it-ex h3 span {
    font-size: 14px;
    display: block;
}
.filter ul li {
    display: inline-block;
    margin: 0 5px 10px;
    font-weight: 500;
    padding: 3px 10px;
    border-radius: 3px;
    border: 1px solid #999;
    transition: .35s ease-in-out;
}
.filter ul li.active {
    color: #FFF;
    background: #02311d; 
}
.filter ul li:hover {
    cursor: pointer;
}
#grid {
    width:100%;
    text-align:center;
    clear:both;
    display:block;
    position:relative;
    padding: 40px 0 0;
    margin:0;
}
.grid-item {
    display: inline-block;
    width: 29%;
    padding: 0;
    margin: 0 2% 80px;
    vertical-align: top;
    position: relative;
}
.grid-item p span {
    position: absolute;
    font-weight: bold;
    font-size: 1.3em;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    color: #FFF;
    background: #02311d;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    line-height: 40px;
    display: block;
    top: -15px;
    left: -15px;
}
.grid-item figure {
    display: block;
    width: 100%;
    height: 200px;
    background-position: center center;
    background-size: cover;
}
.grid-item figure span {
    display: block;
    background: rgba(255,255,255,0.85);
    position: absolute;
    width: 80px;
    height: 30px;
    line-height: 30px;
    top: 80px;
    left: 50%;
    margin-left: -40px;
    transition: .35s ease-in-out;
}
.grid-item figure span:hover {
    cursor: pointer;
    background: rgba(255,255,255,0.7);
    padding: 5px 5px;
    border: 1px solid #999;
    top: 75px;
    margin-left: -45px;
}
.grid-item h3 {
    position: absolute;
    display: block;
    width: 84%;
    margin: 0 0 0 5%;
    top: 180px;
    background: rgba(255,255,255,0.95);
    font-weight: normal;
    font-size: 14px;
    padding: 12px 3%;
    box-shadow: 0px 0px 3px 1px #bfbfbf;
    line-height: 1.3em;
}
.grid-item div {
    border: 1px solid #ccc;
    padding: 60px 5% 10px;
    display: none;
}
.grid-item div h4,
.grid-item div h5 {
    border-bottom: 1px solid #ccc;
    padding-bottom: 6px;
}
.grid-item div p {
    font-size: 13px;
    line-height: 1.3em;
    padding: 10px 10px 20px;
    text-align: left;
}
.grid-item div span {
    transition: .35s ease-in-out;
    font-size: 1.5em;
}
.grid-item div span:hover {
    cursor: pointer;
    color: #999;
}
.subinfo {
    padding: 60px 0 0;
    font-size: 0;
}
.subinfo section {
    width: 47%;
    display: inline-block;
    vertical-align: top;
    margin-right: 3%;
    font-size: 14px;
    text-align: left;
    box-shadow: 0px 0px 3px 1px #bfbfbf;
    border-radius: 3px;
}
.subinfo section:last-of-type {
    margin-right: 0;
}
.subinfo section h4 {
    width: 90%;
    margin: 0 auto;
    padding: 15px 0;
    font-weight: bold;
    line-height: 1.3em;
}
.subinfo section div {
    width: 90%;
    margin: 0 auto;
    min-height: 110px;
}
.subinfo section div figure {
    width: 35%;
    display: inline-block;
    vertical-align: top;
}
.subinfo section div.privacymark figure {
    width: 25%;
}
.subinfo section div p {
    width: 60%;
    display: inline-block;
    margin-left: 3%;
    line-height: 1.3em;
    font-size: 13px;
}
.subinfo section div.privacymark p {
    width: 70%;
}
.client h3 {
    font-weight: bold;
    font-size: 16px;
    padding: 10px 0 20px;
}
.client ul {
    font-size: 0;
}
.client ul li {
    width: 49%;
    margin: 0 2% 10px 0;
    display: inline-block;
    vertical-align: top;
    font-size: 14px;
    font-weight: 600;
    background: #FFF;
    padding: 10px 0;
    text-align: left;
}
.client ul li:nth-of-type(even) {
    margin-right: 0;
}
.client ul li span {
    width: 90%;
    margin: 0 auto;
    display: block;
}
.hosoku {
    text-align: left;
    font-size: 14px;
}
.it-voice {
    padding: 30px 0 0;
}
.it-voice section {
    font-size: 0;
}
.it-voice section figure {
    width: 250px;
    display: inline-block;
    vertical-align: top;
}
.it-voice section div {
    width: 630px;
    display: inline-block;
    vertical-align: top;
    font-size: 15px;
    text-align: left;
}
.it-voice section div h3 {
    width: 95%;
    margin: 0 0 0 5%;
    font-weight: bold;
    font-size: 16px;
    line-height: 1.3em;
    border-bottom: 1px solid #999;
    padding-bottom: 10px;
}
.it-voice section div h3 span {
    display: block;
}
.it-voice section div p {
    line-height: 1.3em;
    width: 95%;
    margin-left: 5%;
    padding: 20px 0;
}
.it-employee section {
    display: flex;
    z-index: 0;
    margin-top: 30px;
}
.it-employee section:nth-of-type(even) {
    flex-direction: row-reverse;
}
.it-employee section figure {
    width: 200px;
}
.it-employee section figure span {
    font-size: 12px;
    display: block;
    padding-top: 5px;
}
.it-employee section div {
    width: 640px;
    margin-left: 10px;
    text-align: left;
    line-height: 1.4em;
    background:#FFFFFF;
    border-radius: 5px;
    position:relative;
    z-index: 1;
    display: table;
    padding: 20px;
}
.it-employee section div:after {
    border: solid transparent;
    content:'';
    height:0;
    width:0;
    pointer-events:none;
    position:absolute;
    border-color: rgba(255, 255, 255, 0);
    border-top-width:9px;
    border-bottom-width:9px;
    border-left-width:28px;
    border-right-width:28px;
    margin-top: -9px;
    border-right-color:#FFFFFF;
    right: 99%;
    top:20%;
    z-index: 2;
}
.it-employee section:nth-of-type(even) div {
    margin-left: -10px;
    margin-right: 10px;
}
.it-employee section:nth-of-type(even) div:after {
    border: solid transparent;
    content:'';
    height:0;
    width:0;
    pointer-events:none;
    position:absolute;
    border-color: rgba(255, 255, 255, 0);
    border-top-width:9px;
    border-bottom-width:9px;
    border-left-width:28px;
    border-right-width:28px;
    margin-top: -10px;
    border-left-color:#FFFFFF;
    left: 99%;
    top:20%;
}
.it-employee section div h3 {
    line-height: 1.3em;
    font-weight: bold;
    padding-bottom: 15px;
}
.it-employee section div p {
    line-height: 1.3em;
}
.it-improvement h3 {
    font-weight: bold;
    font-size: 16px;
    padding: 10px 0 20px;
}
.it-improvement dl {
    font-size: 0;
    text-align: left;
    width: 800px;
    margin: 0 auto;
}
.it-improvement dl dt {
    font-size: 15px;
    display: inline-block;
    width: 690px;
    background: #f4f7f9;
    padding: 7px 0 7px 10px;
}
.it-improvement dl dd {
    font-size: 15px;
    display: inline-block;
    width: 90px;
    text-align: right;
    background: #0b321d;
    color: #FFF;
    margin-bottom: 5px;
    padding: 7px 10px 7px 0;
}
/**--------- Access ---------**/
#access-box {
    padding-top: 30px;
}
#access-box h1 {
    font-size: 20px;
    font-weight: bold;
    padding-bottom: 30px;
}
#access-box .access ul {
    text-align: left;
}
#access-box .access ul li a {
    color: #000;
}
#access-box div {
    margin-bottom: 40px;
}
#access-box div h2 {
    font-size: 16px;
    font-weight: bold;
    padding-bottom: 10px;
}
#access-box div img {
    margin-top: 5px;
}
/**--------- contact-common ---------**/

.contact-common {
    background: #FFF;
    padding-top: 60px;
}
.contact-common h1 {
    font-size: 26px;
    font-weight: bold;
}
.contact-common .leadtxt {
    padding-bottom: 20px;
}
.contact-common .full-box {
    width: 100%;
    margin: 20px auto 0;
    background: #FFF;
    filter:drop-shadow(1px 1px 2px rgba(0, 0, 0, 0.2));
    border-radius: 10px;
    display: table;
}
.contact-common .full-box div {
    display: table-cell;
    width: 50%;
    padding: 30px 30px;
    vertical-align: middle;
}
.contact-common .full-box div h2 {
    font-size: 16px;
    text-align: left;
    padding-bottom: 15px;
}
.contact-common .full-box div p {
    text-align: left;
    line-height: 1.3em;
}
.contact-common .full-box div ul {
    text-align: center;
}
.contact-common .full-box div ul li:nth-of-type(2n) {
    margin-top: 20px;
}
.contact-common .full-box div ul li a {
    background: #0b321d;
    display: block;
    filter:drop-shadow(1px 1px 2px rgba(0, 0, 0, 0.2));
    border-radius: 5px;
    color: #FFF;
    width: 250px;
    padding: 10px 0;
    margin: 0 auto;
}
.contact-common .full-box div ul li a .i-icon {
    margin-right: 7px;
}
.contact-common .full-box div .wide-bo li a {
    width: 350px;
}
.contact-common .half-box {
    width: 48.5%;
    margin: 20px 2% 0 0;
    background: #FFF;
    filter:drop-shadow(1px 1px 2px rgba(0, 0, 0, 0.2));
    border-radius: 10px;
    display: inline-block;
    padding: 30px 0;
}
.contact-common .half-box:nth-of-type(odd) {
    margin-right: 0;
}
.contact-common .half-box div h2 {
    font-size: 16px;
    line-height: 1.3em;
    padding: 0 0 15px;
}
.contact-common .half-box div p {
    line-height: 1.3em;
    text-align: left;
    padding: 0 30px 20px;
}
.contact-common .half-box div dl {
    padding: 10px 0;
    width: 90%;
    margin: 10px auto 0;
    font-weight: bold;
    background: #f3f7fa;
}
.contact-common .half-box div dl a {
    color: #000;
}
.contact-common .half-box div dl dt {
    padding-bottom: 5px;
}
.contact-common .half-box div dl dd .i-icon {
    margin-right: 7px;
}
.contact-common .half-box div ul {
    padding-top: 20px;
}
.contact-common .half-box div ul li a {
    background: #0b321d;
    display: block;
    filter:drop-shadow(1px 1px 2px rgba(0, 0, 0, 0.2));
    border-radius: 5px;
    color: #FFF;
    width: 250px;
    padding: 10px 0;
    margin: 0 auto;
    vertical-align: middle;
}
.contact-common .full-box div ul li a img,
.contact-common .half-box div ul li a img {
    vertical-align: middle;
    margin-right: 7px;
    width: 25px;
    padding-bottom: 4px;
}
.contact-formbox .rec-form h2 {
    background: #0b321d;
}
.contact-formbox .rec-form form {
    background: #f3f7fa;
    padding-bottom: 60px;
    margin-bottom: 60px;
}
.contact-formbox #submit-btn {
    width: 300px;
}
/**--------- terms ---------**/
.termssdetail {
    padding-top: 90px;
}
.termssdetail h1 {
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    font-size: 26px;
    font-weight: bold;
}
.termssdetail h2 {
    margin-bottom: 30px;
}
.termssdetail p {
    text-align: left;
    font-size: 14px;
    margin: 10px 15px;
}
.termssdetail ol {
    text-align: left;
    margin: 20px 0px;
}
.termssdetail ol li {
    padding-left: 0.5em;
    padding-bottom: 15px;
}
.termssdetail ul {
    text-align: left;
    margin: 20px 10px;
}
li.ch_bold.ch_action {
    padding-bottom: 5px;
}
ul.ch_detail1 {
    margin:0px 10px 25px 10px;
}
ul.ch_detail2 {
    margin-top: 0px;
    margin-left: 20px;
    margin-bottom: 0px;
}
.termssdetail ul li {
    padding-left: 0.5em;
    padding-bottom: 5px;
}
.termssdetail .signature {
    padding: 10px 10px;
    width: 880px;
    margin: 0 auto;
}
dl.half {
    margin-top: 15px;
}
.half dt {
    display: inline-block;
    vertical-align: top;
    width: 35%;
    text-align: left;
    background: #05311b;
    color: #FFF;
    padding: 5px 10px;
    margin: 5px 0;
}
.half dd {
    display: inline-block;
    width: 55%;
    text-align: left;
    background: #FFF;
    padding: 5px 10px 5px 15px;
    margin: 5px 0;
}
.box-in {
    background: #FFF;
    text-align: left;
    margin-bottom: 30px;
    padding-bottom: 10px;
}
.box-in.bg-g {
    background: #f4f7f9;
    text-align: left;
    margin-bottom: 30px;
    padding-bottom: 10px;
}
.box-in h3 {
    background: #05311b;
    color: #FFF;
    font-weight: bold;
    padding: 10px 25px;
    margin-bottom: 15px;
}
.box-in p {
    padding: 10px 15px;
}
.box-in dl {
    padding: 5px 30px 15px;
}
.box-in dl dt {
    font-weight: bold;
    padding-top: 5px;
}
.box-in dl dd {
    padding-bottom: 10px;
}
.box-in h4 {
    padding: 10px 30px 0px;
    font-weight: bold; 
}
.box-contact dt {
    width: 150px;
    display: inline-block;
    vertical-align: top;
    text-align: left;
    padding: 5px 10px;
    background: #05311b;
    color: #FFF;
    margin: 5px 0px 5px 0;
}
.box-contact dd {
    width: 600px;
    display: inline-block;
    text-align: left;
    padding: 5px 10px 5px 15px;
    margin: 5px 0;
    background: #FFF;
}
.box-contact dd .i-icon {
    margin-right: 5px;
}
.under-space {
    margin-bottom: 60px;
}
span.underLine {
    text-decoration:underline solid #000000;
}
p.ch_right {
    text-align: right;
}
li.ch_black {
    list-style-type: disc;
}
li.ch_white {
    list-style-type: circle;
}
li.ch_bold {
    font-weight: bold;
}

/**--------- news ---------**/
.newsbox {
    padding-top: 25px;
}
.newsbox h1 {
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    font-size: 26px;
    font-weight: bold;
}
.newsbox nav {
    padding: 30px 0 0;
    text-align: left;
}
.newsbox nav ul {
    border-bottom: 1px solid #ccc;
    padding-bottom: 20px;
}
.newsbox nav ul li {
    display: inline-block;
    margin: 0 15px;
}
.newsbox nav ul li:first-of-type {
    padding-right: 20px;
    border-right: 3px solid #000;
    font-weight: bold;
    margin-left: 5px;
}
.newsbox nav ul li a {
    color: #000;
}
.newsbox-in {
    text-align: left;
    padding-top: 20px;
}
.newsbox-in h1 {
    text-align: left;
    font-weight: bold;
    font-size: 1.1em;
    padding-bottom: 10px;
}
.newsbox-in dl {
    text-align: left;
    margin-top: 20px;
    padding-bottom: 20px;
    border-bottom: 1px dashed #ccc;
}
.newsbox-in dl dt span {
    background: #00834d;
    height: 25px;
    position: relative;
    display: inline-block;
    line-height: 25px;
    color: #FFF;
    font-weight: bold;
    font-size: 12px;
    padding: 0px 10px;
}
.newsbox-in dl dt span:after {
    content: "";
    border-style: solid;
    border-width: 12.5px 0 12.5px 16px;
    border-color: transparent transparent transparent #00834d;
    right: -16px;
    position: absolute;
}
.newsbox-in dl dt span a {
    color: #FFF;
    display: block;
}
.newsbox-in dl dt time {
    font-family: 'Roboto', sans-serif;
    font-weight: bold;
    font-size: 12px;
    display: inline-block;
    margin-left: 25px;
    color: #666;
}
.newsbox-in dl dd {
    font-size: 14px;
    padding: 10px 0 0;
}
.newsbox-in dl dd a {
    color: #000;
}
.newsbox .view-more-button {
    text-align: center;
    margin: 30px 0 0;
    background: none;
    border: none;
}
.newsbox .view-more-button:hover {
    cursor: pointer;
    opacity: 0.8;
}
.newsdetailbox {
    padding-top: 90px;
}
.newsdetailbox h1 {
    font-size: 18px;
    font-weight: bold;
    text-align: left;
    line-height: 1.4em;
}
.cate-time {
    padding: 10px 0;
}
.cate-time li:first-of-type {
    float: left;
}
.cate-time li:first-of-type span {
    background: #00834d;
    height: 25px;
    position: relative;
    display: inline-block;
    line-height: 25px;
    color: #FFF;
    font-weight: bold;
    font-size: 12px;
    padding: 0px 10px;
}
.cate-time li:first-of-type span:after {
    content: "";
    border-style: solid;
    border-width: 12.5px 0 12.5px 16px;
    border-color: transparent transparent transparent #00834d;
    right: -16px;
    position: absolute;
}
.cate-time li:first-of-type span a {
    color: #FFF;
    display: block;
}
#magazine-article .cate-time li:last-of-type,
#newsbox-article .cate-time li:last-of-type {
    float: right;
    font-family: 'Roboto', sans-serif;
    font-weight: bold;
    font-size: 12px;
    display: inline-block;
    margin-left: 25px;
    color: #666;
}
.newsdetail-in {
    padding: 60px 0 20px;
}
.newsdetail-in p {
    line-height: 1.3em;
    padding-bottom: 20px;
}
.prev-next {
    text-align: right;
}
.prev-next li {
    display: inline-block;
    margin-left: 30px;
}
.prev-next li a {
    font-size: 20px;
    color: #000;
}

.taxsonomy-list {
    padding-top: 60px;
}

.notfound div {
    width: 95%;
    margin: 0 auto;
    margin-top: -40px;
}
.notfound div p {
    font-size: 16px;
    line-height: 1.4em;
}
.magazine-in {
    margin-top: 30px;
}






.fa-facebook {
    color: #3B5998
}
.fa-twitter {
    color: #1DA1F2
}






/**-------------------------- footer --------------------------**/
footer {
    background: #f4f7f9;
    position: relative;
}
.w-footer {
    width: 1024px;
    margin: 0 auto;
}
footer nav {
    display: flex;
    justify-content: flex-start;
}
footer nav ul {
    flex-grow: 1;
    text-align: left;
    color: #333;
}
footer nav ul li {
    padding-bottom: 10px;
    font-weight: bold;
}
footer nav ul li a {
    color: #333;
    font-weight: 500;
}
footer nav ul li:first-child a {
    font-weight: bold;
    padding-bottom: 15px;
}
footer nav ul.t-bold li a {
    font-weight: bold;
}
footer nav ul li a .fa-angle-right {
    font-size: 11px;
    margin-right: 9px;
    margin-bottom: 2px;
    margin-left: 4px;
    color: #666;
    transition: .35s ease-in-out;
}
footer nav ul li a:hover .fa-angle-right {
    margin-right: 5px;
    margin-left: 9px;
}
footer nav ul li .fa-window-restore {
    font-size: 11px;
    margin-left: 10px;
    color: #666;
}
footer nav ul li .fa-external-link-alt {
    font-size: 11px;
    margin-left: 10px;
    color: #666;
}
footer .w-full {
    background: #FFF;
}

/**--------- My careritz ---------**/
#linkmy {
    position: absolute;
    right: 40px;
    /*top: 250px;*/
    text-align: right;
}
#linkmy a {
    color: #888;
    font-weight: 500;
}
#linkmy a .i-icon {
    margin-right: 7px;
}

#linkmy .tc span {
    font-weight: bold;
    color: #000;
}
#linkmy .tc .far {
    margin-left: 10px;
}

/*.c-footer-mycareritz {
    position: absolute;
    right: 34px;
    bottom: 34px;
}*/

nav#sitemap_foot{
    margin: 0 0 4em;
    font-weight: bold;
}

footer aside {
    width: 1090px;
    margin: 0 auto;
    padding: 15px 0 80px;
    display: flex;
    position: relative;
}
.foot-simple footer aside {
    padding: 15px 0 15px;
}
.foot-search footer aside {
    padding: 15px 0 10px;
}
footer aside #footlogo img {
    height: 37px;
}
footer aside #footlogocrt img {
    height: 37px;
    margin-left: 60px;
}
footer aside #footttc {
    font-weight: bold;
    white-space: nowrap;
    margin-left: 50px;
}

footer aside .foottzeroimg img {
    height: 71px;
}
footer aside .foottimg img {
    height: 37px;
    margin-left: 20px;
}
footer aside .fa-facebook-square {
    margin-left: 30px;
    color: #0a321c;
    font-size: 26px;
    margin-top: 5px;
}
footer aside .fa-twitter {
    margin-left: 20px;
    color: #0a321c;
    font-size: 26px;
    margin-top: 5px;
}
footer aside .fa-instagram {
    margin-left: 20px;
    color: #0a321c;
    font-size: 29px;
    margin-top: 6px;
}

footer aside p a {
    color: #333;
    font-weight: 500;
}
footer aside #copyright {
    position: absolute;
    right: 0px;
    font-size: 12px;
    padding-top: 7px;
    letter-spacing: 0.3px;
}

/**--------- footer.php ---------**/
#footnav {
    background: #0a321c;
    position: fixed;
    bottom: 0px;
    left: 0px;
    width: 100%;
    z-index: 4;
}
#footnav-fixed {
    background: #0a321c;
    position: relative;
    width: 100%;
    z-index: 4;
    margin-top: -70px;
}
#footnav nav,
#footnav-fixed nav {
    width: 1024px;
    height: 70px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
}
#fn-p {
    color: #FFF;
    font-weight: bold;
    flex-grow: 1;
}
#fn-p span {
    display: block;
}
#footnav p:nth-of-type(2),
#footnav-fixed p:nth-of-type(2) {
    flex-grow: 1;
}
#footnav p a,
#footnav-fixed p a {
    width: 90%;
    margin: 0 auto;
    padding: 7px 0;
    background: #0f4d2b;
    display: block;
    color: #FFF;
    font-weight: bold;
    transition: .35s ease-in-out;
}
#footnav p a:hover,
#footnav-fixed p a:hover {
    background: #666;
}
#footnav p a img,
#footnav-fixed p a img {
    display: inline-block;
    vertical-align: middle;
    margin-bottom: 5px;
    margin-right: 13px;
    transition: .35s ease-in-out;
}
#footnav p a:hover img,
#footnav-fixed p a:hover img {
    margin: 0 8px 5px 5px;
}
#footnav p a .fa-window-restore,
#footnav-fixed p a .fa-window-restore {
    margin-left: 8px;
    margin-bottom: 1px;
    font-size: 12px;
}


#footrec {
    background: #eb5a24;
    position: fixed;
    bottom: 0px;
    left: 0px;
    width: 100%;
    z-index: 996;
}
#footrec nav {
    width: 100%;
    height: 70px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
}
#entry-link p {
    width: 100%;
    height: 70px;
    line-height: 70px;
}
#entry-link p a {
    color: #FFF;
    font-weight: bold;
    font-size: 20px;
    display: block;
    width: 100%;
    height: 70px;
}
#entry-link p a span:last-of-type {
    font-size: 16px;
    border: 1px solid #FFF;
    padding: 5px 20px;
    margin-left: 20px;
}
.thanks {
    width: 580px;
    margin: 0 auto;
    text-align: center;
    padding-top: 20px;
}
#pageup {
    position: fixed;
    right: 20px;
    bottom: 70px;
    z-index: 5;
}
#pageup a {
    display: block;
    color: #000;
    font-size: 9px;
    letter-spacing: 1.2px;
    font-weight: 500;
}
#pageup a:before {
    content: url("../image/css/main/aroow-u.png");
    display: block;
    margin-bottom: -11px;
    transition: .35s ease-in-out;
}
#pageup a:hover:before {
    margin-bottom: -4px;
}
.mobile,
.m-txt {
    display: none;
}
.banner-space {
    width: 880px;
    margin: 0 auto;
    padding: 0 0 60px;
}
/*--------------------------------------- mordalwindow ---------------------------------------*/
#mainlink {
    position: absolute;
    display: block;
    top: 55%;
    left: 55px;
    width: 350px;
}
#mainlink a {
    color: #000;
    background: rgba(255,255,255,.80);
    display: block;
    position: relative;
    vertical-align: middle;
    transition: .35s ease-in-out;
}
#mainlink a:hover {
    background: rgba(200,200,200,1.00);
    color: #333;
}
#mainlink a img {
    box-shadow:0px 0px 6px 1px #bfbfbf;
}
.youtube video {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important;
}
.m-close {
    display: block;
    text-align: center;
    position: fixed;
    left: 50%;
    margin-left: -1em;
    top: 0px;
}
.m-close .i-icon {
    color: #FFF;
    font-size: 26px;
    display: block;
    margin: 0 auto;
}



/*---------------------------------------  tablet ---------------------------------------*/
@media screen and (max-width : 1400px ) {
.news ul {
    width: 80%;
}
}
@media screen and (max-width : 1280px ) {
.news ul {
    width: 70%;
}
}
@media screen and (max-width : 1140px ) {
.news ul {
    width: 70%;
}
#lead section:nth-last-of-type(odd) {
    margin-top: -60px
}
}
@media screen and (max-width : 1100px ) {
#lead section:nth-last-of-type(odd) {
    margin-top: -10px
}
/*--------  googlemap表示対応 --------*/
.gm-style .gm-style-iw-c {
    padding: 12px !important;
}
}
@media screen and (max-width : 780px ) {

.news ul {
    width: 100%;
}
.search-hidden p {
    display: block;
}
}



/**--------------------------------------- smartphone ---------------------------------------**/
@media screen and (max-width : 780px ) {
    #wrapper {
        margin-top: 0px !important;
    }
    header {
        height: 50px;
        background: transparent;
    }
    #top-head {
        height: 50px;
        display: block;
    }
    #mobile-head {
        height: 50px;
        background: rgba(255,255,255,0.50);
        z-index: 998;
    }
    .open #mobile-head {
        background: rgba(255,255,255,1.00);
    }
    #nav-toggle {
        display: block;
    }
    #global-nav {
        position: absolute;
        /* 開いてないときは画面外に配置 */
        top: -2000px;
        background: #173d29;
        width: 100%;
        text-align: center;
        padding: 0;
        transition: .35s ease-in-out;
        height: auto;
    }
    #global-nav ul {
        width: 95%;
        margin: 0 auto;
        padding: 20px 0 0;
    }
    #global-nav ul li {
        width: 95%;
        margin: 0 auto;
        padding: 0 5px;
        text-align: left;
        border-bottom: 0.3px solid rgba(255,255,255,.70);
        font-weight: 500;
        font-size: 18px;
    }
    #global-nav ul li .i-icon {
        display: none;
    }
    #global-nav ul li span {
        color: #FFF;
        position: relative;
    }
    #global-nav ul li span:before {
        content: "";
        width: 12px;
        height: 1px;
        background: #FFF;
        position: absolute;
        bottom: 20px;
        right: 2px;
        transition: .35s ease-in-out;
    }
    #global-nav ul li span:after {
        content: "";
        width: 1px;
        height: 12px;
        background: #FFF;
        position: absolute;
        bottom: 14.5px;
        right: 7.5px;
        transition: .35s ease-in-out;
    }
    #global-nav ul li span.active:before {
        transform: rotate(180deg);
    }
    #global-nav ul li span.active:after {
        transform: rotate(90deg);
    }
    #global-nav li ul {
        position: relative;
        height: auto;
        top: auto;
        left: auto;
        background: transparent;
        overflow: hidden;
        padding: 10px 0 0;
    }
    /* 中途用の検索機能追加のため、幅を変更 */
    #global-nav li ul li {
        display: inline-block;
        width: 35%;
        padding: 0;
        text-indent: 0px;
        border-bottom: none;
        vertical-align: top;
        font-weight: 500;
        font-size: 14px;
        height: 45px;
        line-height: 45px;
    }
    #global-nav li ul li#job_naa {
        width: 60%;
    }
    #global-nav li a {
        color: #FFF;
    }
    #global-nav li ul li:hover {
        background: rgba(128,128,128,.50);
    }
    #global-nav li ul li .i-icon {
        font-size: 10px;
        margin-left: 7px;
        padding-bottom: 1px;
        display: inline-block;
    }
    #global-nav div {
        width: 95%;
        margin: 15px auto 5px;
        padding-bottom: 20px;
        border-bottom: 0.3px solid rgba(255,255,255,.70);
    }
    #global-nav div ul li {
        border: none;
        display: inline-block;
        width: 33%;
        padding: 0;
        margin: 0 7%;
    }
    #global-nav div ul li a {
        font-size: 16px;
    }
    #global-nav div p {
        display: inline-block;
        margin: 0 10px;
        padding: 25px 0 0px;
    }
    #global-nav div p a {
        color: #FFF;
    }
    #global-nav div p a .m-icon {
        font-size: 22px;
        margin: 0 5px;
    }
    .desk {
        display: none !important;
    }
    .mobile {
        display: block !important;
    }
    .m-txt {
        margin-left: 15px;
        display: inline-block;
        color: #8daa9c;
        font-size: 12px;
        font-style: normal;
        font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
        font-weight: 100;
    }
    #logo {
        position: fixed;
        width: auto;
        margin-left: -110px;
        line-height: normal;
        top: auto;
        left: 50%;
        padding-top: 10px;
        background: transparent;
        z-index: 999;
    }
    #logo img {
        width: 220px;
        margin: 0 auto;
    }

    /**--------- パンくずリスト ---------**/
    .breadcrumbs {
        width: auto;
        display: flex;
        overflow-x: scroll;
        white-space: nowrap;
        word-break: keep-all;
        padding: 1em;
        margin: 0em auto 2em;
    }
    .bc-blank .breadcrumbs {
        margin-top: 45px;
    }
    .newsbox .breadcrumbs {
        margin: -0.35em auto 3em;
    }
    .news-bc-blank .breadcrumbs {
        margin-top: 1em;
    }
    .notfound-wrapper .breadcrumbs {
        padding: 1em 0;
    }
    .magazine-box .breadcrumbs {
        margin: 1em auto 0;
        width: auto;
        padding-left: 4em;
    }
    .magazine-bc-blank .breadcrumbs {
        margin: -1em auto 2em;
        padding-left: 1em;
    }








    #mainimage .news {
        position: absolute;
        right: 0px;
        bottom: 0px;
        width: 100%;
        padding: 0;
    }
    #mainimage h1 {
        left: 10px;
        top: 32%;
        margin-top: -2em;
        font-size: 1.8rem;
        text-align: left;
        line-height: 1.2em;
    }
    #mainimage h1 span {
        display: block;
    }
    .news h2,
    .news ul,
    .news span {
        display: block;
    }
    .news h2 {
        font-size: 1em;
        font-weight: bold;
        padding-top: 10px;
        padding-left: 10px;
    }
    .news h2:after {
        content: none;
    }
    .news li {
        padding: 0 10px 10px;
    }
    .news li time {
        font-size: 0.8em;
    }
    .news li a {
        margin-top: 1px;
        width: 75%;
    }
    .news span {
        position: absolute;
        right: 10px;
        top: 8px;
    }
    .news span a {
        font-size: 9px;
    }
    .w-con,
    .w-footer {
        width: 100%;
    }
    .topbox h2 {
        font-size: 36px;
    }
    .topbox h2 span {
        font-size: 12px;
        margin-left: 15px;
        font-weight: bold;
    }
    #lead {
        padding: 40px 0;
    }
    #lead figure {
        width: 95%;
    }
    #lead h2 {
        font-size: 26px;
    }
    #lead p {
        width: 90%;
        margin: auto;
    }
    #lead p span {
        display: inline;
    }
    #recbox {
        padding-bottom: 80px;
    }
    #recbox h2 {
        margin-top: -32px;
        margin-left: 5%;
        padding-bottom: 20px;
    }
    #recbox section {
        width: 90%;
        margin: 0 auto 20px;
        z-index: 1;
    }
    #recbox section:last-of-type {
        width: 80%;
        margin: 20px auto 0;
        padding: 20px 0;
    }
    #recbox section:last-of-type h3 span a {
        margin-left: 0px;
    }
    #rec-it {
        padding: 0 0 40px;
    }
    #rec-it figure {
        width: 100%;
    }
    #service-box {
        padding-top: 10px;
        padding-bottom: 20px;
        overflow: hidden;
    }
    #service-box h2 {
        position: relative;
        right: auto;
        left: auto;
        top: auto;
        padding-bottom: 20px;
        text-align: left;
        width: 90%;
        margin: 0 auto;
    }
    #service-box div div {
        width: 90%;
        display: block;
        margin: 0 auto 30px;
    }
    #service-box div div figure img {
        width: 100%;
    }
    #service-box div div section {
        margin: 0 auto;
        padding: 0 5% 20px;
        text-align: left;
        width: 90%;
    }
    #service-box div div:nth-of-type(2) {
        margin-right: auto;
    }
    #service-box div div section a h3 span {
        right: 10px;
        top: 17px;
    }
    .w80 {
        width: 90%;
    }
    .search .w80 {
        padding: 30px 0;
    }
    .search h2 {
        font-size: 20px;
    }
    .search form p {
        display: block;
        margin: 0 auto 15px;
    }
    .search form select {
        width: 80%;
        margin: 0 auto;
        padding: 15px 7% 15px 3%;
    }
    .search form select:hover {
        cursor: pointer;
    }
    .search form p:after {
        right: 15%;
        bottom: 15px;
    }
    .terms button {
        margin: 10px auto 20px;
        padding: 15px 0;
    }  
    #care-other {
        padding: 60px 0 40px;
    }
    #care-other section {
        width: 100%;
        margin: 0 auto;
        display: block;
        padding-bottom: 30px;
    }
    #care-other section:nth-of-type(2) {
        margin-right: 0;
    }
    #magazine {
        padding-bottom: 30px;
        padding-top: 60px;
    }
    #magazine h2 {
        left: 5%;
        top: -30px;
    }
    #magazine article {
        width: 100%;
        margin-right: auto;
        margin-bottom: 30px;
    }
    #magazine article:last-of-type {
        margin-bottom: 0px;
    }
    #magazine article figure {
        height: 200px;
    }
    #magazine article div {
        width: 90%;
    }
    #magazine-article .magazine-in iframe {
        width: 100%;
    }
    .search-hidden {
        right: -100%;
        top: 70px;
        width: 100%;
        padding: 20px 0;
    }
    .search-hidden  #side_searchbox {
        position: relative;
        width: 90%;
        margin: 0 auto;
    }
    #search-box .open {
        transform: translateX(-100%);
    }
    .search-hidden .f-select {
        text-align: left;
    }
    .search-hidden p {
        width: 85%;
        margin: 0 0 20px 0;
    }
    .search-hidden select {
        padding: 10px 30% 10px 17%;
        width: 100%;
    }
    .search-hidden h3 {
        text-align: left;
        padding: 10px 0;
    }
    .search-hidden ul li {
        display: block;
        margin-bottom: 10px;
        margin-left: 5px;
    }
    .s-type p {
        font-size: 13px;
        height: 30px;
        line-height: 30px;
        padding: 0 0 0 40px;
    }
    .s-type p:before {
        width: 40px;
        height: 30px;
    }
    .station-box .map {
        padding-bottom: 20px;
    }
    .station-box .map iframe {
        width: 100%;
    }
    .station-box .address {
        width: 100%;
        position: relative;
    }
    .station-box .address figure {
        position: absolute;
        bottom: 40px;
        left: 50%;
        margin-left: -70px;
    }
    .station-box .address div {
        width: 90%;
        display: block;
        margin: 0 auto;
        padding-bottom: 160px;
    }
    .near-box {
        width: 90%;
        display: block;
        background: #ececec;
    }
    .near-box section h3 {
        display: block;
        position: relative;
    }
    .near-box section h3:after {
        font-family: "Font Awesome 5 Free";
        content: '\f054';
        font-weight: 900;
        position: absolute;
        right: 10px;
        top: 0.8em;
        transition: .35s ease-in-out;
    }
    .near-box section a {
        transition: .35s ease-in-out;
    }
    .near-box section a:hover h3:after {
        right: 7px;
    }
    .near-box h3 {
        display: block;
        width: 94%;
        padding: 10px 3%;
        text-align: center;
    }
    .near-box .near-type {
        display: none;
        width: 94%;
        padding: 20px 3% 0;
    }
    .near-box .near-type li {
        display: inline-block;
        margin: 5px;
    }
    .near-box .hide-area {
        display: none;
        width: 92%;
        padding: 10px 4%;
    }
    /* jobの検索画面でスマホの場合、アクセス方法等が出ないように制御入れる */
    .near-box.job .hide-area {
        display: none;
        width: 92%;
        padding: 10px 4%;
    }
    /* ここまで */
    .near-box .links {
        width: 100%;
        padding: 20px 0 0;
        position: relative;
        top: auto;
        right: auto;
        height: auto;
        border-left: none;
        text-align: center;
        display: none;
    }
    .near-box .links span {
        position: relative;
        top: auto;
        display: block;
        margin-top: 0;
    }
    .near-box .links li {
        margin: 0 10px;
        display: inline-block !important;
    }
    .near-box .links li:first-of-type {
        margin: 0 10px;
    }
    .near-box .links li:last-of-type {
        display: none !important;
    }
    .near-station h2 {
        line-height: 1.3em;
    }
    .near-station h2 span {
        display: block;
    }
    .hide-open {
        display: none;
        text-align: center;
        bottom: 0px;
        width: 100%;
        height: auto;
        padding: 5px 0;
        border-top: 1px solid #999;
        z-index: 997;
        margin-top: 20px;
    }
    .hide-open:hover {
        cursor: pointer;
    }
    .recruit-station {
        width: 90%;
        margin-top: 30px;
    }
    .recruit-station h2 {
        position: relative;
        text-align: center;
        width: 100%;
        top: auto;
        right: auto;
        z-index: 2;
    }
    .recruit-station h2 span {
        display: block;
    }
    .recruit-station h2 em {
        display: block;
        margin-right: 0px;
    }
    .recruit-station figure {
        width: 100%;
        display: block;
        z-index: -1
    }
    .recruit-station div {
        width: 90%;
        padding: 20px 0 15px;
        margin: 0 auto;
        display: block;
    }
    .recruit-station div p a {
        padding: 10px;
        margin: 20px 0 0;
        position: relative;
        width: 94%;
    }
    .recruit-station div p a em {
        display: block;
    } 
    .recruit-station div p a .i-icon {
        top: 50%;
        margin-top: -0.5em;
    }
    .station-recbox h1 {
        font-size: 20px;
    }
    .station-recbox h1 span {
        display: block;
    }
    #recform-link {
        display: none;
    }
    .station-recbox h2 {
        font-size: 18px;
    }
    .station-recbox .mainimages {
        padding-top: 60px;
    }
    .station-recbox .mainimages figure {
        display: block;
    }
    .station-recbox .mainimages figure img {
        width: 100%;
    }
    .station-recbox .mainimages figure:first-of-type {
        display: none;
    }
    .station-recbox .mainimages figure:last-of-type {
        text-align: center;
        width: 100%;
        padding-top: 30px;
        z-index: -1;
    }
    .station-recbox .mainimages h3 {
        font-size: 18px;
        top: 15px;
        margin-top: 0;
        width: 76%;
        padding: 10px 4%;
        left: 6%;
        border: 1px solid #efefef;
        z-index: 2
    }
    .station-recbox .mainimages p {
        text-align: left;
    }
    .entry ul li {
        line-height: 1.2em;
        width: 90%
    }
    .entry ul li a {
        font-size: 18px;
        padding: 20px 5%;
    }
    .entry ul li span {
        display: block;
    }
    .entry ul li a .i-icon {
        margin-top: -10px;
    }
    .campaign {
        padding: 20px 0;
    }
    .rec-station-wrap .station-box .address div {
        padding-bottom: 0px;
    }
    .station-reason {
        padding: 20px 0 60px;
    }
    .station-reason figure img {
        width: 100%;
    }
    .station-reason figure span {
        position: relative;
        padding: 10px 5%;
        font-size: 20px;
        width: 80%;
        left: 5%;
        top: 50%;
        margin-top: -1em;
        text-align: center;
    }
    .station-reason section {
        padding-top: 60px;
        width: 80%;
    }
    .station-reason section h2 {
        font-size: 18px;
        padding-left: 15%;
        line-height: 1.3em;
    }
    .station-reason section h2 span {
        top: -0.8em;
        left: 0em;
    }
    .station-reason section h2:before {
        left: 1.5em;
        top: -2em;
    }
    .station-reason section h3 {
        font-size: 18px;
        line-height: 1.3em;
        padding: 15px 0 15px;
    }
    .station-reason section p {
        line-height: 1.3em;
    }
    .rec-occu {
        padding: 20px 0;
    }
    .rec-occu h2 {
        font-size: 18px;
        font-weight: bold;
    }
    .rec-occu h2 span {
        display: block;
        margin-left: 0;
    }
    .rec-occu ul {
        padding: 20px 0 0;
        display: block;
        text-align: center;
        margin: 0 auto;
    }
    .rec-occu ul li {
        width: 45%;
        margin: 0 2% 2% 0;
        display: inline-block;
        height: auto;
        vertical-align: top;
        min-height: 70px;
    }
    .rec-occu ul li:nth-of-type(even) {
        margin-right: 0;
    }
    .rec-occu ul li a {
        padding: 10px 0px;
        height: 60px;
    }  
    .station-recbox .rec-outline {
        display: block;
        width: 90%;
        padding: 30px 0 0;
        margin: 0 auto;
    }
    .station-recbox .rec-outline:last-of-type {
        padding: 10px 0 30px;
    }
    .station-recbox .rec-outline dl dt {
        width: 96%;
        padding: 3px 2%;
    }
    .station-recbox .rec-outline dl dd {
        width: 94%;
        padding: 3px 3%;
        display: block;
    }
    .station-recbox .rec-outline ul li {
        display: inline-block;
        padding: 4px 10px;
        border: 1px solid #999;
        margin: 5px;
    }
    .foot-search footer aside {
        padding: 15px 0 130px;
    }   
    footer aside {
        width: 100%;
        padding: 15px 0 130px;
        display: block;
        background: #f4f7f9;
    }
    footer aside p img {
        width: 60%;
    }
    footer aside #copyright {
        position: relative;
        right: auto;
        padding-top: 7px;
        font-size: 10px;
    }

    /**--------- footer.php ---------**/
    #footnav-fixed {
        margin-top: -110px;
    }
    #footnav nav,
    #footnav-fixed nav {
        width: 100%;
        height: auto;
        display: block;
        padding: 15px 0 20px;
    }
    #fn-p {
        font-weight: 500;
    }
    #footnav p span {
        display: inline-block;
    }
    #footnav p:nth-of-type(2),
    #footnav-fixed p:nth-of-type(2) {
        display: inline-block;
        width: 45%;
        margin: 0 1%;
        padding: 10px 0 0;
    }
    #footnav p a,
    #footnav-fixed p a {
        width: 100%;
        padding: 7px 0;
        font-weight: 500;
    }
    #footnav p a img,
    #footnav-fixed p a img {
        width: 20px;
    }

    #footrec nav {
        width: 100%;
        height: auto;
        display: block;
        padding: 10px 0;
        text-align: center;
    }
    #entry-link p {
        height: auto;
        line-height: 1.3em;
    }
    #entry-link p a {
        font-size: 16px;
        display: block;
        height: auto;
    }
    #entry-link p a span:first-of-type {
        display: block;
        width: 100%;
    }
    #entry-link p a span:last-of-type {
        font-size: 14px;
        margin: 5px auto 0;
        display: inline-block;
    }
    #pageup {
        right: 10px;
        bottom: 115px;
    }
    #pageup a {
        display: block;
        color: #000;
        font-size: 9px;
        letter-spacing: 1.2px;
        font-weight: 500;
    }
    #pageup a:before {
        content: url("../image/css/main/aroow-u.png");
        display: block;
        margin-bottom: -11px;
        transition: .35s ease-in-out;
    }
    #pageup a:hover:before {
        margin-bottom: -4px;
    }
    #mainlink {
        top: auto;
        left: 10px;
        width: 50%;
        bottom: 100px;
    }
    .sec-images h1 {
        font-size: 20px;
        margin: 0 auto 10px;
    }
    .sec-images h2 {
        font-size: 24px;
        margin: 0 auto;
    }
    .cap-left div {
        left: auto;
        top: auto;
        margin: 0 auto;
        text-align: center;
        bottom: 40px;
        width: 100%;
    }
    .m-top div {
        bottom: auto;
        top: 80px;
    }
    .sec-in {
        padding: 30px 0;
    }
    .sec-in h2 span {
        display: block;
    }
    .sec-in .lead {
        text-align: left;
    }
    .sec-in .lead span {
        display: inline-block;
    }
    .sec-in .sub-txt {
        text-align: left;
    }
    .sec-in h2 {
        width: 90%;
        margin: 0 auto;
        line-height: 1.3em;
    }
    .sec-in .w880 {
        width: 90%;
    }
    .management-in {
        position: relative;
        padding: 30px 0 10px;
    }
    .management-in figure {
        width: 45%;
        display: block;
        text-align: left;
    }
    .management-in div {
        width: 100%;
        display: block;
        margin-left: 0px;
    }
    .management-in div h3 {
        margin-left: 0px;
        padding-left: 0px;
        padding-top: 15px;
        font-size: 18px;
    }
    .management-in div h4 {
        padding: 0;
        position: absolute;
        top: 70px;
        left: 50%;
    }
    .management-in div h4 span {
        display: block;
        margin-left: 0px;
    }
    .management-in .tenkai {
        display: table;
        text-align: center;
        padding: 5px 0;
        width: 80%;
        margin: 20px auto 0;
    }
    .rec-description h2 span,
    .rec-description h3 span {
        display: block;
    }
    .rec-description div p {
        text-align: left;
    }
    .rec-description div figure {
        width: 98%;
        margin: 10px auto 0;
    }
    .rec-description div dl {
        padding: 5px 4%;
        width: 92%;
        margin: 0 auto 20px;
    }
    .rec-description div dl:nth-of-type(3) {
        width: 96%;
        width: 92%;
        margin: 0 auto;
    }
    .rec-reason div {
        display: flex;
        z-index: 0;
        margin-top: 20px;
        margin-bottom: 30px;
    }
    .rec-reason div:nth-of-type(even) {
        flex-direction: row-reverse;
    }
    .rec-reason div figure {
        width: 25%;
    }
    .rec-reason div figure span {
        font-size: 12px;
        display: block;
    }
    .rec-reason div p {
        width: 60%;
    }
    .rec-reason div p:after {
        top: 10%;
    }
    .rec-reason div:nth-of-type(even) p:after {
        top: 10%;
    }
    .qa {
        width: 90%;
        padding: 30px 0 10px;
    }
    div[id^="Q"] p{
        margin: 5px auto 5px;
    }
    p.con {
        background-color: #f3f7fa;
        border-radius: 0 0 20px 20px;
    }
    .qa div {
        width: 100%;
        margin: 30px auto 40px;
        display: block;
    }
    .qa div:last-of-type {
        margin: 0 auto;
    }
    .qa div div {
        text-align: center;
    }
    .qa div div span {
        padding: 7px 20px;
        border-radius: 7px;
    }
    .qa div div span .i-icon {
        display: inline-block;
    }
    .qa div div span.active .i-icon {
        transform: rotate(180deg);
    }
    .qa div div p {
        display: none;
        text-align: left;
    }
    .essentials-detail ul li {
        width: 47%;
        margin-bottom: 10px;
    }
    .banner {
        width: 90%;
    }
    .rec-jinbutsu section {
        display: block;
        width: 100%;
        min-height: auto;
    }
    .rec-jinbutsu div p {
        width: 45%;
    }
    .rec-reason-it section {
        width: 100%;
        margin: 0 auto 30px;
    }
    .rec-reason-it section figure {
        width: 45%;
    }
    .rec-reason-it section div {
        width: 47%;
    }
    .rec-reason-it section div p.detail {
        position: relative;
        bottom: 0px;
        right: 0px;
        text-align: right;
        padding-top: 10px;
    }
    .modalcontent {
        width: 90%;
    }
    .modalcontent figure {
        width: 90%;
        display: block;
        margin: 0 auto 20px;
    }
    .modalcontent div {
        width: 90%;
        display: block;
        margin: 0 auto;
    }
    .it-career dl {
        width: 100%;
        display: block;
        margin: 30px auto;
        min-height: auto;
    }
    .it-honne dl dd span {
        display: block;
        width: 83%;
        margin-right: auto;
    }
    .it-honne dl dd {
        text-align: right;
    }
    .it-honne dl dd img {
        text-align: right;
        margin-top: 20px;
    }
    .it-five dl dt {
        position: relative;
        line-height: 1.3em;
        width: 80%;
        padding: 12px 10px 0 50px;
    }
    .it-five dl dt span {
        position: absolute;
        margin-right: 0px;
        left: 10px;
        top: 0px;
    }
    .it-five dl dt span:after {
        position: absolute;
        bottom: -32px;
        left: 20px;
    }
    .it-five dl dd {
        padding: 20px 0 30px;
    }
    .essentials-detail .flow section {
        position: relative;
    }
    .essentials-detail .flow section span {
        display: block;
        position: absolute;
        left: 0px;
        top: 15px;
    }
    .essentials-detail .flow section dl dt {
        margin-left: 50px;
    }
    .essentials-detail .flow section dl dd {
        display: block;
        width: 100%;
        margin: 10px auto;
        padding: 7px 0 20px 0;
        border-left: none;
        border-top: 1px solid #999;
        min-height: auto;
    }
    .mind-in {
        display: block;
    }
    .mind-in figure {
        width: 100%;
    }
    .mind-in div {
        width: 100%;
        margin-left: 0px;
        margin-top: 20px;
    }
    .mind-in:nth-of-type(even) div {
        margin-right: 0px;
    }
    .mind-in div p {
        font-size: 14px;
        line-height: 1.5em;
        padding-bottom: 20px;
    }
    .mind-in div h3 {
        text-align: center;
        padding-bottom: 16px;
        line-height: 1.2em;
        font-size: 17px;
    }
    .mind-in div h3 span {
        display: block;
    }
    .feature section {
        width: 100%;
        margin-right: 0%;
        margin-top: 30px;
        display: flex;
        flex-direction: row-reverse;
        flex-direction: column;
        padding: 10px 0;
        background: #FFF;
        border-radius: 10px;
    }
    .feature section h3 {
        padding: 10px 0 5px;
        order: 1;
        width: 90%;
        margin: 0 auto;
    }
    .feature section p {
        order: 2;
        width: 90%;
        margin: 0 auto;
    }
    .feature section figure {
        order: 3;
        width: 90%;
        margin: 0 auto;
    }
    .promise section {
        width: 100%;
        margin-right: 0%;
        margin-bottom: 50px;
    }
    .promise section span {
        margin: 0 0 0 -25px;
        position: absolute;
        top: -25px;
        left: 50%;
        display: block;
    }
    .promise section h3 {
        text-align: center;
        padding-top: 30px;
    }
    #kaigo-service {
        display: none;
        right: -300px;
    }
    .service-box {
        display: flex;
        flex-direction: column;
        padding-top: 30px;
        margin-bottom: 10px;
    }
    .service-box figure {
        display: block;
        width: 100%;
        order: 1;
    }
    .service-box div {
        display: block;
        width: 100%;
        font-size: 14px;
        order: 2;
    }
    .service-box div h3 {
        font-size: 15px;
        text-align: center;
        line-height: 1.2em;
    }
    .service-box div h3 span {
        display: block;
    }
    .service-box div h4 {
        padding: 20px 5px 15px 20px;
        font-size: 14px;
        font-weight: bold;
    }
    .service-box div p {
        padding: 5px 5px 15px 20px;
        line-height: 1.4em;
    }
    .service-box section {
        font-size: 14px;
        order: 3;
    }
    .service-box ul {
        order: 4;
    }
    .service-box section h3 {
        font-size: 14px;
        width: 90%;
        margin: 0 auto;
    }
    .service-box section section {
        display: block;
        width: 100%;
        margin: 0 auto;
        padding-bottom: 15px;
    }
    .service-box section section h4 {
        padding-top: 15px;
        position: relative;
        width: 90%;
        margin: 0 auto;
    }
    .service-box section section h4 span {
        display: block;
        position: absolute;
        right: 10px;
        top: 1em;
        border: 1px solid #999;
        padding: 2px 8px;
        font-size: 13px;
    }
    .service-box section section ul {
        padding: 15px 0;
        width: 90%;
        margin: 0 auto;
        display: none;
    }
    .contact-box {
        padding: 15px 0;
        border-top: 5px solid #f4f7f9;
        text-align: center;
        background: #FFF;
    }
    .contact-box li {
        display: block;
        margin: 0 auto;
        width: 80%;
        position: relative;
    }
    .contact-box li:nth-of-type(2) {
        margin-top: 20px;
    }
    .contact-box li a {
        padding: 10px 20px 10px 55px;
        text-align: left;
        line-height: 1.3em;
    }
    .contact-box li a img {
        position: absolute;
        top: 15px;
        left: 20px;
        margin-right: 0;
        margin-bottom: 0;
    }
    .kaigo-main {
        margin-bottom: 30px;
    }
    .thanks {
        width: 90%;
    }
    .style section {
        width: 100%;
        margin: 0 auto;
        padding-bottom: 30px;
    }
    .filter {
        width: 100%;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
    }
    .filter ul {
        width: 880px;
        list-style: none;
        display: flex;
    }
    .filter ul li {
        margin: 0 5px 0px;
        white-space: nowrap;
    }
    .it-feature section {
        width: 100%;
        margin: 0 auto 60px;
        min-height: auto;
    }
    .gnav {
        width: 100%;
        height: 40px;
        background: #9fb7d4;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
    }
    .gnav ul {
        width: 800px;
        height: 40px;
        margin: 0 auto 2px;
        list-style: none;
        display: flex;
    }
    .grid-item {
        display: block;
        width: 90%;
        margin: 0 auto 60px;
    }
    .subinfo {
        padding: 30px 0 0;
    }
    .subinfo section {
        width: 90%;
        display: block;
        margin: 0 auto 20px;
        font-size: 14px;
    }
    .subinfo section:last-of-type {
        margin-right: auto;
    }
    .subinfo section div {
        min-height: auto;
        padding-bottom: 20px;
    }
    .subinfo section div figure {
        width: 70%;
        display: block;
        margin: 0 auto;
    }
    .subinfo section div.privacymark figure {
        width: 100px;
    }
    .subinfo section div p {
        width: 100%;
        display: block;
        margin-left: auto;
        padding-top: 20px;
    }
    .subinfo section div.privacymark p {
        width: 100%;
    }
    .client ul li {
        width: 100%;
        margin: 0 auto 10px;
        display: block;
        background: transparent;
    }
    .client .hosoku {
        width: 90%;
        margin: 0 auto;
    }
    .it-voice section {
        width: 90%;
        margin: 0 auto;
    }
    .it-voice section figure {
        width: 30%;
    }
    .it-voice section div {
        width: 70%;
    }
    .it-employee section {
        display: block;
        margin-top: 30px;
    }
    .it-employee section figure {
        width: 40%;
        margin: 0 auto;
    }
    .it-employee section div {
        width: 85%;
        margin: 15px auto 0;
        padding: 20px;
    }
    .it-employee section div:after {
        border-top-width: 0px;
        border-bottom-width: 20px;
        border-left-width: 15px;
        border-right-width: 15px;
        margin-top: -15px;
        margin-right: -20px;
        border-right-color: transparent;
        border-bottom-color: #FFF;
        right: 50%;
        top: 0%;
    }
    .it-employee section:nth-of-type(even) div {
        margin-left: auto;
        margin-right: auto;
    }
    .it-employee section:nth-of-type(even) div:after {
        border-top-width: 0px;
        border-bottom-width: 20px;
        border-left-width: 15px;
        border-right-width: 15px;
        margin-top: -15px;
        margin-left: -20px;
        border-left-color:transparent;
        border-bottom-color: #FFF;
        left: 50%;
        top: 0%;
    }
    .it-improvement dl {
        width: 100%;
        margin: 0 auto;
        display: table;
        margin-bottom: 5px;
    }
    .it-improvement dl dt {
        width: 65%;
        background: #f4f7f9;
        padding: 7px 0 7px 5%;
        display: table-cell;
    }
    .it-improvement dl dd {
        width: 20%;
        padding: 7px 5% 7px 0;
        display: table-cell;
        vertical-align: middle;
    }
    .banner-space {
        width: 90%;
        margin: 0 auto;
        padding: 0 0 60px;
    }
    .contact-common .full-box {
        display: block;
        padding-bottom: 30px;
    }
    .contact-common .full-box div {
        display: block;
        width: 90%;
        margin: 0 auto;
        padding: 30px 0 0;
    }
    .contact-common .full-box div h2 {
        text-align: center;
    }
    .contact-common .full-box div h2 span {
        display: block;
    }
    .contact-common .half-box {
        width: 100%;
        margin: 20px auto 0 auto;
        padding: 30px 0;
    }
    .contact-common .half-box:nth-of-type(odd) {
        margin-right: auto;
    }
    .contact-common .half-box div {
        width: 90%;
        margin: 0 auto;
    }
    .contact-common .full-box div .wide-bo li a {
        width: 95%;
    }
    .termssdetail .signature {
        width: 100%;
    }
    .termssdetail .signature p {
        width: 85%;
        margin: 0 auto;
    }
    .half dt {
        display: block;
        width: 96%;
        padding: 5px 2%;
        margin: 5px auto 0;
    }
    .half dd {
        display: block;
        width: 96%;
        padding: 5px 2%;
        margin: 5px auto 20px;
    }
    .box-contact dt {
        width: 96%;
        display: block;
        padding: 5px 2%;
        margin: 5px auto 0;
    }
    .box-contact dd {
        width: 96%;
        display: block;
        padding: 5px 2%;
        margin: 0 auto 20px;
    }
    .newsbox {
        padding-top: 50px;
    }
    .newsbox h1 {
        font-size: 20px;
    }
    .newsbox nav ul {
        border-bottom: 1px solid #ccc;
        padding-bottom: 20px;
        text-align: center;
    }
    .newsbox nav ul li {
        display: inline-block;
        margin: 0 15px;
    }
    .newsbox nav ul li:first-of-type {
        padding-right: 0;
        border-right: none;
        margin-left: 0;
        display: block;
        position: relative;
        padding-bottom: 15px;
    }
    .newsbox nav ul li:first-of-type:after {
        position: absolute;
        width: 30px;
        height: 3px;
        background: #000;
        bottom: 10px;
        left: 50%;
        margin-left: -15px;
        content: "";
        display: block;
    }
    .newsdetailbox {
        padding-top: 80px;
    }
    .newsdetail-in {
        padding: 50px 0 20px;
    }
    .prev-next {
        text-align: center;
    }
    .prev-next li {
        display: inline-block;
        margin: 0 15px;
    }

    header .c-facebook-img,.c-twitter-img {
        padding-bottom: 4px;
    }
    header .c-youtube-img {
        padding-bottom: 6px;
    }
    header .c-twitter-img {
        width: 23px;
        height: 21px;
    }
    header .c-instagram-img {
        width: 29px;
        height: 29px;
    }




}
/*---------------------------------------  ipad横向き対応 ---------------------------------------*/
@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) and (orientation: landscape) {
    #mainimage h1 {
        font-size: 2.5rem;
    }
    .search-hidden select {
        width: 100%;
    }
    #recform-link {
        display: none;
    }
    #search-box h2 span {
        display: none !important;
    }
    .recruit-station h2 {
        position: relative;
        text-align: center;
        width: 100%;
        top: auto;
        right: auto;
        z-index: 2;
    }
    .recruit-station h2 span {
        display: block;
    }
    .recruit-station h2 em {
        display: block;
        margin-right: 0px;
    }
}


/*---------------------------------------  hide ---------------------------------------*/
/* SP用 */
@media screen and (max-width : 780px ) {
    .hideSp {
        display: none;
    }
    }
    /*PC用 */
    @media screen and (min-width : 781px ) {
    .hidePc {
        display: none;
    }
}

/*---------------------------------------  recruit-banner ---------------------------------------*/
/* SP用 */
@media screen and (max-width : 780px ) {
    .recruit-headerbanner {
        width: 90%;
        padding-top: 30px;
    }
    .recruit-footerbanner {
        padding-top: 30px;
    }
}
/*PC用 */
@media screen and (min-width : 781px ) {
    .recruit-headerbanner {
        position: absolute;
        right: 0px !important;
        bottom: 0px !important;
        left:auto !important;
        top:auto !important;
        width: 25%;
        z-index: 2;
    }
    .recruit-headerbanner img {
        margin:5px 0 0 0;
    }
    .recruit-footerbanner {
        padding-top: 60px;
    }
}

/* ----- css-top-service ----- */
#service-box.css-top-service div div {
    width: 90%;
    margin-right: 0;
}
#service-box.css-top-service div div figure img {
    width: 100%;
}
#service-box.css-top-service div div section {
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
}
@media screen and (max-width : 780px ) {
    #service-box.css-top-service div div {
        margin-right: auto;
    }
    #service-box.css-top-service div div section {
        max-width: none;
    }
}
/* ----- css-top-recruit ----- */
#recbox.css-top-recruit h2+section {
    width: 90%;
    margin: 0;
}
#recbox.css-top-recruit h2+section figure {
    height: 502px;
    overflow: hidden;
}
#recbox.css-top-recruit h2+section figure img {
    margin-top: -86px;
}
#recbox.css-top-recruit section div {
    max-width: 528px;
}
#recbox.css-top-recruit section div p {
    text-align: center;
}
@media screen and (max-width : 780px ) {
    #recbox.css-top-recruit h2+section figure {
        height: auto;
    }
    #recbox.css-top-recruit h2+section figure img {
        margin-top: 0;
    }
    #recbox.css-top-recruit section div {
        max-width: none;
    }
}



.inner-block {
    width: 1000px;
    margin: 0 auto;
}


.c-kv {
    position: relative;
    padding: 4.9vw 0 0 5.93vw;
    height: 40.6vw;
    width: 100%;
    box-sizing: border-box;
}
.c-kv::before {
    content: "";
    display: block;
    width: 91.6vw;
    height: 30.1vw;
    position: absolute;
    left: 0;
    bottom: 0;
    background: #f6faf5;
}
.c-kv-title {
    position: relative;
    text-align: left;
}
.c-kv-title__en {
    font-family: "ipapmincho","YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
    font-size: 5.29vw;
    line-height: 1.77;
    letter-spacing: 0.065em;
    display: block;
    text-align: left;
    opacity: 0.07;
    text-shadow: 0px 3px 6px rgba(255, 255, 255, 0.8);
}
.c-kv-title__ja {
    font-family: "notoserif","YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
    font-size: 2vw;
    line-height: 1.32;
    letter-spacing: 0.4em;
    font-weight: 500;
    display: block;
    text-align: left;
    top: -4.36vw;
    position: relative;
}
.c-kv-title__ja02 {
    font-family: "ipapmincho","YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
    font-size: 2.14vw;
    letter-spacing: 0.07em;
    line-height: 3.21vw;
    font-weight: 500;
    color: #113c1f;
    display: block;
    text-align: left;
    top: -0.9vw;
    position: relative;
    text-shadow: 0px 3px 6px rgba(255, 255, 255, 0.8);
    margin-left: 16.6vw;
    z-index: 1;
}
.c-kv-title__ja02::before {
    content: "";
    position: absolute;
    top: 0;
    left: -16vw;
    bottom: 0;
    margin: auto;
    width: 15.2vw;
    height: 0.07vw;
    background-color: #113c1f;
}
.c-kv-img {
    position: absolute;
    top: 0;
    right: 0;
    width: 63vw;
    height: 34.2vw;
}
.c-kv-img > img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}

.c-kv02 {
    position: relative;
    padding: 15.71vw 0 0 5.93vw;
    height: 42.2vw;
    width: 100%;
    box-sizing: border-box;
}
.c-kv02::before {
    content: "";
    display: block;
    width: 91.6vw;
    height: 33.6vw;
    position: absolute;
    left: 0;
    bottom: 0;
    background: #2B4834;
}
.c-kv02-title {
    position: relative;
    text-align: left;
}
.c-kv02-title__en {
    font-family: "ipapmincho","YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
    font-size: 4.5vw;
    line-height: 1.24;
    letter-spacing: 0.07em;
    color: #fff;
    opacity: 0.12;
    display: block;
    text-align: left;
}
.c-kv02-title__ja {
    font-family: "notoserif","YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
    font-size: 2vw;
    line-height: 1.32;
    letter-spacing: 0.4em;
    font-weight: 500;
    display: block;
    text-align: left;
    top: -3vw;
    margin-left: 2.36vw;
    position: relative;
    color: #fff;
}
.c-kv02-title__ja::before {
    content: "";
    display: block;
    width: 0.2vw;
    height: 1.93vw;
    background: linear-gradient(#113c1f 0%, #2fb4de 100%);
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin-left: -1.5vw;
    margin-top: 0.42vw;
    transform: skewX(-27deg);
}
.c-kv02-title__ja02 {
    font-family: "notoserif","YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
    font-size: 1.2vw;
    line-height: 1.42;
    letter-spacing: 0.05em;
    font-weight: 500;
    display: block;
    text-align: left;
    padding-left: 8.8vw;
    top: -0.3vw;
    position: relative;
    color: #FFF;
}
.c-kv02-title__ja02::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0.9vw;
    bottom: 0;
    margin: auto;
    width: 6.71vw;
    height: 0.07vw;
    background-color: #FFF;
}
.c-kv02-img {
    position: absolute;
    top: 0;
    right: 0;
    width: 65vw;
    height: 41.4vw;
}
.c-kv02-img > img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}

div[id^="Q"] p[id^=Q][id$=A]{
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: left;
}
div[id^="Q"] p[id^=Q][id$=A].open {
    white-space: pre-wrap;
    overflow: visible;
    text-overflow: unset;
}
.text-container {
    padding: 10px 20px;
    line-height: 1.3em;
}
.w-footer.desk.c-footer-box01-box p a {
    color: #333;
    font-weight: 500;
}

@media screen and (max-width: 780px) {
    .c-kv02 {
        height: auto;
        display: flex;
        flex-direction: column;
        padding: 0;
    }
    .c-kv02:before::before {
        display: none;
    }
    .c-kv02-img {
        width: auto;
        height: auto;
        order:1;
        position: relative;
    }
    .c-kv02-img {
        width: auto;
        height: auto;
        order:1;
        position: relative;
    }
    .c-kv02-title {
        width: auto;
        order:2;
        position: relative;
        background: #2B4834;
        padding: 45px 20px 70px 20px;
        margin-right: 20px;
    }
    .c-kv02-title__en {
        font-size: 63px;
        line-height: 1;
    }
    .c-kv02-title__en.pat02 {
        font-size: 59px;
    }
    .c-kv02-title__ja {
        font-size: 28px;
        margin-left: 30px;
        top : -0.9em;
    }
    .c-kv02-title__ja::before {
        width: 4px;
        height: 30px;
        margin-left: -22px;
        margin-top: 0;
    }
    .c-kv02-title__ja02 {
        font-size: 18px;
        padding-left: 100px;
        top: 0;
    }
    .c-kv02-title__ja02::before {
        left: 0;
        width: 90px;
        height: 1px;
    }
}
@media screen and (max-width : 370px ) {
    .c-kv02-title__en {
        font-size: 54px;
    }
}
@media screen and (max-width : 389px ) {
    .c-kv02-title__ja {
        font-size: min(8.5vw,28px);
    }
}



/* c-anchor */
.c-anchor-list {
    position: relative;
    display: flex;
    flex-wrap: wrap;
}
.c-anchor-list li {
    position: relative;
    width: 200px;
    background-color: #113C1F;
    border-radius: 2px;
}
.c-anchor-list li::after {
    content: "";
    position: absolute;
    background: url('../image/common/arrow-down-short.svg') no-repeat;
    background-size: contain;
    bottom: 7px;
    left: 94px;
    right: 0;
    height: 8px;
    width: 8px;
}
.c-anchor-list li a {
    display:block;
    color: #fff;;
    font-size: 13px;
    padding: 9.5px 0 18.5px 0;
    letter-spacing: 0.34em;
    line-height: 1.3;
    font-weight: bold;
}
.c-sec-title {
    position: relative;
    text-align: left;
}
@media screen and (max-width: 780px) {
    .c-anchor-list {
        display: block;
    }
    .c-anchor-list li {
        width: auto;
    }
    .c-anchor-list li a {
        padding: 9.5px 20px 9.5px 20px;
        text-align: left;
    }
    .c-anchor-list li::after {
        left: auto;
        right:20px;
        top: 0;
        bottom: 0;
        margin: auto;
        width: 12px;
        height: 12px;
    }
}

/* c-sec-title */
.c-sec-title .en {
    font-family: "ipapmincho","YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
    position: absolute;
    top: -37px;
    font-size: 44px;
    line-height: 1.77;
    letter-spacing: 0.065em;
    opacity: 0.07;
    text-shadow: 0px 3px 6px rgba(255, 255, 255, 0.8);
}
.c-sec-title .ja {
    font-family: "notoserif","YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
    font-size: 28px;
    line-height: 1.32;
    letter-spacing: 0.4em;
    font-weight: 500; 
    margin-left: 6px;
    color: #000;
}
@media screen and (max-width: 780px) {
    .c-sec-title .en {
        font-size: 31px;
        top: -27px;
    }
    .c-sec-title .ja {
        font-size: 21px;
    }
}

/* c-footer */
.c-footer {
    background-color: #FFF;
    margin-top: 140px;
    padding-bottom: 70px;
}
.c-footer-contact-ttl {
    text-align: center;
}
.c-footer-contact-ttl__en {
    font-family: "ipapmincho","YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
    font-weight: 300;
    font-size: 114px;
    letter-spacing: -0.01em;
    color: #000;
    opacity: 0.07;
    text-shadow: 0px 3px 6px rgba(255, 255, 255, 0.8);
}
.c-footer-contact-ttl__jp {
    font-family: "notoserif","YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
    color: #000;
    letter-spacing: 0.402em;
    font-weight: 500;
    font-size: 28px;
    margin-top: -61px;
    position: relative;
    display: flex;
    justify-content: center;
}
@media screen and (max-width: 780px) {
    .c-footer-contact-ttl__jp {
        margin-top: -33px;
    }
}
.c-footer-contact-ttl__jp::before {
    content: "";
    display: block;
    width: 5px;
    height: 28px;
    background: linear-gradient(#113c1f 0%, #2fb4de 100%);
    margin: auto 0;
    transform: skewX(-27deg);
    margin-right: 10px;
}
.c-footer-contact-btn {
    margin-top: 58px;
}
.c-footer-contact-btn__btn {
    background: linear-gradient(-90deg, #317e4a 0%, #2fb4de 100%);
    padding: 36px 177px;
    font-family: "notoserif","YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
    font-weight: 500;
    font-size: 20px;
    letter-spacing: 0.24em;
    color: #fff;
    display: inline-flex;
    box-sizing: border-box;
}
.c-footer-contact-btn__btn img {
    transition: .35s ease-in-out;
}
.c-footer-contact-btn__btn:hover {
    opacity: 1;
    color: #fff;
}
.c-footer-contact-btn__btn:hover img {
    transform: translateX(4px);
}

@media screen and (max-width: 389px) {
    .c-footer-contact-btn__btn {
        font-size: min(4.6vw,20px);
    }
}
.c-footer-contact-btn__img {
    width: 42px;
    /* margin-left: 26px; */
    display: flex;
    align-items: center;
}
.c-footer-contact-btn__img>img {
    width: 100%;
}
@media screen and (min-width: 781px) {
    .c-footer-contact-btn__img {
        margin-left: 26px;
    }
}
@media screen and (max-width: 780px) {
    .c-footer-contact-btn__btn {
        justify-content: space-between;
    }
}

.c-footer-box-inner {
    border-top: 1px solid #D6D6D6;
}
.c-footer-list {
    display: flex;
    justify-content: center;
    padding: 15px 0;
}
@media screen and (min-width: 781px) {
    .c-footer-box {
        border-top: 1px solid #D6D6D6;
        padding: 15px 0;
    }
    .c-footer-contact-ttl +.c-footer-box {
        margin-top: 170px;
    }
    /* .c-footer {
        width: 1280px;
    } */
    .c-footer-list {
        max-width: 1280px;
        width: auto !important;
    }
}
@media screen and (max-width: 780px) {
    .c-footer {
        background-color: #fff;
        padding-top: 96px;
        padding-bottom: 110px;
    }
    .c-footer-contact-btn {
        padding: 0 20px;
    }
    .c-footer-contact-btn__btn {
        padding: 25px 27px;
        width: 100%;
    }
    .c-footer-contact-ttl__en {
        font-size: 59px;
    }
}
.c-footer-list__box {
    display: flex;
    align-items: center;
}
.c-footer-box01 {
    background-color: #F4F7F9;
    position: relative;
}
.c-footer-box01-box {
    max-width: 1024px;
}

.c-footer-copy {
    padding-bottom: 25px;
    letter-spacing: 0.3px;
}
.c-footer-box-sp {
    background-color: #F8F8F8;
    padding: 20px 0 10px;
    margin-top: 72px;
}
.c-footer-box-sp__img {
    text-align: center;
}
.c-footer-box-sp__img>img {
    width: 225px;
}
.c-footer-box-sp__copy {
    font-family: "Noto Sans JP";
    font-weight: normal;
    font-size: 10px;
    letter-spacing: 0.15em;
    text-align: center;
    color: #525252;
    margin-top: 10px;
}

/**--------- 空のPタグ削除 ---------**/
p:empty {
    display: none;
}
