@charset "utf-8";
body {
font-family: 'Noto Sans JP',sans-serif;
font-weight: 500;
letter-spacing: 0.1em;
background-color: #F6F6F6;
}
p {
line-height: 1.6;
}
.disp_n {
display: none;
}
.ovf_h {
overflow: hidden;
}
.v_mid {
vertical-align: middle;
}
.pos_r {
position: relative;
}
.mg-t1 {
margin-top: 15px;
}
.mg-t2 {
margin-top: 40px;
}
.mg-t3 {
margin-top: 60px;
}
.mg-t4 {
margin-top: 100px;
}
.mg-l0 {
margin-left: 75px;
}
.fs-0 {
font-size: 16px;
letter-spacing: 0.1em;
}
.fs-1 {
font-size: 93.75%;
}
.fs-2 {
font-size: 106.25%;
}
.fs-3 {
font-size: 112.5%;
}
.fs-4 {
font-size: 125%;
}
.fs-5 {
font-size: 200%;
}
.fs-6 {
font-size: 150%;
}
.fn {
font-weight: 400;
}
.line_h1 {
line-height: 2.2;
}
.lts-1 {
letter-spacing: 0.05em;
}
.pd-lr {
padding-left: 20px;
padding-right: 20px;
}
.pd-lr0 {
padding-left: 40px;
padding-right: 40px;
}
.pd-t1 {
padding-top: 100px;
}
.pd-b1 {
padding-bottom: 100px;
}
.pd-t2 {
padding-top: 50px;
}
.bdr1 {
border-radius: 30px;
}
.bdr2 {
border-radius: 25px;
}
.bdr3 {
border-radius: 40px;
}
.bgcw {
background-color: #fff;
}
.dbox {
padding: 100px 20px;
}
.mw1440 {
max-width: 1440px;
}
.mw1240 {
max-width: 1240px;
}
.btn {
max-width: 450px;
display: block;
height: 80px;
line-height: 74px;
border: solid 1px #707070;
border-radius: 74px;
padding: 0 40px 0 95px;
position: relative;
background-color: #fff;
}
.btn:before {
content: '';
width: 12px;
height: 11px;
position: absolute;
left: 60px;
top: 50%;
margin-top: -4px;
background: url(images/btn_ar.png) center center no-repeat;
transition: left 0.2s ease-in-out;
}
.btn:hover {
border-color: #4C6F4F;
background-color: #4C6F4F;
opacity: 1;
}
.service-3 .btn:hover {
background-color: #000000;
}
.btn:hover .b {
display: none;
}
.btn:hover .w {
display: inline;
}
.btn:hover:before {
background-image: url(images/btn_ar_w.png);
left: 65px;
}
.btn > span {
display: inline-block;
width: 100%;
max-width: 320px;
letter-spacing: 0;
font-size: 0;
vertical-align: middle;
}
.btn .jp {
display: inline-block;
width: 48.4%;
max-width: 150px;
vertical-align: middle;
}
.btn .en {
display: inline-block;
width: 32.3%;
max-width: 100px;
vertical-align: middle;
}
.btn .bar {
display: inline-block;
width: 19.3%;
max-width: 60px;
text-align: center;
vertical-align: middle;
}
#container {
max-width: 1920px;
margin-left: auto;
margin-right: auto;
overflow: hidden;
}
#footer_to_top {
position: absolute;
top: 0;
right: 0;
width: 109px;
display: block;
}
#top-head {
position: absolute;
height: 90px;
width: 100%;
padding-left: 50px;
z-index: 100;
top: 30px;
}

