@charset "utf-8";
/* CSS Document */

/*common*/
/* body {
    overflow: hidden;
    min-width: 1240px;
}

#menu {
    display: none;
}

.flex {
    flex-wrap: wrap;
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
}

.flex-sb {
    flex-wrap: wrap;
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    justify-content: space-between;
}

.sp {
    display: none;
} */

body {
    min-width: auto;
}

img {
    max-width: 100%;
}

a:hover img {
    opacity: 0.7;
}

.en {
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
}

.con_inner {
    max-width: 1200px;
    margin: 0 auto;
}

/*heading*/
.heading01 {
    font-size: 16px;
    text-align: center;
    /* color: #ffffff; */
}

.heading01 .en {
    font-size: 46px;
    font-weight: 500;
    display: inline-block;
    position: relative;
    padding-top: 16px;
}

.heading01 .en::before {
    content: "";
    display: inline-block;
    width: 100%;
    height: 1px;
    background-color: #000;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
}

div#works .heading01 .en::before {
    background: #fff;
}

.heading01 .rubi {
    display: block;
}

.heading02 {
    font-size: 30px;
    color: #ffffff;
    padding: 6px 24px;
    background-color: #222222;
    position: relative;
    overflow: hidden;
}

.heading02::before {
    content: "";
    display: block;
    width: 340px;
    height: 100%;
    position: absolute;
    top: 0;
    left: -15px;
    background-color: #333333;
    transform: skew(25deg);
}

.heading02 span {
    position: relative;
    z-index: 5;
}

.heading02 .en {
    font-weight: 500;
}

.hd_top {
    background: #f3f3f3;
    overflow: hidden;
    border-bottom: 1px solid #cdcdcd;
}

.hd_btm {
    background: #000000;
    overflow: hidden;
    height: 65px;
}

.hdTop_logo {
    float: left;
    padding: 5px 0;
}

ul.navSub {
    float: right;
    width: 700px;
    overflow: hidden;
}

ul.navSub li {
    float: left;
}

ul.navSub li a {
    display: block;
    margin: 0 15px;
    font-weight: bold;
    line-height: 60px;
    position: relative;
}

ul.navSub li a::before {
    content: "";
    position: absolute;
    display: block;
    width: 0;
    height: 3px;
    background-color: #000000;
    bottom: 18px;
    left: 50%;
    -webkit-transition: .2s linear;
    -moz-transition: .2s linear;
    -o-transition: .2s linear;
    transition: .2s linear;
}

ul.navSub li a:hover::before {
    width: 100%;
    left: 0;
}

.hdTop_logo p {
    background: url(/wp/wp-content/uploads/2020/09/logo_nishida.png) no-repeat 20px 8px;
}

.hdBtm_L {
    float: left;
    width: calc(100% - 630px);
}

.hdBtm_R {
    float: right;
    width: 630px;
    transform: skew(25deg);
    overflow: hidden;
    margin-right: -4vw;
}

.hd_btm a {
    color: #fff;
    font-weight: bold;
}

.hdBtm_R li {
    float: left;
    width: 100px;
    text-align: center;
}

.hdBtm_R li.nishida_logo {
    width: 310px;
}

.hdBtm_R li.nishida_logo a {
    background: #f3f3f2;
}

.hdBtm_R li.nishida_logo a p {
    padding-right: 40px;
    padding-top: 2px;
}

.hdBtm_logo {
    float: left;
    padding: 15px 0 0 20px;
    width: 186px;
}

.hdBtm_L nav {
    float: right;
    line-height: 1;
}

.hdBtm_L nav a {
    line-height: 65px;
    display: inline-block;
    margin: 0 10px;
    position: relative;
}

.hdBtm_L nav a::before {
    content: "";
    position: absolute;
    display: block;
    width: 0;
    height: 3px;
    background-color: #000000;
    bottom: 20px;
    left: 50%;
    -webkit-transition: .2s linear;
    -moz-transition: .2s linear;
    -o-transition: .2s linear;
    transition: .2s linear;
}

.hdBtm_L nav a:hover::before {
    width: 100%;
    left: 0;
}

.hdBtm_L nav a::before {
    background-color: #ffffff;
}

.hdBtm_R ul {
    transform: skew(-25deg);
}

.hdBtm_R li.news {
    margin-left: 15px;
}

.hdBtm_R li.news p {
    background: url(/wp/wp-content/uploads/2020/09/ico_news.png) no-repeat center 8px;
    background-size: 24px auto;
    padding-top: 35px;
}

.hdBtm_R li.news a {
    background: #777;
}

.hdBtm_R li.news a:hover {
    background: #aaa;
}

.hdBtm_R li a {
    display: block;
    color: #ffffff;
    text-decoration: none;
    transform: skew(25deg);
    width: 100%;
    height: 66px;
}

.hdBtm_R li p {
    position: absolute;
    transform: skew(-25deg);
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    font-size: 13px;
}

.hdBtm_R li.contact a {
    background: #680c0d;
}

.hdBtm_R li.contact a:hover {
    background: #bb5d5e;
}

.hdBtm_R li.contact p {
    background: url(/wp/wp-content/uploads/2020/09/ico_contact.png) no-repeat center 8px;
    background-size: 24px auto;
    padding-top: 35px;
}

.hdBtm_R li.faq a {
    background: #340507;
}

.hdBtm_R li.faq a:hover {
    background: #8e3236;
}

.hdBtm_R li.faq p {
    background: url(/wp/wp-content/uploads/2020/09/ico_faq.png) no-repeat center 8px;
    background-size: 24px auto;
    padding-top: 35px;
}

.hdBtm_R li.tel {
    width: 255px;
}

.hdBtm_R li.tel a {
    background: #fff;
    color: #333;
    line-height: 70px;
}

.hdBtm_R li.tel a p {
    padding-right: 25px;
}

.hdBtm_R li p span {
    font-size: 20px;
}

/*button*/
.btn01 {
    text-align: center;
}

.btn01 a {
    display: inline-block;
    width: 324px;
    height: 60px;
    line-height: 60px;
    font-size: 16px;
    position: relative
}

.btn01 a span {
    position: relative;
    z-index: 3;
}

.btn01 a::before {
    content: "";
    display: block;
    width: 0;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    -webkit-transition:.2s linear;
    -moz-transition:.2s linear;
    -o-transition:.2s linear;
    transition:.2s linear;
}

.btn01 a:hover::before {
    width: 100%;
}

.btn01.black a {
    background-color: #000000;
    color: #ffffff;
}

.btn01.black a::before {
    background-color: #680c0d;
}

.btn01.red a {
    background-color: #680c0d;
    color: #ffffff;
}

.btn01.red a::before {
    background-color: #000000;
}

.btn01.prev a::after {
    content: "";
    display: block;
    width: 7px;
    height: 10px;
    background-image: url(/wp/wp-content/uploads/2020/09/ico_arrow01_l.png);
    background-size: 7px auto;
    position: absolute;
    top: calc(50% - 3px);
    left: 20px;
}

.btn01.next a::after {
    content: "";
    display: block;
    width: 7px;
    height: 10px;
    background-image: url(/wp/wp-content/uploads/2020/09/ico_arrow01_r.png);
    background-size: 7px auto;
    position: absolute;
    top: calc(50% - 3px);
    right: 20px;
}

/*header*/
header {
    background-color: #222222;
    /* height: 118px; */
    overflow: hidden;
    box-shadow: 0px 0px 6px 3px rgba(0,0,0,0.07);
    -moz-box-shadow: 0px 0px 6px 3px rgba(0,0,0,0.07);
    -webkit-box-shadow: 0px 0px 6px 3px rgba(0,0,0,0.07);
}

