@charset "utf-8";

#wpadminbar {position: fixed!important;} html,body {min-width: 768px;}
body {padding-top: 50px;}
.sp {display: none!important;} .container {width: 90vw; margin: 0 auto;} .h-g {padding: 80px 0;}
.h-g .big {font-size: 40px;}
.h-g .small {font-size: 15px;} .more {margin: 100px auto;}
.more a {min-width: 260px;} .sub_cat_navi {margin-bottom: 40px;} .pagination {margin-bottom: 48px;}
.h-news_entry,
.h-works_entry {width: calc((100% - 36px) / 2); margin: 0 36px 42px 0;}
.h-news_entry:nth-child(even),
.h-works_entry:nth-child(even) {margin-right: 0;}
.h-news_entry a,
.h-works_entry a {height: 37.5vw;}
.h-news_entry a .cat,
.h-works_entry a .cat {top: 20px; font-size: 12px; padding: 4px 20px;}
.h-news_entry .text h2,
.h-works_entry .text h2 {font-size: 20px;}
.h-news_entry .text p {font-size: 14px;}
.h-news_entry .text time,
.h-works_entry .text time {font-size: 14px;} header {position: fixed; top: 0; height: 50px; box-shadow: 0 0 2px 0 #aaa;}
.customize-support header {top: 46px;}
@media screen and (min-width: 783px) {
.customize-support header {top: 32px;}
}
header .logo img {width: auto; height: 25px;} header #nav-toggle {position: relative; right: -10px; width: 50px; height: 50px; z-index: 400;}
header #nav-toggle > div {position: absolute; left: 10px; width: 30px; height: 2px; background: var(--color-green); transition: .3s ease;}
header #nav-toggle div:nth-child(1) {top: 18px;}
header #nav-toggle div:nth-child(2) {top: 24px; opacity: 1;}
header #nav-toggle div:nth-child(3) {top: 30px;}
header .g-navi {flex-direction: column; justify-content: center; align-items: center; position: fixed; top: 0; right: 0; width: 360px; height: 100dvh; background: #fff; transition: .5s ease transform; transform: translateX(100%); z-index: 300;}
header .g-navi a {display: block; font-size: 15px; text-align: center; padding: 8px 0;}
header .g-navi a span {position: relative; display: block; color: inherit; z-index: 2;}
header .g-navi a.recruit {display: flex; justify-content: center; align-items: center; gap: 6px; width: 100%; color: #fff; background: var(--color-green); margin-top: 12px; padding: 12px 0; border-top: 1px solid var(--color-green); border-bottom: 1px solid var(--color-green);}
header .g-navi a.recruit:hover {color: var(--color-green); background: #fff;}
header .g-navi a.recruit svg {position: relative; width: 1em; fill: #fff; z-index: 2;}
header .g-navi a.recruit:hover svg {fill: var(--color-green);}
header .g-navi-back {content: ""; position: fixed; inset: 0; width: 100vw; height: 100dvh; background: rgba(0,0,0, .375); opacity: 0; visibility: hidden; pointer-events: none; transition: .3s ease; z-index: 299;}
.open header .g-navi {transform: translateX(0);}
.open header .g-navi-back {opacity: 1; visibility: visible; pointer-events: auto;}
.open #nav-toggle div:nth-child(1) {transform: rotate(45deg); top: 24px;}
.open #nav-toggle div:nth-child(2) {opacity: 0;}
.open #nav-toggle div:nth-child(3) {transform: rotate(-45deg); top: 24px;} footer .container {display: block; text-align: center; margin: 10px auto;}
footer .info {padding: 20px 0 10px;}
footer .info .logo {display: inline-block; margin-bottom: 10px;}
footer .info .logo img {width: auto; height: 30px;}
footer .info .recruit {width: 280px; margin: 15px auto 0; padding: 8px 0;}
footer .info .add {margin-top: 15px;}
footer .info .add dl {margin-top: 10px;}
footer .info .add dl dt {margin-bottom: 3px;}
footer .f-navi {display: inline-flex; gap: 10px 25px; padding: 10px 0;}
footer .f-navi ul {text-align: left;} #scroll {right: 32px; bottom: 32px; width: 60px; height: 60px;}
#scroll a {height: 50%; font-size: 20px; line-height: 1.5;}  #front .anim .container {position: absolute; left: 50%; transform: translateX(-50%); width: 1200px;} #front .copy {display: block; padding: 60px 0;}
#front .copy h2 {font-size: 42px; margin-bottom: 20px;}
#front .copy h2 br {display: none;} #front .business .entry {display: block; width: calc((100% - 60px) / 2); margin: 60px 60px 0 0;}
#front .business .entry:nth-child(2n) {margin-right: 0;}
#front .business .entry img {position: relative; width: auto; height: 120px; margin: auto; padding-bottom: 30px;}
#front .business .entry .w {left: 16px;}
#front .business .entry .g {left: 34px;}
#front .business .entry .p {left: -14px;}
#front .business .entry .m {left: 26px;}
#front .business .entry .t {left: 14px;}
#front .business .entry .i {left: 46px; top :4px;}
#front .business .entry .text {min-height: 240px; background: #fff; padding: 10px 32px 12px;}
#front .business .entry .text h3 {font-size: 18px; text-align: center; padding: 8px 0; border-bottom: 1px solid #aaa;}
#front .business .entry .text ul {padding: 7.5px 5px;}
#front .business .entry .text ul li {line-height: 2;}
#front .business .entry .text ul li:before {content: "≫"; padding: 0 5px 0 0;} #front .works .works_list {flex-wrap: wrap;}
#front .works .works_entry {display: block; position: relative; width: calc(100% / 3); height: calc(100vw / 3); background: #000; overflow: hidden;}
#front .works .works_entry .cover h3 {font-size: 15px; margin: 0 20px;}
#front .works .works_entry img {width: 100%; height: 100%; object-fit: cover; object-position: 50%; font-family: 'object-fit: cover; object-position: 50% 50%;';}
#front .works .works_entry .cat {position: absolute; display: block; top: 16px; right: 0; color: #fff; font-size: 12px; line-height: 1; background: var(--color-green); padding: 4px 20px;}
#front .works .works_entry:hover img {transform: scale(1.1,1.1);}
#front .works .works_entry:hover img .cat {opacity: 1;} #front .member {background: #e4e4e4; padding-bottom: 10px;}
#front .member .member_list {width: 660px; margin: 0 auto; justify-content: flex-start; flex-wrap: wrap;}
#front .member .member_entry {width: 180px; margin: 0 60px 60px 0;}
#front .member .member_entry:nth-child(3n) {margin-right: 0;}
#front .member .member_entry {cursor: pointer;}
#front .member .member_entry div {position: relative; width: 100%; height: 180px; border-radius: 50%; -webkit-perspective: 500px; perspective: 500px; transition: all .75s;}
#front .member .member_entry div img {position: absolute; top: 0; left: 0; width: 100%; height: 100%; border-radius: 50%; -webkit-backface-visibility:hidden; backface-visibility: hidden; object-fit: cover; object-position: 50%; font-family: 'object-fit: cover; object-position: 50% 50%;'; transition: all .75s;}
#front .member .member_entry div .front {transform: rotateY(0deg); z-index: 1;}
#front .member .member_entry div .back {transform: rotateY(180deg); z-index: 2;}
#front .member .member_entry:hover div .front {transform: rotateY(180deg); z-index: 1;}
#front .member .member_entry:hover div .back {transform: rotateY(0deg); z-index: 2;}
#front .member .member_entry p,
#front .member .member_entry h3 {text-align: center; transition: .3s ease;}
#front .member .member_entry:hover p,
#front .member .member_entry:hover h3 {color: var(--color-green);}
#front .member .member_entry p {font-size: 12px; margin: 18px 0 0;}
#front .member .member_entry h3 {font-size: 18px;} #front .member .member_entry.shake:hover {animation: buruburu .1s infinite;} #front .profile {margin-bottom: 100px;}
#front .profile table {
width: 100%;
margin: 0 auto;
font-size: 14px;
line-height: 1.5;
text-align: left; border: 1px solid #ccc;
}
#front .profile table th,
#front .profile table td {vertical-align: top; padding: 7.5px 12.5px; border-bottom: 1px dotted #ccc;}
#front .profile table th { width: 20%;
} #front .map {}
#front .map .googlemap {height: 400px;}
#front .map .traffic {display: block; margin: 50px auto; padding: 0 30px;}
@media screen and (min-width: 1920px) {
#googlemap {padding-bottom: 25%;}
} #front .news {}
#front .news .news_list {display: block; width: 100%; margin: 0 auto;}
#front .news .news_entry {justify-content: space-between; align-items: center; margin-bottom: 12px; padding: 0 10px 10px; border-bottom: 1px solid #ccc;}
#front .news .news_entry:hover {opacity: 1; border-color: var(--color-green);} #front .video {width: 100%; height: 400px; overflow: hidden;}
#front .video video {min-width: 100%; height: 100%; object-fit: cover; object-position: 50%; font-family: 'object-fit: cover; object-position: 50%;';} #front .office_photo {flex-wrap: wrap; padding: 50px 0 42px;}
#front .office_photo a {display: block; width: calc((100% - 24px) / 4); height: 132px; margin: 0 8px 8px 0;}
#front .office_photo a:nth-child(4n) {margin-right: 0;}
#front .office_photo a img {width: 100%; height: 100%; object-fit: cover; object-position: 50%; font-family: 'object-fit: cover; object-position: 50%;';} #front .banner {}
#front .banner .big {display: block; width: 980px; height: auto; margin: 0 auto;}
#front .banner .banner_box {justify-content: space-between; flex-wrap: nowrap; margin-bottom: 24px;}
#front .banner .banner_box a {display: block; width: 18%; height: 100px;}  #single-state {margin-top: 30px;}
#single-state h1 {font-size: 32px; padding: 80px 10px;}
#single-state .viewsite {padding: 8px 20px;}
.postlink {padding: 12px 0;} #single {margin-bottom: 40px;}
#single .main_img {margin-bottom: 30px;}
#single h2 {font-size: 26px; padding: 16px 0;}
#single h3 {font-size: 22px; padding: 0 15px;}
#single h4 {font-size: 18px; padding: 0 0 0 20px;}
#single h4:before {top: 6px; left: 0; width: 12px; height: 12px;} #single-works {margin-bottom: 40px;}
#single-works .main-img {max-width: calc(100% - 30px); height: 54vw; margin: 20px auto; box-shadow: 15px 15px 0 0 var(--color-green);}
#single-works .main-img.web {width: 100%; height: 100%;}
#single-works .state table {width: auto; margin: 120px auto 0;}
#single-works .state table th {width: 25%;}
#single-works .state .overview {margin: 100px auto 0;}
#single-works .works-img {margin: 100px auto;}
#single-works .works-img.pc-small-img,
#single-works .works-img.pc-big-img {margin: 100px auto;}
#single-works .works-img.pc-small-img {max-width: 660px;}
#single-works .works-img.pc-small-img a {width: 300px; height: 240px; margin: 15px;}
#single-works .works-img.pc-big-img a {width: 30%; max-width: 220px; height: 220px; margin: 0 10px;}
#single-works .works-img.sp-img a {width: 152px; height: 271px; margin: 60px 25px;}
#single-works .works-img.sp-img a:before {width: 176px; height: 374px; top: -56px; left: -12px;} #wcd .wcd_list {flex-wrap: wrap;}
#wcd .wcd_list .wcd_entry {width: 100%; margin: 0 0 40px 0; padding: 25px;}
#wcd .wcd_list .wcd_entry img {height: 360px;}
#wcd .wcd_list .wcd_entry h2 {font-size: 20px; margin: 20px 0 15px; padding-left: 10px;}
#wcd .wcd_list .wcd_entry p {font-size: 14px;} #recruit .recruit_card-list {
margin-bottom: 60px;
}
#recruit .recruit_card-list .recruit_card-item {
width: calc((100% - 40px) / 3);
}
#recruit .recruit_card-list .recruit_card-item:not(:nth-child(3n)) {
margin-right: 20px;
}
#recruit .recruit_card-list .recruit_card-item .recruit_card-content {
padding: 26px 22px 5px;
}
#recruit .recruit_card-list .recruit_card-item .recruit_card-title {
font-size: 20px;
margin-bottom: 22px;
}
#recruit .recruit_card-list .recruit_card-item .recruit_card-post-title {
margin-bottom: 15px;
}
#recruit .recruit_card-list .recruit_card-item .recruit_card-post-title span {
font-size: 15px;
}
#recruit .recruit_card-list .recruit_card-item .recruit_card-post-list {
margin-bottom: 20px;
}
#recruit .recruit_card-list .recruit_card-item .recruit_card-post-item {
font-size: 14px;
margin-bottom: 12px;
} #contact .page-description {margin: 0 0 80px;}
.form {width: 88%; margin: 0 auto 80px;}
.form .tab_select li {height: 200px;}
.form .tab_select li img,
.form .tab_select li svg {height: 90px;}
.form .tab_select li span {font-size: 18px; margin-top: 30px;}
.form .tab_content li {padding: 50px;}
.form .tab_content li p.center {margin-bottom: 50px;}
.form .tab_content .inner {width: 90%; max-width: 960px;}
.form .tab_content dl {display: flex; align-items: center;}
.form .tab_content dt {width: 40%; padding: 0 2%;}
.form .tab_content dd {width: 60%; padding: 0 2%;}
.form .tab_content .wpcf7-radio {margin: 0 -38px 0 38px;}
.form .tab_content .wpcf7-radio .wpcf7-list-item-label {margin-right: 38px;}
.form .tab_content input[type="submit"] {font-size: 16px; padding: 12px 100px;}
.form .tab_content .cheak {margin: 40px auto;}
@media screen and (max-width: 1024px) {
.form {width: 100%;}
.form .tab_content li {padding: 40px;}
.form .tab_content li p.center {margin-bottom: 40px;}
.form .tab_content .wpcf7-radio {flex-direction: column; text-align: left;}
.form .tab_content .wpcf7-radio .wpcf7-list-item-label {margin: 5px 38px 5px 0;}
}
@media screen and (max-width: 768px) {
.form .tab_content li {padding: 30px;}
.form .tab_content li p.center {margin-bottom: 30px;}
.form .tab_content li p.center em {display: block;}
.form .tab_content .inner {width: 100%;}
.form .tab_content dt {width: 44%; padding: 0 2% 0 1%;}
.form .tab_content dd {width: 56%; padding: 0 1% 0 2%;}
} #notfound {padding: 100px 0 40px;}
#notfound h1 span.big {font-size: 140px;}
#notfound p {margin: 50px 0;}
#notfound .more {margin: 50px auto;}