#top-head > div {
position: relative;
height: 90px;
padding: 0 50px;
}
#top-head > div:before {
content: '';
display: block;
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
border-radius: 74px 0 0 74px;
background: rgba(255,255,255,0.86);
z-index: 101;
}
#top-head .logo {
line-height: 90px;
max-width: 240px;
width: 17%;
float: left;
position: relative;
z-index: 104;
}
#top-head .logo a {
display: inline-block;
}
#top-head .logo a img {
vertical-align: middle;
}
#mobile-nav {
 position: absolute;
 width: 60px;
 height: 60px;
 right: 0;
 top: 15px;
 z-index: 104;
 display: none;
}
/* Toggle Button */
#nav-toggle {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 40px;
  height: 40px;
  text-align: center;
  cursor: pointer;
  z-index: 104;
  padding: 10px;
}
#nav-toggle div {
  position: relative;
  height: 100%;
}
#nav-toggle span {
  display: block;
  position: absolute;
  width: 100%;
  height: 2px;
  background: #000;
  top: 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: 0px;
}
#nav-toggle span:nth-child(2) {
  top: 9px;
}
#nav-toggle span:nth-child(3) {
  top: 19px;
}
#global-nav {
position: absolute;
right: 0;
z-index: 101;
}
#global-nav > ul {
list-style: none;
}
#global-nav > ul >li {
float: left;
line-height: 90px;
padding: 0 15px;
}
#global-nav > ul >li.last {
padding-right: 0;
}
#global-nav > ul >li a {
color: #707070;
font-size: 15px;
letter-spacing: 0.1em;
display: inline-block;
opacity: 1;
}
#global-nav > ul >li a:after {
content: '';
width: 0;
height: 2px;
margin-top: 4px;
background-color: #A7D676;
display: block;
transition: width 0.2s linear;
}
#global-nav > ul >li a:hover:after {
width: 100%;
}
#global-nav > ul >li.last a {
display: block;
height:90px;
line-height: 90px;
padding: 0 80px 0 50px;
text-align: center;
background-color: #000;
color: #fff!important;
font-size: inherit;
border-radius: 74px 0 0 74px;
}
#global-nav > ul >li.last a:hover {
color: #000;
background-color: #A7D676;
opacity: 0.7;
}
#global-nav > ul >li.last a:after {
display: none;
}

#global-nav .sub {
display: none;
}

/* #nav-toggle */
.open #nav-toggle span:nth-child(1) {
  top: 8px;
  -webkit-transform: rotate(315deg);
  -moz-transform: rotate(315deg);
  transform: rotate(315deg);
}
.open #nav-toggle span:nth-child(2) {
  height: 0;
  top: 50%;
}
.open #nav-toggle span:nth-child(3) {
  top: 8px;
  -webkit-transform: rotate(-315deg);
  -moz-transform: rotate(-315deg);
  transform: rotate(-315deg);
}
/* #global-nav */
.open #global-nav {
  /* #global-nav top + #mobile-head height */
  -moz-transform: translateY(2052px);
  -webkit-transform: translateY(2052px);
  transform: translateY(2052px);
}

#footer {
background-color: #4C6F4F;
padding: 100px 20px 50px;
color: #fff;
overflow: hidden;
}
#footer > div {
padding-right: 140px;
}
#footer .subtitle {
font-size: 13px;
font-weight: 400;
letter-spacing: 0.2em;
margin-bottom: 20px;
}
#footer .left {
max-width: 280px;
margin-right: 20px;
}
#footer .logo {
display: block;
max-width: 270px;
}
#footer .contact {
color: #4C6F4F;
background-color: #fff;
border-radius: 30px;
display: block;
max-width: 270px;
line-height: 60px;
text-align: center;
margin-top: 15px;
}
#footer .contact:hover {
opacity: 1;
background-color: #A7D676;
}
#footer .ovf_h {
max-width: 670px;
}
#footer .ovf_h ul {
list-style: none;
margin-left: 50px;
float: left;
}
#footer ul:first-child {
margin-left: 0;
}
#footer ul li {
margin-top: 20px;
}
#footer ul li:first-child {
margin-top: 0;
margin-bottom: 30px;
}
#footer ul li a {
color: #fff;
font-size: 15px;
letter-spacing: 0.1em;
}
#footer ul li.sub a {
font-size: 14px;
font-weight: 400;
}
#footer ul li a:hover {
opacity: 1;
color: #A7D676;
}
#footer .scroll_text {
margin-top: 50px;
}
#footer .scroll_text .slick-list {
overflow: visible;
}
#footer .scroll_text li {
margin-top :0!important;
margin-bottom :0!important;
}
#footer .copyright {
font-size: 14px;
margin-top: 30px;
}
#main {
max-width: none;
}
#topmain .mask {
position: absolute;
width: 100%;
height: 100%;
z-index: 2;
}
#topmain video {
width: 100%;
}
.mainimg {
max-width: none;
width: 100%;
}
.page_toptitle {
position: absolute;
top: 53.4%;
left: 7%;
width: 19.6%;
max-width: none;
}
.top-worksa .m {
position: absolute;
width: 100%;
top: 0;
left: 0;
margin-top: -5%;
}
.top-1 .left {
width: 55%;
max-width: 720px;
padding-left: 20px;
padding-right: 45px;
}
.top-1 .left > div {
width: 100%;
max-width: 500px;
}
.top-1 .left .title {
max-width: 432px;
margin-bottom: 30px;
}
.top-title .i {
max-width: 262px;
display: block;
margin-bottom: 20px;
}
.top-2 {
margin-top: 160px;
}
.bgw {
position: absolute;
width: 50%;
height: 100%;
background-color: #fff;
top: 0;
right: 0;
}
.bgrw {
position: absolute;
width: 50%;
height: 100%;
background-color: #fff;
top: 0;
left: 75px;
border-radius: 90px 0 0 90px;
}
.top-2 .bgrw {
left: 35px;
}
.top-2 .bgw, .top-2 .bgrw {
height: 70%;
}
.top-2 h2 {
top: -22px;
font-weight: 500;
position: relative;
}
.top-2 h3 {
font-weight: 400;
}
.top-2 .linkbox > div {
width: 48.4%;
max-width: 600px;
margin-top: 60px;
}
.top-2 .linkbox > div a {
display: block;
}
.top-2 .linkbox > div a:hover img {
transform: scale(1.1 );
transition: 0.3s ease-in-out;
}
.workslist {
margin-top: 60px;
margin-left: 300px;
}
.workslist a {
color: #000;
}
.workslist .bg {
opacity: 0;
}
.workslist .w {
position: absolute;
max-height: 100%;
top: 0;
bottom: 0;
left: 0;
right: 0;
margin: auto;
}
.workslist .slick-slide {
/* max-width: 422px; */
padding: 0 15px;
}
.workslist .slick-prev,
.workslist .slick-next,
.stafflist .slick-prev,
.stafflist .slick-next {
width: 60px;
height: 60px;
font-size: 0;
border: solid 1px #707070;
border-radius: 50%;
top: auto;
bottom: 20px;
background-color: #fff;
background-position: center center;
background-repeat: no-repeat;
transform: none;
transition: 0.3s ease-in-out;
z-index: 2;
}
.workslist .slick-prev {
left: -220px;
background-image: url(images/ar_l.png);
}
.workslist .slick-next {
left: -140px;
background-image: url(images/ar_r.png);
}
.stafflist .slick-prev {
left: -220px;
background-image: url(images/ar_l.png);
}
.stafflist .slick-next {
left: -140px;
background-image: url(images/ar_r.png);
}
.workslist .slick-prev:before,
.workslist .slick-next:before,
.stafflist .slick-prev:before,
.stafflist .slick-next:before {
display: none;
}
.workslist .slick-prev:hover,
.stafflist .slick-prev:hover {
background-color: #262626;
background-image: url(images/ar_l_w.png);
}
.workslist .slick-next:hover,
.stafflist .slick-next:hover {
background-color: #262626;
background-image: url(images/ar_r_w.png);
}