header .head_left {
    color: #ffffff;
    font-size: 16px;
    padding: 20px 30px;
    float: left;
    width: calc(100% - 670px);
}

header .head_left h1 {
    display: inline-block;
    vertical-align: middle;
}

header .head_left p {
    display: inline-block;
    margin-left: 25px;
    vertical-align: middle;
}

header .head_right {
    float: right;
    width: 690px;
    transform: skew(25deg);
    overflow: hidden;
    height: 118px;
    margin-right: -27px;
}

header .head_right .inner {
    transform: skew(-25deg);
    margin-left: -13px;
}

.skew-menu {
    text-align: center;
    height: 66px;
}

.skew-menu ul {
    /*display: inline-block;*/
    margin: 0;
    padding: 0;
    list-style: none;
    width: 100%;
}

.skew-menu ul li {
    float: left;
    box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
    text-transform: uppercase;
    color: #555;
    font-weight: bolder;
    transition: all 0.3s linear;
    width: 150px;
}

.skew-menu ul li.nishida {
    width: calc(100% - 300px);
}

.skew-menu ul li a {
    display: block;
    color: #ffffff;
    text-decoration: none;
    transform: skew(25deg);
    width: 100%;
    height: 66px;
}

.skew-menu ul li a p {
    position: absolute;
    transform: skew(-25deg);
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    font-size: 13px;
}

.skew-menu ul li.news a {
    background-color: #777777;
}

.skew-menu ul li.news a:hover {
    background-color: #aaaaaa;
}

.skew-menu ul li.news a p {
    background: url(/wp/wp-content/uploads/2020/09/ico_news.png) no-repeat center 8px;
    background-size: 24px auto;
    padding-top: 35px;
}

.skew-menu ul li.contact a {
    background-color: #680c0d;
}

.skew-menu ul li.contact a:hover {
    background-color: #bb5d5e;
}

.skew-menu ul li.contact a p {
    background: url(/wp/wp-content/uploads/2020/09/ico_contact.png) no-repeat center 8px;
    background-size: 24px auto;
    padding-top: 35px;
}

.skew-menu ul li.faq a {
    background: #340507;
}

.skew-menu ul li.faq a:hover {
    background: #8e3236;
}

.skew-menu ul li.faq a p {
    background: url(/wp/wp-content/uploads/2020/09/ico_faq.png) no-repeat center 8px;
    background-size: 24px auto;
    padding-top: 35px;
}

.skew-menu ul li.nishida a {
    background-color: #f3f3f2;
    overflow: hidden;
}

.skew-menu ul li.nishida a:hover {
    background-color: #eeeeee;
}

.nav {
    background-color: #ffffff;
    text-align: center;
}

.nav ul li {
    display: inline-block;
    text-align: center;
    height: 52px;
    padding: 0 30px;
    line-height: 52px;
    font-weight: bold;
}

.nav ul li a {
    position: relative;
}

.nav ul li a::before {
    content: "";
    position: absolute;
    display: block;
    width: 0;
    height: 3px;
    background-color: #000000;
    bottom: -7px;
    left: 50%;
    -webkit-transition: .2s linear;
    -moz-transition: .2s linear;
    -o-transition: .2s linear;
    transition: .2s linear;
}

.nav ul li a:hover::before {
    width: 100%;
    left: 0;
}

#head_sub {
    background-color: rgba(0,0,0,0.8);
    min-width: 1200px;
}

#head_sub .logo {
    float: left;
    padding: 15px 0 0 20px;
    width: 186px;
}

#head_sub .head_sub_right {
    float: right;
}

#head_sub .nav {
    float: left;
    background: none;
    margin-right: 10px;
}

#head_sub .nav li {
    height: 66px;
    line-height: 66px;
    padding: 0 20px;
}

#head_sub .nav li a::before {
    background-color: #ffffff;
}

#head_sub .nav li a {
    color: #ffffff;
}

#head_sub .head_sub_btn {
    float: left;
}

#head_sub .skew-menu {
    width: 610px;
    margin-right: -17px;
}

#head_sub .skew-menu ul li {
    width: 100px;
}

#head_sub .skew-menu ul li.nishida_logo {
    width: 310px;
}

#head_sub .skew-menu ul li.nishida_logo a {
    background: #f3f3f2;
}

#head_sub .skew-menu ul li.nishida_logo a p {
    padding-right: 15px;
}

#head_sub .skew-menu ul li.nishida {
    width: calc(100% - 300px);
}

#head_sub .skew-menu ul li.nishida a {
    color: #000;
}

#head_sub .skew-menu ul li.nishida a p {
    font-size: 13px;
    padding-right: 40px;
    padding-top: 10px;
    text-align: right;
    font-weight: normal;
}

#head_sub .skew-menu ul li.nishida a p span {
    display: block;
    font-size: 14px;
    font-weight: bold;
}

body.fixed #head_sub {
    position: fixed;
    z-index: 999;
    width: 100%;
    top: 0;
    left: 0;
}

/*page top*/
#page-top {
    display: block;
    width: 60px;
    height: 60px;
    text-align: center;
    position: fixed;
    bottom: 20px;
    right: 20px;
    cursor: pointer;
    z-index: 5;
    background-color: #484848;
    padding: 15px;
}

#page-top:hover {
    opacity: 0.7;
    -webkit-transition:.2s linear;
    -moz-transition:.2s linear;
    -o-transition:.2s linear;
}

#page-top.relative {
    position: relative;
    right: inherit;
    bottom: inherit;
    width: 100%;
    padding: 14px 0;
}

#page-top.relative img {
    height: 100%;
}

/*footer*/
footer .footTop {
    background-color: #000000;
    padding: 40px 30px;
}

footer .footTop .logo {
    float: left;
    padding: 10px;
    width: 106px;
}

footer .footTop .fr {
    text-align: right;
}

footer .footTop .link li {
    display: inline-block;
    margin-bottom: 20px;
    margin-left: 20px;
}

footer .footTop .link li a {
    color: #ffffff;
}

footer .footTop .link li a:hover {
    color: #cccccc;
}

footer .footTop .bn li {
    display: inline-block;
    margin-left: 20px;
}

#footer_area {
    background:#fff;
}

#footer_area .info01 {
    overflow:hidden;
    _height:1%;
    clear:both;
    background:#fff;
    border-top:2px solid #dfdfdf;
    border-bottom:1px solid #d9d9d9
}

#footer_area div .wrap {
    margin:0 auto;
    width:960px;
    font-size:12px;
}

#footer_area .pagetop {
    float:right;
}

#footer_area .info01 .list li a,
#footer_area ul.link li a {
    color:#000;
}

#footer_area .info01 .list li a {
    display: block;
    padding: 10px 0;
}

#footer_area .info01 .list li a:hover {
    opacity: .7;
}

#footer_area a:link {
    color:#333;
    text-decoration:none;
}

#footer_area a:visited {
    color: inherit;
}

#footer_area a:hover {
    color:#999;
}

/*--info01-----------------*/
#footer_area .info01 .wrap {
    clear:both;
    overflow:hidden;
    _height:1%;
}

#footer_area .info01 p {
    float:left;
    margin-right:30px;
}

#footer_area .info01 .list {
    float:left;
    width:790px;
    overflow:hidden;
}

#footer_area .info01 .list li {
    float:left;
    margin-right:30px;
}

/*--info02-----------------*/
#footer_area .info02 {
    border-bottom:1px solid #d9d9d9
}

#footer_area .info02 .wrap {
    overflow:hidden;
    _height:1%;
    margin:0 auto;
    padding:36px 0 36px 0;
    width:960px;
}

#footer_area .info02 .wrap li {
    float:left;
    width:19%;
}

#footer_area .info02 .wrap li.col01 {
    width:23%;
}

#footer_area .info02 .wrap li li {
    margin-bottom:4px;
    float:none;
    width:100%;
    font-size:11px;
}

#footer_area .info02 .wrap .sub li {
    padding-left:10px;
}

#footer_area .info02 .wrap li p {
    margin-bottom:10px;
    font-weight:bold;
}

#footer_area .info02 .wrap li p.spLink01 {
    margin-top:30px;
}

#footer_area .info02 .wrap li span {
    display:block;
    margin:10px 0;
}

#footer_area .info02 .info02 .contact {
    float: right;
}

/*--info03-----------------*/
#footer_area .info03 {
    padding:20px 0;
}

#footer_area .info03 .wrap {
    overflow:hidden;
    _height:1%;
}

#footer_area .info03 ul {
    overflow:hidden;
    _height:1%;
    width:550px;
    float: left;
    max-width: 100%;
}

#footer_area .info03 ul li {
    float:left;
}

#footer_area .info03 .name {
    font-weight:bold;
    margin-right:30px;
}

#footer_area .info03 .name span {
    display:block;
    font-weight:normal;
    font-size:10px;
}

#footer_area .info03 .copy {
    margin-top:10px;
    float: right;
    font-size:9px;
    color:#9c9c9c;
    width:380px;
    text-align:right;
}

/*モーダル*/
.lineup_modal .modal-content {
    width: 900px;
    margin: 0;
    padding: 50px 50px 55px;
    border: 1px solid #aaa;
    background: #fff;
    z-index: 6;
}

#modal-overlay {
    z-index: 1;
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 120%;
    background-color: rgba( 0,0,0, 0.75 );
}

.lineup_modal .button-link {
    position: absolute;
    display: block;
    width: 82px;
    height: 36px;
    top: -46px;
    right: 0;
}

.lineup_modal .button-link:hover {
    cursor: pointer;
}

.lineup_modal .modal-content .item_img {
    float: left;
    margin-right: 48px;
    width: 400px;
}

.lineup_modal .modal-content .item_img span.length {
    display: block;
    text-align: center;
    margin-top: 10px;
    font-weight: bold;
    font-size: 16px;
}

.lineup_modal .modal-content .item_img span.length::before {
    content: "";
    display: block;
    width: 100%;
    height: 13px;
    background: url(/wp/wp-content/uploads/2020/09/img_length.png) no-repeat center center;
    background-size: 100% auto;
}

.lineup_modal .modal-content .item_img span.length span {
    font-size: 22px;
}

.lineup_modal .modal-content .item_info {
    float: left;
    width: 350px;
}

.lineup_modal .modal-content .item_info .cat {
    width: 156px;
    text-align: center;
    padding: 5px 0;
    font-size: 12px;
}

.lineup_modal .modal-content .item_info .cat.white {
    border: 1px solid #eeeeee;
}

.lineup_modal .modal-content .item_info .cat.silver {
    background-color: #f1f1f1;
}

.lineup_modal .modal-content .item_info .cat.gray {
    background-color: #999999;
    color: #ffffff;
}

.lineup_modal .modal-content .item_info .cat.champagne {
    background-color: #f2e2cf;
}

.lineup_modal .modal-content .item_info .cat.bronze {
    background-color: #8e7362;
    color: #ffffff;
}

.lineup_modal .modal-content .item_info .cat.black {
    background-color: #000000;
    color: #ffffff;
}

.lineup_modal .modal-content .item_info .cat.texture {
    border: 1px solid #000000;
}

.lineup_modal .modal-content .item_info .name {
    margin: 20px 0 40px;
    font-size: 36px;
    line-height: 1.2;
}

.lineup_modal .modal-content .item_info dl {
    font-size: 16px;
}

.lineup_modal .modal-content .item_info dl dt {
    float: left;
    width: 140px;
    position: relative;
}

.lineup_modal .modal-content .item_info dl dt::after {
    content: ":";
    position: absolute;
    right: 0;
}

.lineup_modal .modal-content .item_info dl dd {
    padding-left: 160px;
    line-height: 1.3;
    margin-bottom: 10px;
}

.lineup_modal .modal-content .btn01 {
    margin-top: 40px;
}

.lineup_modal .modal-content .btn01 a span {
    background: url(..//wp/wp-content/uploads/2020/09/ico_contact.png) no-repeat left center;
    background-size: 24px auto;
    padding-left: 35px;
}

/*************************************************
下層共通
*************************************************/
.under_mv {
    background-position: center center;
    background-size: cover;
    padding: 70px 0 60px;
}

.under_mv h2 {
    text-align: center;
    font-size: 20px;
    color: #ffffff;
}

.under_mv h2 .en {
    font-size: 56px;
    display: block;
}

.under_mv .mv_text {
    max-width: 1220px;
    margin: 30px auto 0;
    color: #fff;
    text-align: center;
    font-weight: 700;
    font-size: 16px;
    line-height: 1.7;
}

/*ソートボタン*/
.sort_btn {
    padding: 0 10px;
    background-color: #ececec;
}

.sort_btn .inner {
    max-width: 1220px;
    margin: 0 auto;
    padding: 35px 0;
}

.sort_btn ul li {
    width: 18.36%;
    margin: 0.82%;
    float: left;
    background-color: #ffffff;
    text-align: center;
    font-weight: bold;
    cursor: pointer;
    height: 50px;
    line-height: 50px;
    -webkit-transition: .2s linear;
    -moz-transition: .2s linear;
    -o-transition: .2s linear;
    transition: .2s linear;
}

.sort_btn ul li:hover {
    opacity: 0.7;
}

.sort_btn ul li.active {
    background-color: #680c0d;
    color: #ffffff;
}

/*実績リスト*/
.works_list li {
    float: left;
    margin-right: 20px;
    margin-bottom: 20px;
    width: 285px;
    height: 190px;
    position: relative;
    -webkit-transition:.2s linear;
    -moz-transition:.2s linear;
    -o-transition:.2s linear;
    transition:.2s linear;
}

.works_list li:nth-of-type(4n) {
    margin-right: 0;
}

.works_list li a {
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
    -js-display: flex;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

.works_list li a:hover {
    box-shadow:0px 0px 6px 3px rgba(0,0,0,0.2);
    -moz-box-shadow:0px 0px 6px 3px rgba(0,0,0,0.2);
    -webkit-box-shadow:0px 0px 6px 3px rgba(0,0,0,0.2);
}

.works_list li .thum {
    width: 100%;
    height: 100%;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    -moz-transition: -moz-transform 0.2s linear;
    -webkit-transition: -webkit-transform 0.2s linear;
    -o-transition: -o-transform 0.2s linear;
    -ms-transition: -ms-transform 0.2s linear;
    transition: transform 0.2s linear;
    position: absolute;
    top: 0;
    left: 0;
}

.works_list li:hover .thum {
    /* -webkit-transform: scale(1.2); */
    /* -moz-transform: scale(1.2); */
    /* -o-transform: scale(1.2); */
    /* -ms-transform: scale(1.2); */
    /* transform: scale(1.2); */
}

.works_list li .txt {
    position: relative;
    width: 100%;
    text-align: center;
    color: #ffffff;
    -webkit-transition:.2s linear;
    -moz-transition:.2s linear;
    -o-transition:.2s linear;
    transition:.2s linear;
    opacity: 0;
    font-size: 15px;
    font-weight: bold;
    z-index: 3;
}

.works_list li .txt span {
    display: inline-block;
    padding: 5px 10px;
    border: 1px solid #ffffff;
    font-size: 12px;
    margin-top: 5px;
}

.works_list li:hover .txt {
    opacity: 1;
}

/* .works_list li:hover .txt br {
    display: none;
} */

.works_list li a::before {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 0 36px 36px;
    border-color: transparent transparent #680c0d transparent;
    position: absolute;
    z-index: 3;
    right: 0;
    bottom: 0;
    opacity: 0.8;
    -webkit-transition:.2s linear;
    -moz-transition:.2s linear;
    -o-transition:.2s linear;
    transition:.2s linear;
}

.works_list li:hover a::before {
    border-width: 0 0 570px 570px;
}

.search_formWrap {
    max-width: 1220px;
    margin: 50px auto;
}

.search_formWrap #search_form {
    border: 5px solid #680c0d;
    padding: 20px;
    position: relative;
    margin-bottom: 20px;
}

.search_formWrap #search_form.works_form {
    /* height: 592px; */
    overflow: hidden;
}