.workscat {
margin-top: 20px;
}
.workscat > span {
font-size: 14px;
font-weight: 400;
letter-spacing: 0.1em;
display: inline-block;
border: solid 1px #707070;
border-radius: 14px;
padding: 7px 15px;
}
.workstitle {
margin-top: 10px;
}
.top-recruit {
margin-left: -16px;
margin-right: -16px;
font-size: 0;
letter-spacing: 0;
text-align: center;
}
.top-recruit > div {
width: 50%;
display: inline-block;
vertical-align: top;
}
.top-recruit > div > div {
width: 50%;
margin-top: 100px;
display: inline-block;
vertical-align: top;
padding: 0 16px;
}
.top-recruit .title {
max-width: 75px;
width: 26.3%;
margin-right: 12%;
margin-left: auto;
z-index: 4;
}
.top-recruit .i {
border-radius: 24px;
margin-top: -41.6%;
}
.top-recruit .i:before {
content: '';
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: #9CC474;
opacity: 0;
z-index: 2;
}
.top-recruit a {
font-size: 16px;
color: #000;
}
.top-recruit a:hover {
opacity: 1;
}
.top-recruit a:hover .i:before {
opacity: 0.34;
}
.top-recruit .subtitle {
margin-top: 10px;
text-align: left;
letter-spacing: 0.1em;
}
.top-recruit .subtitle:before {
content: '';
display: inline-block;
margin-right: 6px;
vertical-align: middle;
width: 19px;
height: 19px;
border-radius: 50%;
background-color: #A7D676;
background-image: url(images/tri_a.png);
background-position: center center;
background-repeat: no-repeat;
}
.top-recruit a:hover .subtitle:before {
background-color: #4C6F4F;
}
.top-news .bgw {
left: 0;
right: auto;
}
.top-news .bgrw {
left: 50%!important;
border-radius: 0 90px 90px 0;
}

.top-news .left {
width: 320px;
}
.newslist {
list-style: none;
}
.top-news .newslist {
max-width: 740px;
margin-right: 50px;
}
.newslist .date {
color: #A7D676;
display: inline-block;
margin-right: 20px;
letter-spacing: 0.02em;
}
.newslist li {
height: 80px;
line-height: 80px;
border-bottom: dashed 1px #000;
padding-right: 20px;
background: url(images/news_ar.png) right center no-repeat;
}
.newslist li.no_news {
border: none;
background: none;
padding-right: 0;
}
.archive .newslist li.no_news {
text-align: center;
}
.newslist .title {
color: #000;
font-weight: 400;
display: inline-block;
height: 16px;
overflow:hidden;
}
.access .left {
width: 310px;
}
.access iframe {
width: 100%;
height: 395px;
}

/* page */
.pagelinks {
line-height: 3;
}
.pagelinks a {
display: inline-block;
color: #000;
font-size: 14px;
font-weight: 400;
letter-spacing: 0.1em;
}
.page-title {
font-size: 118.75%;
font-weight: 400;
}
.page-title > span {
display: inline-block;
padding-bottom: 20px;
letter-spacing: 0.2em;
position: relative;
}
.page-title > span:after {
content: '';
position: absolute;
width: 100%;
height: 1px;
bottom: 0;
left: 20px;
background-color: #707070;
}
.page-subtitle {
margin-top: 20px;
margin-left: 30px;
font-weight: 400;
}
.about-1 {
max-width: 1040px;
font-size: 0;
letter-spacing: 0;
}
.about-1 .left {
width: 51.25%;
vertical-align: bottom;
}
.about-1 .left p {
line-height: 2.5;
}
.about-1 .right {
width: 40.84%;
max-width: 392px;
margin-left: 7.9%;
vertical-align: bottom;
font-weight: 400;
}
.about-1 .right img {
width: 100%;
}
.about-1 .president {
text-align: right;
padding-right: 20px;
margin-top: 15px;
letter-spacing: 0.26em;
}
.about-2 {
max-width: 1040px;
}
.about-2 > div {
max-width: 850px;
}
.about-2 .left {
width: 34.5%;
max-width: 293px;
padding-right: 20px;
padding-top: 15px;
}
.about-2 .right {
width: 65.5%;
}
.about-2 .right > div {
max-width: 480px;
}
.about-2 .right p {
line-height: 3.5;
font-weight: 400;
letter-spacing: 0.1em;
}
.scroll_img {
max-width: 421px;
width: 60%;
}
.scroll_img .slick-list {
overflow: visible;
}
.scroll_img .slick-slide {
padding: 0 4px;
}
.about-3 {
max-width: 980px;
}
.about-3 > div {
max-width: 815px;
}
.about-tbl {
border-collapse: collapse;
width: 100%;
}
.about-tbl tr {
border-top: dotted 2px #707070;
}
.about-tbl th {
text-align: left;
width: 250px;
padding: 20px;
line-height: 2;
font-weight: 400;
}
.about-tbl td {
padding: 20px 0;
line-height: 2;
font-weight: 400;
}
.about-5 {
margin-left: -16px;
margin-right: -16px;
font-size: 0;
letter-spacing: 0;
}
.about-5 > div {
display: inline-block;
width: 33.33%;
max-width: 424px;
padding-left: 16px;
padding-right: 16px;
vertical-align: top;
}