.search_formWrap p.attention{
    color: #e30000;
    font-size: 12px;
}

.search_formWrap h2 {
    background: #680c0d;
    color: #fff;
    font-size: 16px;
    font-weight: 600;
    width: 300px;
    height: 45px;
    line-height: 45px;
    text-align: center;
    position: relative;
}

.search_formWrap h2 i {
    position: absolute;
    left: 80px;
    top: 12px;
    font-size: 20px;
}

.search_formWrap .fl_wrap.type01 {
    margin-bottom: 20px;
    align-items: center;
}

.search_formWrap .fl_wrap .search-box {
    width: 48%;
    margin-bottom: 30px;
}

.lineup_form .fl_wrap .search-box {
    width: 31%;
}

.search_formWrap .fl_wrap .search-box.type02 .radioWrap:nth-child(odd) {
    width: 50%;
}

.search_formWrap .fl_wrap .search-box.type02 .radioWrap:nth-child(even) {
    width: 40%;
}

.search_formWrap .fl_wrap.type02 .search-box h3 {
    width: 100%;
    display: block;
    border-bottom: 1px solid #000;
    padding-bottom: 5px;
    margin-bottom: 15px;
    padding-left: 1em;
    font-size: 16px;
}

.search_formWrap .fl_wrap.type02 .search-box h3 span {
    font-size: 12px;
    font-weight: normal;
    margin-left: 1em;
    color: #5b5b5b;
}

.radioWrap {
    width: 45%;
    display: inline-block;
    margin-bottom: 10px;
}

.labelWrap.colorWrap label.radioWrap:nth-child(odd) {
    width: 55%;
}

.labelWrap.colorWrap label.radioWrap:nth-child(even) {
    width: 35%;
}

label.radioWrap {
    line-height: 135%;
    position: relative;
    margin: 0.5rem;
    cursor: pointer;
    cursor:-moz-pointer;
    cursor:-webkit-pointer;
    -webkit-user-select: pointer;
    -moz-user-select: pointer;
    -ms-user-select: pointer;
    user-select: pointer;
}

label.radioWrap input {
    position: relative;
    margin: 0 10px 0 0;
    cursor: pointer;
}

label.radioWrap input:before,
label.radioWrap input:after {
    position: absolute;
    z-index: 1;
    top: -0.125rem;
    left: -0.125rem;
    width: 1rem;
    height: 1rem;
    content: '';
    -webkit-transition: all 0s ease-in-out;
    transition: all 0s ease-in-out;
    border-radius: 50%;
    background: #ffffff;
}

label.radioWrap input:after {
    z-index: 0;
    top: -0.25rem;
    left: -0.25rem;
    width: 1.25rem;
    height: 1.25rem;
    background: #7d7d7d;
}

label.radioWrap input:checked::after {
    background: #1c8c00;
}

label.radioWrap input:checked:before {
    -webkit-transform: scale(0, 0);
    transform: scale(0, 0);
    border-width: 0.625rem;
    border-color: #1c8c00;
}

.radioWrap div {
    margin-right: 5px;
}

.search_formWrap .btnWrap {
    width: 40%;
}

.search_formWrap .searchBtn {
    height: 45px;
    line-height: 45px;
    font-size: 16px;
    text-align: center;
    transition: .3s;
    border-radius: 50px;
}

.search_formWrap .searchBtn:active {
    opacity: 1;
    -webkit-animation: flash 1s;
    animation: flash 1s;
}

.search_formWrap #button {
    background: #ffa500;
    color: #fff;
    width: 60%;
    position: relative;
}

.search_formWrap #button input {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 30px;
    cursor: pointer;
    background: no-repeat;
    opacity: 0;
}

.search_formWrap #button i {
    margin-right: 20px;
}

.search_formWrap #release {
    background: #333;
    color: #fff;
    width: 35%;
    cursor: pointer;
}

.numWrap.flex {
    margin-bottom: 50px;
}

p.hit_text {
    font-size: 16px;
}

p.hit_text span {
    font-size: 20px;
    margin: 0 5px;
    color: #ffa500;
}

p.hit_text.all    span {
    color: #000;
}

.search-box_label {
    font-weight: bold;
}

.is-hide {
    display: none;
}

.fl_wrap02 .overseas {
    width: 48%;
}

div#check_itemArea span {
    border: 1px solid;
    padding: 1em;
    font-size: 14px;
    margin: 10px;
    width: 200px;
    text-align: center;
}

div#check_itemArea {
    justify-content: center;
}

.cp_ipselect {
    display: block;
    width: 50%;
    height: 100%;
    position: relative;
    background: #fff;
    z-index: 2;
}

.cp_ipselect ul {
    list-style: none;
    padding: 0;
    position: relative;
}

.cp_ipselect input {
    color: inherit;
    font: inherit;
    margin: 0;
    background: transparent;
    outline: none;
    border: none;
    border-radius: 0;
    -webkit-appearance: none;
    appearance: none;
    display:none;
    position: relative;
}

.cp_sl08 {
    width: 100%;
    height: 100%;
    cursor: pointer;
    /* background-color: white; */
    -webkit-box-shadow: 0 2px 0 white;
    box-shadow: 0 2px 0 white;
    border-radius: 2px;
}

.cp_sl08_expand {
    width: 0;
    height: 40px;
    position: absolute;
    top: 0;
    right: 0;
}

.cp_sl08_expand::after {
    position: absolute;
    top: 1.2em;
    right: 0.5em;
    width: 0;
    height: 0;
    padding: 0;
    content: '';
    pointer-events: none;
    border-top: 6px solid rgba(0, 0, 0, 0.3);
    border-right: 6px solid transparent;
    border-left: 6px solid transparent;
    -webkit-transform: translate(-50%, -50%) rotate(0deg) scaleY(1.75);
    transform: translate(-50%, -50%) rotate(0deg) scaleY(1.75);
    -webkit-transition: all 250ms cubic-bezier(0.4,0.25,0.3,1);
    transition: all 250ms cubic-bezier(0.4,0.25,0.3,1);
    z-index: 2;
    opacity: 0.6;
}

.cp_sl08_expand:hover::after {
    opacity: 1;
}

.cp_sl08_expand:checked::after {
    -webkit-transform: translate(-50%, -50%) rotate(180deg) scaleX(-1) scaleY(1.75);
    transform: translate(-50%, -50%) rotate(180deg) scaleX(-1) scaleY(1.75);
}

.cp_sl08_expandLabel {
    display: block;
    width: 100%;
    height: 40px;
    position: absolute;
    top: 0;
    left: 0;
    cursor: pointer;
}

.cp_sl08_close {
    display: none;
}

.cp_sl08_closeLabel {
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    display: none;
}

.cp_sl08_items {
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    border: 2px solid #680c0d;
    border-radius: 2px;
    /* padding-top: 30px; */
    max-height: 200px;
    overflow: scroll;
    -ms-overflow-style: none; /* IE, Edge 対応 */
    scrollbar-width: none; /* Firefox 対応 */
}

.cp_sl08_items select {
    border: none;
    width: 100%;
    padding: 5px 10px;
    cursor: pointer;
}

.cp_sl08_input {
    display: none;
}

.cp_sl08_label {
    -webkit-transition: all 250ms cubic-bezier(0.4,0.25,0.3,1);
    transition: all 250ms cubic-bezier(0.4,0.25,0.3,1);
    display: block;
    height: 0;
    line-height: 30px;
    overflow: hidden;
    color: #3e3e3e;
    background-color: #ffffff;
    cursor: pointer;
    padding-left: 20px;
}

.cp_sl08_placeholder {
    height: 40px;
    vertical-align: middle;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0.6;
    background-color: transparent;
}

.cp_sl08_expand:checked + .cp_sl08_closeLabel {
    display: block;
}

.cp_sl08_expand:checked + .cp_sl08_closeLabel + .cp_sl08_options .cp_sl08_label {
    height: 30px;
}

.cp_sl08_expand:checked + .cp_sl08_closeLabel + .cp_sl08_options .cp_sl08_label:hover {
    background-color: #bdbdbd;
}

.cp_sl08_expand:checked + .cp_sl08_closeLabel + .cp_sl08_options + .cp_sl08_expandLabel {
    display: none;
}

.cp_sl08_input:checked + .cp_sl08_label {
    height: 30px;
    margin-top: -30px;
}

.modal_contentWrap {
    margin: 0 auto;
}

.modal {
    display: none;
    height: 100vh;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 99999;
}

.modal__bg {
    background: rgba(0,0,0,0.8);
    height: 100vh;
    position: absolute;
    width: 100%;
}

.modal__content {
    background: #fff;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%,-50%);
    width: 60%;
    max-height: 90vh;
}

.modal__contentIn {
    height: 75vh;
    overflow: scroll;
    overflow-y:scroll;
    padding: 20px 150px;
    padding: 20px 10vw;
}

.use_bukken {
    margin: 10px 0 50px 0;
}

.use_bukken h3 {
    margin-bottom: 1em;
    background: #ccc;
    padding: .5em 1em;
    color: #1a1a1a;
}

.use_bukken ul li {
    width: 48%;
    border-bottom: 1px solid #ccc;
    padding: 10px;
    position: relative;
}

.use_bukken ul li:before {
    content: "";
    font-family: "Font Awesome 5 Free";
    content: '\f054';
    font-weight: 900;
    position: absolute;
    right: 10px;
    top: 10px;
    color: #ccc;
}

.use_bukken ul li:nth-of-type(even) {
    margin-left: 4%;
}

.use_bukken ul li:nth-of-type( -n + 2 ) {
    border-top: 1px solid #ccc;
}

.modal__content .movie {
    width: 100%;
    height: 25vw;
    margin-bottom: 15px;
    position: relative;
    margin-top: 15px;
}

.modal__content .movie iframe {
    width: 96%;
    height: 90%;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    max-width: 100%;
    max-height: 100%;
}

.modal__content .imageWrap .image {
    width: 48%;
    height: 11.5vw;
    position: relative;
    margin-bottom: 15px;
}

.modal__content .imageWrap .image a {
    display: block;
    width: 100%;
    height: calc(100% - 10px);
    background-size: cover;
    background-position: center;
}

.modal__content .imageWrap .image span {
    display: block;
    width: 100%;
    height: 25px;
    position: absolute;
    left: 0;
    bottom: -15px;
    font-size: 12px;
    line-height: 25px;
    text-align: center;
}

.modal__content .imageWrap .image img {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 90%;
    height: auto;
}

.modal__content .text p.type span {
    background: #e8e8e8;
    display: inline-block;
    color: #1a1a1a;
    padding: .2em 1em;
    font-size: 12px;
    margin-bottom: 10px;
    margin-right: 10px;
}

.modal__content .fl_wrap {
    margin-bottom: 20px;
}

.modal__content .text h2 {
    margin-bottom: 1em;
    font-size: 20px;
}

.modal__content .text p.main_text {
    margin-bottom: 1em;
}

.modal__content .text dl {
    margin-bottom: 5px;
}

.modal__content .text dl dt {
    width: 35%;
}

.modal__content .text dl dd {
    width: 65%;
}

a.contactBtn {
    display: block;
    width: 50%;
    height: 40px;
    line-height: 40px;
    background: #000;
    color: #fff;
    text-align: center;
    margin: 0 auto;
}

a.js-modal-close {
    position: absolute;
    right: 20px;
    top: 10px;
    font-size: 30px;
    cursor: pointer;
}

.about_al_page {
    margin: 100px auto;
    max-width: 1220px;
}

.about_al_page .image_wrap {
    height: 510px;
    position: relative;
    margin-bottom: 100px;
}

.about_al_page .image_wrap .type01 {
    position: absolute;
    left: 0;
    top: 0;
    width: 63%;
}

.about_al_page .image_wrap .type02 {
    position: absolute;
    right: 0;
    top: 0;
    width: 34%;
}

.about_al_page .image_wrap .type03 {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 34%;
}

.image_wrap_bottom .image {
    width: 48%;
}

.attention_wrap {
    border: 1px solid #ccc;
    padding: 40px 20px;
    box-shadow: 1px 1px 2px #333;
    margin-top: 100px;
}

.attention_wrap h2 {
    text-align: center;
    font-size: 25px;
    margin-bottom: 30px;
}

.attention_wrap h2 span {
    display: block;
    font-size: 17px;
}

.attention_wrap p.main_text {
    text-align: center;
    font-size: 16px;
    line-height: 2.5;
    margin-bottom: 50px;
}

.attention_wrap h3 {
    font-size: 20px;
    text-align: center;
    color: #9f0000;
    margin-bottom: 20px;
}

.attention_wrap ol li {
    line-height: 2;
}

.attention_wrap ol {
    margin-bottom: 50px;
}

.attention_wrap table {
    width: 100%;
    border-collapse: collapse;
}

.attention_wrap table th {
    background: #bcbcbc;
    min-width: 120px;
}

.attention_wrap table th,
.attention_wrap table td {
    border: 1px solid #ccc;
    padding: 20px;
    vertical-align: middle;
    text-align: center;
}

.about_flWrap {
    margin-bottom: 100px;
}

.about_flWrap .image {
    width: 50%;
}

.about_flWrap .text {
    width: 45%;
}

.about_flWrap .text h2 {
    font-size: 25px;
    margin-bottom: .5em;
    border-bottom: 3px solid #777;
    position: relative;
    padding-bottom: 10px;
}

.about_flWrap .text h2:after {
    content: "";
    display: block;
    width: 100px;
    height: 3px;
    background: #680c0d;
    position: absolute;
    left: 0;
    bottom: -3px;
}