.service-1 ul {
margin-left: 50px;
}
.service-1 li {
line-height: 2.27;
}
.service-2 {
max-width: 1040px;
margin-left: 30px;
}
.service-2 h3 {
max-width: 759px;
}
.four {
margin-left: -16px;
margin-right: -16px;
font-size: 0;
letter-spacing: 0;
text-align: center;
}
.four > div {
width: 50%;
display: inline-block;
vertical-align: top;
}
.four > div > div {
width: 50%;
margin-top: 50px;
display: inline-block;
vertical-align: top;
padding: 0 16px;
}
.four .title {
height: 34px;
padding: 8px 10px;
color: #fff;
background-color: #4C6F4F;
border-radius: 3px;
}
.service-3 {
background-color: #4C6F4F;
}
.service-3 .page-title > span:after {
background-color: #fff;
}
.service-3 .scroll_img {
max-width: 424px;
}
.service-3 .scroll_img .slick-slide {
padding: 0 16px;
}
.service-3 .scroll_img .bg {
opacity: 0;
}
.service-3 .scroll_img .w {
position: absolute;
top: 0;
width: 107.7%;
max-width: none;
margin-left: -3.85%;
}
.service-3 .scroll_img a {
color: #fff;
}
.service-3 .scroll_img a:hover {
opacity: 1;
}
.service-3 .scroll_img a:hover .w {
transform: scale(1.1);
transition: 0.3s ease-in-out;
}
.service-3 .scroll_img a .workscat > span {
border-color: #fff;
background-color: #fff;
color: #4C6F4F;
}
.service-4 {
max-width: 1028px;
}
.service-4 > div {
margin-left: -16px;
margin-right: -16px;
font-size: 0;
letter-spacing: 0;
}
.service-4 > div > div {
width: 212px;
padding: 0px 16px;
display: inline-block;
vertical-align: top;
}
.service-4 .content {
padding-top: 40px;
}
.service-4 p {
font-size: 13px;
line-height: 2;
}
.archive_workslist_title {
font-size: 156.25%;
font-weight: 400;
letter-spacing: 0.25em;
}
.archive_workslist {
margin-left: -16px;
margin-right: -16px;
font-size: 0;
letter-spacing: 0;
text-align: center;
}
.archive_workslist > div {
display: inline-block;
max-width: 424px;
width: 33.33%;
padding: 0 16px;
vertical-align: top;
}
.archive_workslist > div > a {
display: block;
color: #000;
margin-top: 40px;
}
.archive_workslist .bg {
opaciy: 0;
}
.archive_workslist .w {
position: absolute;
top: 0;
left: 0;
margin-top: -14.7%;
}
.archive_workslist .title {
font-weight: 400;
}
.singleworks {
padding-left: 30px;
padding-right: 30px;
}
.singleworksthum {
max-width: 950px;
}
.singleworks .slick-list {
max-width: 816px;
margin-left: auto;
margin-right: auto;
}
.singleworksthum .slick-list {
max-width: 840px;
margin-left: auto;
margin-right: auto;
}
.singleworks .bg,
.singleworksthum .bg {
opacity: 0;
}
.singleworks .w {
position: absolute;
max-height: 100%;
top: 0;
bottom: 0;
left: 0;
right: 0;
margin: auto;
}
.singleworksthum .w {
position: absolute;
top: 0;
width: 110%;
max-width: none;
margin-left: -5%;
max-height: 100%;
}
.singleworks .slick-prev,
.singleworks .slick-next {
width: 60px;
height: 60px;
font-size: 0;
border: solid 1px #707070;
border-radius: 50%;
background-color: #fff;
background-position: center center;
background-repeat: no-repeat;
transition: 0.3s ease-in-out;
z-index: 2;
}
.singleworks .slick-prev {
left: 0px;
background-image: url(images/ar_l.png);
}
.singleworks .slick-next {
right: 0px;
background-image: url(images/ar_r.png);
}
.singleworks .slick-prev:before,
.singleworks .slick-next:before {
display: none;
}
.singleworks .slick-prev:hover {
background-color: #262626;
background-image: url(images/ar_l_w.png);
}
.singleworks .slick-next:hover {
background-color: #262626;
background-image: url(images/ar_r_w.png);
}
.singleworks .num {
font-size: 13px;
}
.singleworksthum .slick-slide {
padding-left: 12px;
padding-right: 12px;
}
.singleworksthum .slick-prev,
.singleworksthum .slick-next {
width: 40px;
height: 40px;
font-size: 0;
border-radius: 50%;
background-color: #4C6F4F;
background-position: center center;
background-repeat: no-repeat;
z-index: 2;
}
.singleworksthum .slick-prev {
left: 0px;
background-image: url(images/ar_l2.png);
}
.singleworksthum .slick-next {
right: 0px;
background-image: url(images/ar_r2.png);
}
.singleworksthum .slick-prev:before,
.singleworksthum .slick-next:before {
display: none;
}
.archive {
max-width: 1028px;
padding: 135px 20px;
}
.archive .newslist {
max-width: 740px;
}
.archive .newslist h2 {
font-size: inherit;
font-weight: 400;
}
.postbox {
width: 100%;
margin-right: -300px;
}
.postbox .entry-title {
margin-top: 20px;
color: #4C6F4F;
}
.postbox .entry-content {
margin-top: 30px;
}
.postbox .entry-content p {
line-height: 2.2;
}
.postbox > div {
margin-right: 300px;
}
.postlinks {
max-width: 280px;
}
.postlinks .prev {
display: inline-block;
width: 6px;
height: 8px;
margin-right: 5px;
background: url(images/tri_l.png) center center no-repeat;
}
.postlinks .next {
display: inline-block;
width: 6px;
height: 8px;
margin-left: 5px;
background: url(images/tri_r.png) center center no-repeat;
}
.postlinks a {
color: #000;
font-size: 13px;
font-weight: 400;
}
.postlinks > div:hover .prev {
background-image(images/tri_l_h.png);
}
.postlinks > div:hover .next {
background-image(images/tri_r_h.png);
}
.postlinks > div:hover a {
color: #4C6F4F;
opacity: 1;
}
#sidebar {
width: 270px;
float: right;
border-radius: 34px;
background-color: #fff;
overflow: hidden;
}
.sidebar_title {
line-height: 80px;
font-weight: 400;
background-color: #DEDEDE;
}
#sidebar > div {
max-width: 200px;
padding: 35px 0 50px;
}
#sidebar ul {
list-style: none;
margin-bottom: 25px;
}
#sidebar .date {
font-size: 14px;
font-weight: 400;
color: #000;
margin-bottom: 5px;
}
#sidebar a {
color: #000;
font-weight: 400;
}
#sidebar li {
padding-top: 15px;
padding-bottom: 15px;
border-bottom: solid 1px #707070;
}
#sidebar li a {
line-height: 2;
}