.about_flWrap .text h2 img {
    height: 35px;
}

.about_flWrap .text h2:before {
    content: "";
    display: block;
    width: 100px;
    height: 3px;
    background: #680c0d;
    position: absolute;
    left: 0;
    bottom: -3px;
}

.about_flWrap .text p {
    font-size: 15px;
    line-height: 2;
}

.stepWrap {
    margin-bottom: 180px;
}

.stepWrap p.attention_text {
    font-size: 18px;
    color: #4b4b4b;
    text-align: center;
}

.stepWrap ul {
    justify-content: center;
    margin-bottom: 40px;
}

.stepWrap ul li {
    position: relative;
    color: #680c0d;
}

.stepWrap h3 {
    text-align: center;
    margin-bottom: 2em;
    font-size: 28px;
    color: #333;
}

.stepImg {
    text-align: center;
}

span.text_kako {
    position: absolute;
    right: 14px;
    top: 55px;
    font-size: 14px;
    color: #fff;
    background: #414141;
    padding: 5px 15px;
    border-radius: 20px;
}

.stepWrap ul li .li_in {
    width: 200px;
    height: 200px;
    border: 2px solid #680c0d;
    border-radius: 100%;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    text-align: center;
    padding-top: 20px;
    line-height: 2;
    font-size: 16px;
    margin-right: 80px;
}

.stepWrap ul li:after {
    font-family: "Font Awesome 5 Free";
    content: '\f101';
    font-weight: 900;
    position: absolute;
    right: 25px;
    top: 85px;
    font-size: 40px;
}

.stepWrap ul li:last-child::after {
    display: none;
}

.stepWrap ul li span.num {
    position: absolute;
    left: 0;
    top: -2px;
    width: 100%;
    display: block;
    background: #680c0d;
    height: 50px;
    line-height: 50px;
    color: #fff;
    font-size: 14px;
}

.common_flWrap {
    margin-bottom: 100px;
}

.common_flWrap .image {
    width: 50%;
}

.common_flWrap .text {
    width: 45%;
}

.common_flWrap .text h3 {
    font-size: 25px;
    margin-bottom: .5em;
    position: relative;
    border-bottom: 3px solid #777;
}

.common_flWrap .text h3:before {
    content: "";
    display: block;
    width: 100px;
    height: 3px;
    background: #680c0d;
    position: absolute;
    left: 0;
    bottom: -3px;
}

.common_flWrap .text p {
    font-size: 15px;
    line-height: 2;
}

.common_flWrap.w100 .text {
    width: 100%;
}

.common_flWrap.w100 .text a {
    position: relative;
    display: block;
    width: 400px;
    max-width: 100%;
    height: 60px;
    line-height: 60px;
    text-align: center;
    margin: 0 auto;
    background: #680c0d;
    color: #fff;
    border-radius: 50px;
    margin-top: 50px;
}

.common_flWrap.w100 .text a:after {
    font-family: "Font Awesome 5 Free";
    content: '\f105';
    font-weight: 900;
    position: absolute;
    right: 80px;
    top: 0px;
}

.lb-outerContainer {
    width: 1152px !important;
    height: 648px !important;
    max-width: 1152px;
    max-height: 648px;
    overflow: hidden;
    border: solid 5px #fff;
}

.lightbox .lb-image {
    width: 100%!important;
    height: auto!important;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
}

.use_bukken span.morelink {
    width: 100%;
    text-align: center;
    margin: 10px 0 0;
    background: #f2f2f2;
    font-weight: bold;
    padding: 5px 0;
    border-radius: 5px;
    position: relative;
    cursor: pointer;
}

.work_info .clearfix {
    display: flex;
    justify-content: center;
}

.work_info .clearfix #mapArea:empty {
    display: none;
}

.work_detail .use_item > div.morelink {
    text-align: center;
    border: 1px solid #808080;
    padding: 10px 0;
    cursor: pointer;
}

.use_bukken ul span.morelink:last-child {
    display: none !important;
}

.about_al_page .common_flWrap .text h3 img {
    height: 30px;
}

.about_al_page .common_flWrap .text h3 {
    padding-bottom: 10px;
}

.about_al_page .attention_wrap h2 img {
    height: 40px;
    margin: 0 0 20px;
}

/* カラーステンレスとは箇所ここから */

.page-template-page-csus .about_box{
    margin-bottom: 100px;
    margin-top: -100px;
}

.page-template-page-csus .about_box .con_inner{
}

.page-template-page-csus .about_box .type-main{
    margin-bottom: 50px;
}

.page-template-page-csus .about_box .type-main dl dt h2{
    background: #333;
    color: #fff;
    font-size: 20px;
    padding: 1em;
    padding-left: 80px;
    margin-bottom: 1em;
    position: relative;
}

.page-template-page-csus .about_box .type-main dl dt h2:after{
    content: "";
    display: block;
    width: 40px;
    height: 1px;
    background: #fff;
    position: absolute;
    left: 20px;
    top: 50%;
}


.page-template-page-csus .about_box .type-main dl dd{
    font-size: 15px;
    line-height: 2.2;
}

.page-template-page-csus .about_box .type-sub .fl_wrap{
    align-items: center;
}

.page-template-page-csus .about_box .type-sub .image_box{
    width: 30%;
    text-align: center;
    order: -1;
}

.page-template-page-csus .about_box .type-sub .textArea{
    width: 68%;
}

.page-template-page-csus .about_box .type-sub .image_box p{
    font-size: 22px;
    font-weight: 600;
    margin-bottom: 1em;
    text-decoration: underline;
}

.page-template-page-csus .about_box .type-sub dl {
    margin-bottom: 2em;
}

.page-template-page-csus .about_box .type-sub dl:last-child{
    margin-bottom: 0;
}

.page-template-page-csus .about_box .type-sub dl dt{
    font-size: 18px;
    margin-bottom: .5em;
    border-bottom: 2px solid;
    padding-bottom: .5em;
    position: relative;
    padding-left: 1em;
}

.page-template-page-csus .about_box .type-sub dl dt:before{
    content: "■";
    position: absolute;
    left: 0;
    top: -10px;
    font-size: 12px;
    color: #333;
}

.page-template-page-csus .about_box .type-sub dl dd{
    line-height: 2;
    font-size: 14px;
}

.page-template-page-csus .about_box .type-sub dl dt span{
    font-style: italic;
    margin-right: .5em;
}

.page-template-page-csus .about_box .type-sub{
    margin-bottom: 50px;
}

.page-template-page-csus .about_box .type-sub:last-child{
    margin-bottom: 0;
}

.page-template-page-csus .about_box .type-sub h3{
    font-size: 22px;
    margin-bottom: 1.5em;
    background: #f1f1f1;
    padding: .5em;
    border-left: 5px solid;
    padding-left: 20px;
}

/* カラーステンレスとは箇所ここまで */

.list_page_text_area {
    margin-bottom: 40px;
}

.list_page_text_area .list_page_text_area_ttl {
    background-color: #000;
    color: #fff;
    font-size: 20px;
    font-weight: 700;
    width: fit-content;
    padding: .5em;
    margin-bottom: -1em;
    position: relative;
    z-index: 1;
}

.list_page_text_area .inner {
    background-color: #f9f9f9;
    padding: 40px 35px;
    margin-left: 30px;
}

.list_page_text_area .inner .text {
    font-size: 16px;
    line-height: 1.7;
    font-weight: 500;
    letter-spacing: .02em;
}

.list_page_text_area .inner .text .blue {
    color: #395dfa;
}

.list_page_text_area .inner .text .red {
    color: #f03939;
}

.list_page_text_area .inner .text+.text {
    margin-top: 1em;
}

@media (max-width: 1340px) {

    header .head_left {
        width: calc(100% - 610px);
        font-size: 14px;
    }

    header .head_right {
        width: 610px;
    }

    .skew-menu ul li {
        width: 110px;
    }

    .skew-menu ul li.nishida {
        width: calc(100% - 220px);
    }

    .nav ul li {
        padding: 0 20px;
    }

    #head_sub .nav li {
        padding: 0 15px;
    }

    #head_sub .skew-menu {
        width: 580px;
    }

    #head_sub .skew-menu ul li {
        width: 90px;
    }

    #head_sub .skew-menu ul li.nishida {
        width: calc(100% - 280px);
    }

    #head_sub .skew-menu ul li.nishida a p {
        background-size: 83% auto;
        background-position: 8px 14px;
    }

}

@media screen and (max-width: 1260px) {

    .search_formWrap {
        width: 94%;
    }

    div#map {
        width: 94%;
        padding: 70px 0 0;
    }

    div#mapArea {
        max-width: 100%;
    }

}

@media screen and (max-width: 1240px) {

    .con_inner {
        width: 90%;
    }

    div#works .con_inner {
        width: 100%;
        padding: 0 10px;
    }

    .works_list li {
        width: 25%;
        padding: 10px;
        height: calc((225vw - 225px) / 16 + 20px);
        margin: 0;
    }

    .works_list li .txt {
        font-size: 1.5vw;
    }

    .works_list li .txt span {
        font-size: 1.2vw;
        padding: 0vw 2vw;
        line-height: 2;
    }

}