#sidebar .to_newslist {
font-size: 13px;
padding-right: 20px;
background: url(images/tri_r.png) right center no-repeat;
}
.contactform .title {
margin-top: 25px;
}
.contactform .hissu {
font-size: 13px;
color: #4C6F4F;
}
.contactform .w1 {
max-width: 560px;
}
.contactform .w2 {
max-width: 145px;
}
.contactform input[type=text],
.contactform input[type=tel],
.contactform input[type=email],
.contactform textarea {
margin-top: 10px;
width: 99%;
padding: 20px;
border: solid 1px #707070;
border-radius: 10px;
background-color: #fff;
}
.contactform input[type=checkbox] {
width: 20px;
height: 20px;
vertical-align: middle;
}
.contactform .wpcf7-submit {
max-width: 390px;
width: 100%;
display: block;
line-height: 90px;
margin: 40px auto 0;
background-color: #A7D676;
border-radius: 45px;
border: none;
color: #4C6F4F;
font-size: 150%;
font-weight: 500;
font-family: inherit;
letter-spacing: 0.1em;
}


.contactform .waku {
margin-top: 10px;
border: solid 1px #707070;
border-radius: 10px;
background-color: #fff;
padding: 10px 20px 20px;
width: 99%;
}
.contactform .waku .wpcf7-list-item {
margin-right: 40px;
margin-top: 10px;
}
.wpcf7-not-valid-tip {
margin-top: 4px;
}
.privacypolicy {
background-color: #fff;
padding: 20px;
font-size: 14px;
font-weight:400;
margin-top: 10px;
height: 150px;
overflow: auto;
border-radius: 10px;
}

.rec-1 .left {
width: 48.71%;
max-width: 604px;
}
.rec-1 .left img {
border-radius: 88px;
}
.rec-1 .right {
width: 51.29%;
padding: 5% 20px 0;
}
.rec-1 .right p {
line-height: 3.1;
max-width: 440px;
}
.rec-2, .rec-4 {
margin-left: -16px;
margin-right: -16px;
letter-spacing: 0;
font-size: 0;
}
.rec-2 > div {
display: inline-block;
vertical-align: top;
}
.rec-2 > div > div {
display: inline-block;
vertical-align: top;
padding: 30px 16px 0;
width: 180px;
}
.rec-3 .left {
width: 48.4%;
}
.rec-3 .right {
max-width: 456px;
width: 44.3%;
}
.rec-3 .right img {
border-radius: 50px;
}
.stafflist {
max-width: 760px;
margin-left: 320px;
}
.stafflist .img {
max-width: 286px;
width: 38.7%;
}
.stafflist .right {
padding-left: 20px;
}
.stafflist .right > div {
max-width: 400px;
width: 100%;
}
.stafflist .slick-slide {
padding-left: 10px;
padding-right: 10px;
}
.stafflist .subtitle {
font-size: 14px;
}
.stafflist .content {
padding-left: 10%;
}

.rec-4 > div {
display: inline-block;
vertical-align: top;
padding-top: 50px;
padding-left: 16px;
padding-right: 16px;
width: 25%;
max-width: 318px;
}
.recbox .title {
background-color: #A7D676;
padding: 15px 80px 15px 40px; 
}
.recbox .title a {
position: absolute;
top: 0;
right: 0;
display: block;
height: 100%;
width: 60px;
background: url(images/plus.png) center center no-repeat;
}
.recbox .title a.open {
background-image: url(images/minus.png);
}