/**追加CSS SP START**/
@media (max-width: 767px) {

    .pc {
        display: none;
    }

    .wrap {
        max-width: 96%;
    }

    body#front_page {
        min-width: 100%;
    }

    #page-top {
        width: 50px;
        height: 50px;
        bottom: 10px;
        right: 10px;
    }

    .slicknav_nav {
        background: #000;
    }

    ul.spNav_sub {
        background: #e4e4e4;
    }

    ul.spNav_sub02 {
        background: #fff;
    }

    ul.spNav a > a {
        border-bottom: none;
    }

    ul.spNav li > a, ul.spNav li > a > a {
        color: #fff !important;
        font-size: 14px;
        font-weight: normal;
    }

    ul.spNav li > a {
        padding: 10px !important;
    }

    ul.spNav_sub li > a, ul.spNav_sub li a > a {
        color: #333 !important;
        font-size: 12px;
        line-height: 2;
    }

    ul.spNav_sub li > a {
        padding: 5px 10px !important;
    }

    .spNav02 {
        padding: 40px 10px 20px;
    }

    .spNav02 a {
        color: #fff !important;
        display: inline-block;
        font-weight: bold;
        width: 100%;
        text-align: center;
        font-size: 14px;
        border: none;
        line-height: 30px;
    }

    .spNav02 p {
        width: 48%;
    }

    .spNav02 p.news {
        background: #767676;
    }

    .spNav02 p.contact {
        background: #681310;
    }

    .spNav02 i {
        width: 20px;
        height: 20px;
        display: inline-block;
        line-height: 0;
        margin-right: 8px;
    }

    .spNav02 i img {
        display: inline-block;
        vertical-align: middle;
    }

    .slicknav_nav .slicknav_arrow {
        position: absolute;
        right: 10px;
    }

    .btn01.prev a::after {
        left: 10px;
    }

    .btn01.next a::after {
        right: 10px;
    }

    body {
        overflow: hidden;
        min-width: 100%;
    }

    .search_formWrap {
        margin: 20px auto;
        margin-bottom: 0;
        background: #f2f2f2;
        padding: 10px;
        padding-bottom: 20px;
    }

    .search_formWrap h2 {
        width: 100%;
        height: auto;
        line-height: 0;
        padding: 20px;
    }

    .search_formWrap #search_form {
        background: #fff;
        margin-bottom: 50px;
        padding-bottom: 140px;
        position: relative;
    }

    .search_formWrap .fl_wrap {
        display: block;
    }

    .search_formWrap .fl_wrap .search-box {
        width: 100%;
        position: relative;
        margin-bottom: 0;
    }

    .search_formWrap .btnWrap {
        width: 90%;
        position: absolute;
        left: 5%;
        bottom: 20px;
        justify-content: center;
    }

    .search_formWrap #button {
        width: 80%;
        margin-bottom: 10px;
        position: relative;
    }

    .search_formWrap #release {
        width: 55%;
        order: 1;
        background: #9a9a9a;
    }

    .search_formWrap .fl_wrap.type02 .search-box h3 {
        position: relative;
        color: #fff;
        background: #333;
        padding-top: 5px;
        padding-right: 30px;
        padding-left: 10px;
    }

    .search_formWrap .fl_wrap.type02 .search-box h3 span {
        color: #fff;
    }

    .search_formWrap .fl_wrap.type02 .search-box h3:before {
        content: "";
        font-family: "Font Awesome 5 Free";
        content: '\f0fe';
        font-weight: 900;
        position: absolute;
        right: 10px;
        top: 3px;
        font-size: 19px;
    }

    .search_formWrap .fl_wrap.type02 .search-box span.closeBtn {
        position: absolute;
        right: 10px;
        top: 8px;
        color: #fff;
        z-index: 2;
    }

    .search_formWrap .fl_wrap.type02 .search-box h3.selected:before {
        content: '\f146';
    }

    p.closeBtnHat {
        display: none;
    }

    .radioWrap {
        width: 100% !important;
    }

    .labelWrap {
        padding-bottom: 20px;
        display: none;
    }

    .search_formWrap h2 i {
        position: static;
        font-size: initial;
        margin-right: 10px;
    }

    .fl_wrap02 {
        display: block;
    }

    .fl_wrap02 .overseas {
        width: 100%;
    }

    .cp_ipselect {
        width: 100%;
        height: 40px;
        z-index: 2;
    }

    footer .footTop .logo {
        float: initial;
        width: 70px;
        margin: auto;
    }

    footer .footTop .fr {
        width: 220px;
        float: initial;
        margin: auto;
    }

    footer .footTop .bn li {
        margin: 15px auto 0;
    }

    #footer_area .info01 .list li {
        margin-right: 10px;
        font-size: 11px;
    }

    #footer_area .pagetop {
        display: none;
    }

    #footer_area .info03 ul li {
        float: initial;
        font-size: 12px!important;
    }

    #footer_area .info03 .name {
        margin: 0 auto 10px;
    }

    .modal__content .imageWrap {
        width: 100%;
    }

    .modal__content .text {
        width: 100%;
    }

    .modal__content {
        top: 50%;
        width: 90%;
    }

    .modal__contentIn {
        padding: 2vw;
        padding-bottom: 8vw;
    }

    a.js-modal-close {
        position: absolute;
        right: 8px;
        top: 8px;
        font-size: 5vw;
        background: #000;
        padding: 0 2vw;
        color: #ffffff;
    }

    .modal__content .text .type {
        padding-right: 10vw;
    }

    .movieBtn {
        text-align: right;
        margin-bottom: 20px;
    }

    a.contactBtn {
        width: 80%;
    }

    .use_bukken {
        margin-bottom: 8vw;
    }

    .modal__content .imageWrap .image {
        width: 49%;
        height: calc(22.2525vw + 10px);
        margin-bottom: 5vw;
    }

    .modal__content .movie {
        height: 55vw;
        margin-bottom: 2vw;
    }

    .heading02 {
        font-size: 20px;
        padding: 3px 14px;
    }

    .works_list li:hover a::before {
        border-width: 0 0 36px 36px;
    }

    .modal__content .imageWrap .image span {
        font-size: 2.5vw;
        line-height: 5vw;
        height: 5vw;
    }

    .use_bukken ul li {
        width: 100%;
        padding: 10px;
    }

    .use_bukken ul li:nth-of-type(even) {
        margin-left: 0;
    }

    .use_bukken ul li:nth-of-type( -n + 2 ) {
        border-top: none;
    }

    .search_formWrap #search_form.works_form {
        height: auto;
    }

    div#check_itemArea span {
        font-size: 3vw;
        margin: 0 0 5px;
        width: 49%;
        padding: 5px;
    }

    .search_formWrap .fl_wrap .search-box.type02 .radioWrap:nth-child(odd) {
        width: 100%;
    }

    .search_formWrap .fl_wrap .search-box.type02 .radioWrap:nth-child(even) {
        width: 100%;
    }

    .numWrap.flex {
        margin-bottom: 0;
    }

    div#check_itemArea {
        margin-top: 20px;
        justify-content: space-between;
    }

    div#check_itemArea:empty {
        margin-top: 0;
    }

    .about_al_page .image_wrap {
        height: auto;
        margin-bottom: 10px;
        padding: 2%;
    }

    .about_al_page .image_wrap .type01,
    .about_al_page .image_wrap .type02,
    .about_al_page .image_wrap .type03 {
        position: static;
        width: 100%;
        margin: 20px 0;
    }

    .image_wrap_bottom .image {
        width: 100%;
        margin-bottom: 50px;
    }

    .about_al_page    .table_wrap {
        overflow: scroll;
    }

    .about_al_page table {
        width: 1000px;
    }

    p.table_attention_text.sp {
        text-align: right;
        font-size: 12px;
    }

    .attention_wrap {
        width: 96%;
        margin: 0 auto;
        margin-top: 50px;
    }

    .about_flWrap .image {
        width: 100%;
    }

    .about_flWrap .text {
        width: 100%;
        margin-bottom: 20px;
    }

    .about_al_page {
        padding: 0 2%;
        margin-top: 50px;
    }

    .stepWrap p.attention_text {
        font-size: 16px;
        line-height: 2;
    }

    .stepWrap ul {
        justify-content: center;
        margin-bottom: 0;
    }

    .stepWrap ul li {
        width: 90%;
        height: auto;
        margin-bottom: 10vw;
        border-radius: 5px;
    }

    .stepWrap ul li:nth-child(2),
    .stepWrap ul li:nth-child(3) {
        margin-bottom: 10vw;
    }

    .stepWrap ul li:nth-child(2)::after,
    .stepWrap ul li:nth-child(3)::after {
        top: 100%;
    }

    .stepWrap ul li .li_in {
        width: 100%;
        height: auto;
        padding-top: 0;
        font-size: 4vw;
        border-radius: 5px;
    }

    .stepWrap ul li .li_in p {
        margin: 5vw 0;
    }

    .stepWrap ul li:nth-child(3):before {
        display: none;
    }

    .stepWrap ul li:after {
        right: 48%;
        top: 100%;
        font-size: 5vw;
        -moz-transform: rotate(90deg);
        -webkit-transform: rotate(90deg);
        -o-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
        transform: rotate(90deg);
    }

    .stepWrap ul li span.num {
        height: auto;
        font-size: 3vw;
        position: static;
        line-height: 1;
        padding: 2vw 0;
    }

    .common_flWrap .image {
        width: 100%;
    }

    .common_flWrap .text {
        width: 100%;
        order: -1;
        margin-bottom: 20px;
    }

    .stepWrap {
        margin-bottom: 50px;
    }

    .common_flWrap .text h3 {
        font-size: 20px;
    }

    .common_flWrap .text p {
        font-size: 14px;
    }

    .common_flWrap {
        margin-bottom: 50px;
    }

    span.text_kako {
        text-align: center;
        margin-top: 4vw;
        font-size: 4vw;
        background: #414141;
        color: #ffff;
        border-radius: 20px;
        position: static;
        display: block;
    }

    .stepWrap h3 {
        font-size: 4.5vw;
    }

    .lb-outerContainer {
        width: 94%!important;
        height: 52.875vw!important;
    }

    .lb-dataContainer {
        width: 94%!important;
    }

    .works_list li a:hover {
        box-shadow: none;
        -moz-box-shadow: none;
        -webkit-box-shadow: none;
    }

    .about_flWrap {
        margin-bottom: 50px;
    }

    #footer_area .info03 .copy {
        width:100%;
        text-align:center;
    }

    .work_detail .use_item .type02 .item_img {
        width: 100%;
        height: 150px;
    }

    .work_info .clearfix {
        display: block;
    }

    .lb-dataContainer {
        margin-top: 27vw;
    }

    .labelWrap.colorWrap label.radioWrap:nth-child(even) {
        width: 100%;
    }

    .labelWrap.colorWrap label.radioWrap:nth-child(odd) {
        width: 100%;
    }

    div#works .con_inner {
        padding: 0;
        width: 94%;
        margin: auto;
    }

    .about_al_page .common_flWrap .text h3 img {
        height: 25px;
    }

    .about_flWrap .text h2 img {
        height: 30px;
    }

    .about_al_page .attention_wrap h2 img {
        height: 30px;
        margin: 0 0 15px;
    }

    .search_formWrap p.attention{
        font-size: 2.5vw;
    }

    /* カラーステンレスとは箇所ここから */

    .page-template-page-csus .about_box{
        margin-bottom: 10vw;
        margin-top: 0;
    }

    .page-template-page-csus .about_box .type-main{
        margin-bottom: 4vw;
    }

    .page-template-page-csus .about_box .type-main dl dt h2{
        font-size: 4vw;
        padding-left: 10vw;
    }

    .page-template-page-csus .about_box .type-main dl dt h2:after{
        width: 5vw;
        left: 2vw;
    }

    .page-template-page-csus .about_box .type-main dl dd{
        font-size: 13px;
        line-height: 2;
    }

    .page-template-page-csus .about_box .type-sub .image_box p{
        font-size: 18px;
    }

    .page-template-page-csus .about_box .type-sub dl dt{
        font-size: 14px;
    }

    .page-template-page-csus .about_box .type-sub dl dt:before{
        font-size: 10px;
    }

    .page-template-page-csus .about_box .type-sub dl dd{
        font-size: 12px;
    }
    
    .page-template-page-csus .about_box .type-sub{
        margin-bottom: 40px;
    }

    .page-template-page-csus .about_box .type-sub h3{
        font-size: 16px;
        margin-bottom: 2em;
        padding-left: 20px;
    }

    .page-template-page-csus .about_box .type-sub .image_box{
        width: 100%;
        order: 2;
    }

    .page-template-page-csus .about_box .type-sub .textArea{
        width: 100%;
        margin-bottom: 30px;
    }

    .under_mv .mv_text {
        width: 94%;
    }

    .list_page_text_area {
        margin-bottom: 0;
        margin-top: 20px;
    }
    
    .list_page_text_area .list_page_text_area_ttl {
        font-size: 16px;
    }
    
    .list_page_text_area .inner {
        padding: 25px 20px;
        margin-left: 20px;
    }
    
    .list_page_text_area .inner .text {
        font-size: 12px;
    }

    /* カラーステンレスとは箇所ここまで */
}