.recbox .wrap_desc {
height: 0;
overflow: hidden;
}
.recbox .desc {
background-color: #fff;
padding: 40px 20px 60px;
}
.recbox .desc > div {
max-width: 820px;
}
.jobtbl {
border-collapse: collapse;
width: 100%;
border: solid 1px #707070;
margin-top: 15px;
}
.jobtbl tr {
border-top: solid 1px #707070;
}
.jobtbl th {
background-color: #F5F5F5;
vertical-align: top;
text-align: left;
width: 150px;
padding: 30px 20px;
font-weight: 400;
line-height: 1.86;
}
.jobtbl td {
padding: 30px 20px;
font-weight: 400;
line-height: 1.86;
}
.rec_btm {
background: url(images/rec_btm_bg.jpg) center center no-repeat;
background-size: cover;
}
.rec_btm .btns {
margin-left: -45px;
margin-right: -45px;
font-size: 0;
letter-spacing: 0;
text-align: center;
}
.rec_btm .btns a {
display: inline-block;
vertical-align: top;
max-width: 425px;
margin-top: 40px;
margin-left: 45px;
margin-right: 45px;
text-align: center;
padding: 25px 48px;
border-radius: 75px;
background-color: #fff;
}
.rec_btm .btns a:hover {
opacity: 1;
background-color: #A7D676;
}

@media screen and (max-width: 999px){
#top-head {
top: 0px;
padding: 0;
}
body.open {
overflow: hidden;
}
#top-head.open {
height: 100%;
background-color: rgba(0,0,0,0.7);
}
#top-head > div {
height: 70px;
padding-top: 10px;
overflow: hidden;
}
#top-head.open > div {
height: 100%;
}
#top-head > div:before {
height: 60px;
left: 20px;
top: 10px;
z-index: 102;
border-radius: 30px 0 0 30px;
}
#top-head .logo {
line-height: 60px;
width: auto;
margin-right: 90px;
max-width: 200px;
}
#mobile-nav {
display: block;
}
#global-nav {
position: absolute;
width: 100%;
height: 100%;
overflow: auto;
clear:both;
top: -2000px;
left: 0;
margin-top: -50px;
padding-top: 50px;
padding-left: 50px;
background-color: #f0f0f0;
-webkit-transition: opacity .8s ease-in-out;
-moz-transition: opacity .8s ease-in-out;
transition: opacity .8s ease-in-out;
}
#global-nav > ul {
}
#global-nav > ul > li {
float: none;
height: 40px;
}
#global-nav > ul > li:after {
display: none;
}
#global-nav > ul > li:not(.sub) {
margin-top: 30px;
}
#global-nav > ul > li:not(.sub) a {
color: #000;
}
#global-nav > ul > li.sub {
display: block;
}
#global-nav > ul > li.sub a {
font-size: 14px;
margin-left: 20px;
}
#global-nav > ul > li.last {
padding: 30px 20px;
height: auto;
line-height: 1;
margin-left: -50px;
}
#global-nav > ul > li.last a {
height: 60px;
line-height: 60px;
max-width: 600px;
margin-left: auto;
margin-right: auto;
border-radius: 30px;
}
#footer .ovf_h {
display: none;
}
#footer_to_top {
top: auto;
bottom: 0;
}
.top-1 .left {
width: auto;
float: none;
padding-right: 20px;
}
.top-1 .left > div {
max-width: none;
float: none;
}
.top-1 .right {
overflow: visible;
float: right;
width: 60%;
margin-top: 40px;
}
.top-1 .btn {
margin-left: auto;
margin-right: auto;
}
.top-recruit > div,
.four > div {
width: auto;
display: block;
}
.top-recruit > div > div,
.four > div > div {
width: auto;
max-width: 318px;
}
.top-news .left {
width: 200px;
}
.top-news h2 {
margin-right: -80px;
}
.access .left {
float: none;
width: auto;
margin-bottom: 40px;
}
.about-1 .left {
display: block;
width: auto;
}
.about-1 .left p {
line-height: 1.8;
}
.about-1 .right {
display: block;
width: auto;
margin-top: 40px;
margin-left: auto;
margin-right: auto;
}
.archive_workslist > div {
width: 50%;
}
.singleworksthum .slick-slide {
padding-left: 6px;
padding-right: 6px;
}
.rec-1 .left {
float: none;
width: auto;
}
.rec-1 .right {
width: auto;
padding: 40px 0 0;
}
.rec-1 .right p {
max-width: 800px;
}
.rec-4 > div {
width: 50%;
}
.stafflist {
margin-left: 240px;
}
.stafflist .slick-prev {
left: -160px;
background-image: url(images/ar_l.png);
}
.stafflist .slick-next {
left: -80px;
background-image: url(images/ar_r.png);
}
}
@media screen and (max-width: 767px){
.mg-l0 {
margin-left: 30px;
}
.pd-lr0 {
padding-left: 20px;
padding-right: 20px;
}
.pc767_n {
display: none;
}
.sp767_i {
display: inline;
}
.mainimg {
width: 140%;
margin-left: -20%;
}
.page_toptitle {
top: 60%;
left: 9.8%;
width: 27.5%;
}
.bgrw {
left: 30px;
border-radius: 50px 0 0 50px;
}
.top-news .bgrw {
border-radius: 0 50px 50px 0;
}
.top-2 .linkbox > div {
float: none;
width: auto;
margin-left: auto;
margin-right: auto;
}
.workslist {
margin-left: 100px;
}
.rec-3 > div {
float: none!important;
width: auto!important;
}
.rec-3 .right {
margin-top: 40px;
}

.stafflist {
margin-left: 20px;
padding-bottom: 70px;
}
.singleworks {
padding-left: 20px;
padding-right: 20px;
}
.workslist .slick-prev,
.workslist .slick-next,
.stafflist .slick-prev,
.stafflist .slick-next,
.singleworks .slick-prev,
.singleworks .slick-next {
width: 40px;
height: 40px;
background-size: 10px 9px;
}
.singleworksthum .slick-prev,
.singleworksthum .slick-next {
width: 30px;
height: 30px;
background-size: 8px 7px;
}
.workslist .slick-prev {
left: -100px;
}
.workslist .slick-next {
left: -50px;
}
.stafflist .slick-prev {
left: 50%;
margin-left: -60px;
bottom: 0;
}
.stafflist .slick-next {
left: 50%;
margin-right: -60px;
bottom: 0;
}
.singleworksthum .slick-prev {
left: -7px;
}
.singleworksthum .slick-next {
right: -7px;
}

.top-news .left {
width: auto;
float: none;
margin-bottom: 40px;
}
.top-news h2 {
margin-right: auto;
}
.top-news .newslist {
margin-right: 20px;
}
.about-2 .left {
float: none;
width: auto;
max-width: 498px;
padding-right: 0;
padding-top: 0;
}
.about-2 .right {
float: none;
width: auto;
margin-top: 40px;
}
.about-2 .right > div {
max-width: none;
}
.about-2 .right p {
line-height: 2;
}
.about-tbl th {
width: 200px;
padding: 10px;
}
.about-5 > div {
display: block;
width: 80%;
margin: 50px auto 0;
padding-top: 0;
}
.service-2 {
margin-left: 20px;
}
.service-2 > div {
padding-left: 0;
padding-right: 0;
}
.postbox {
float: none;
margin-right: auto;
}
.postbox > div {
margin-right: auto;
}
#sidebar {
display: none;
}
}

@media screen and (max-width: 639px){
html, .fs-0 {
font-size: 14px;
}
.dbox {
padding: 60px 20px;
}
.mg-t3 {
margin-top: 45px;
}
.mg-t4 {
margin-top: 60px;
}
.pd-t1 {
padding-top: 60px;
}
.pd-b1 {
padding-bottom: 60px;
}
#footer .scroll_text .slick-slide img {
width: 600px;
}
.top-title .i {
width: 70%;
}
.about-tbl,
.about-tbl tr,
.about-tbl tbody,
.about-tbl th,
.about-tbl td {
width: auto;
display: block;
}
.about-tbl tr {
border-top: none;
}
.about-tbl th {
background-color: #707070;
color: #fff;
}
.about-tbl td {
padding-left: 20px;
}
.archive_workslist > div {
width: auto;
}
}

@media screen and (max-width: 480px){
.bdr1 {
border-radius: 15px;
}
.bdr2 {
border-radius: 10px;
}
#footer > div {
padding-right: 60px;
}
#footer_to_top {
width: 60px;
}
.btn {
max-width: 260px;
height: 60px;
line-height: 54px;
padding-right: 30px;
padding-left: 70px;
}
.btn:before {
left: 40px;
}
.btn:hover:before {
left: 45px;
}
.btn .bar, .btn .en {
display: none;
}
.btn .jp {
width: auto;
}
.newslist li {
height: auto;
line-height: 1;
padding-top: 20px;
padding-bottom: 20px;
}
.newslist .title {
height: auto;
display: block;
line-height: 1.4;
margin-top: 5px;
}
.jobtbl,
.jobtbl tr,
.jobtbl tbody,
.jobtbl th,
.jobtbl td {
width: auto;
display: block;
}
.jobtbl th,
.jobtbl td {
padding: 15px 10px;
}
.rec-1 .left img,
.rec-3 .right img {
border-radius: 30px;
}
.stafflist .img {
float: none;
width: auto;
margin-left: auto;
margin-right: auto;
}
.stafflist .right {
padding-left: 0;
margin-top: 30px;
}
.stafflist .right > div {
max-width: none;
}

}
