@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto+Condensed:wght@100..900&display=swap');

/*
Theme Name: housen-ss
Description: housen-ss
Version: 1.0
*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
}

article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, main {
	display: block;
}

ol, ul {
    list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

/* -------------------------------- 

Primary style

-------------------------------- */

html * {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

*, *:after, *:before {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

body {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 100%;
    color: #000;
    background-color: #fff;
    line-height: 1.6;
    -webkit-text-size-adjust: none;
}

body, html {
  /* important */
    height: 100%;
}

a {
    color: #009e96;
    text-decoration: none;
}

a:hover {
    color: #898989;
    transition: color 0.2s ease-out;
}

a:hover img {
	opacity: 0.6;
    transition: opacity 0.2s ease-out;
}

/* -------------------------------- 

Modules

-------------------------------- */

.container {
    width: 100%;
    max-width: 1240px;
    margin: 0 auto;
    clear: both;
    position: relative;
    z-index: 100;
}

.sp {
    display: none;
}

.sp_page {
    display: none;
}

@media only screen and (max-width:1140px) {

.pc {
    display: none;
}
.sp {
    display: block;
}
.pc_page {
    display: none;
}
.sp_page {
    display: inline-block;
}

}

@media only screen and (max-width:768px) {}

/* -------------------------------- 

post

-------------------------------- */

p {
    font-size: 16px;
    font-weight: normal;
    line-height: 1.88;
    padding: 0 0 1em;
    text-align: justify;
    color: #000;
}

.alignleft {
    float:left;
    padding:0 15px 15px 10px;
}

.alignright {
    float:right;
    padding: 0 10px 15px 15px;
}

.aligncenter {
    padding: 20px 0 20px 0;
    text-align: center;
    display: block;
    margin: 0 auto;
}

/* -------------------------------- 

header

-------------------------------- */

header {
    background: #fff;
    width: 100%;
    height: 110px;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 1000;
    box-shadow: 0 2px 4px #00000024;
}

header .container {
    max-width: none;
    padding: 0 40px;
}

header #logo {
    float: left;
    position: relative;
    top: 27px;
    left: 10px;
}

header #logo a {
    display: block;
    width: 429px;
    height: 56px;
    background: url(images/logo.png) no-repeat 0;
    text-indent: -9999px;
}

header #logo a:hover img {
	opacity: 1;
}

.site-header {
    transition: 0.5s;
}

.site-header.hide {
    transform: translateY(-100%);
}

@media only screen and (max-width:1380px) {

header {
    background: #fff;
    height: 60px;
	border-bottom: 1px solid #d3cbc6;
}

header #logo {
    top: 16px;
    left: 17px;
}

header #logo a {
    width: 260px;
    height: 30px;
    background-size: 100%;
}

}

/* -------------------------------- 

nav pc

-------------------------------- */

nav#gnav {
    float: right;
    position: relative;
    right: 30px;
}

nav#gnav ul {
    display: flex;
    flex-wrap: wrap;
}

nav#gnav ul li {
    padding: 42px 0 0 30px;
}

nav#gnav ul li a {
    font-size: 16px;
    font-weight: bold;
    color: #000;
}

nav#gnav ul li a:hover {
    color: #898989;
}

nav#gnav ul li.btn_contact {
    margin: 0;
}

nav#gnav ul li.btn_contact a {
    display: block;
    width: 160px;
    height: 48px;
    background-color: #009e96;
    border: 1px solid #009e96;
    color: #fff;
    text-align: center;
    position: relative;
    padding: 10px 0 0;
    top: -11px;
	transition: all 0.2s ease-out;
	border-radius: 0;
}

nav#gnav ul li.btn_contact a:hover {
    background-color: #fff;
	color: #009e96;
	transition: all 0.2s ease-out;
}

@media only screen and (max-width:1380px) {

nav#gnav ul li {
    padding: 34px 0 0 30px;
}

}

/* -------------------------------- 

nav sp

-------------------------------- */

h1.logo_sp {
    width: 260px;
    position: relative;
    top: 8px;
    left: 17px;
    z-index: 1000;
}

h1.logo_sp img {
    width: 260px;
    height: auto;
}

#toggle {
    position: fixed;
    top: 18px;
    right: 23px;
    transition: all 0.8s ease-out;
}

#toggle-box {
    position: relative;
    width: 30px;
    height: 26px;
    cursor: pointer;
}

#toggle-box > span {
    width: 100%;
    height: 2px;
    left: 0;
    display: block;
    background: #000;
    position: absolute;
    transition: transform .6s ease-in-out, top .5s ease, bottom .5s ease;
}

#toggle-box > span:nth-child(1) {
    top: 0;
}

#toggle-box > span:nth-child(2) {
    top: 50%;
    transform: translatey(-50%);
}

#toggle-box > span:nth-child(3) {
    bottom: 0;
}

.is-open #toggle-box > span {
    background: #000;
}

.is-open #toggle-box > span:nth-child(1) {
    top: 50%;
    transform: rotate(45deg) translatey(-50%);
}

.is-open #toggle-box > span:nth-child(2) {
    width: 0;
}

.is-open #toggle-box > span:nth-child(3) {
    top: 50%;
    transform: rotate(-45deg) translatey(-50%);
}

#toggle {
    z-index: 1000;
}

#main {
    position: relative;  
    z-index: 990;
}

#nav-content {
    overflow: auto;
    width: 100%;
    height: 0;
    background: #fff;
    color: #000;
    position: fixed;
    top: 0;
    left: 0;
    text-align: center;
    opacity: 0;
    transition: opacity .6s ease, visibility .6s ease;
}

#nav-content ul {
    list-style: none;
}

#nav-content ul li {
	background-color: #fff;
}

#nav-content ul li.link_x {
    padding: 18px 0 0;
}

#nav-content ul li:nth-child(odd) {
	background-color: #f5f3f2;
}

#nav-content a {
    display: block;
    color: #000;
    text-decoration: none;
    padding: 12px 0;
    transition: opacity .6s ease;
    pointer-events: none;
    font-weight: bold;
    font-size: 17px;
}

#nav-content a:hover {
    opacity: 0.6;
}

.is-open {
    overflow: hidden;
}

.is-open #nav-content {
    z-index: 999;
    visibility: visible;
    opacity: 1;
    height: 100%;
}

.is-open #nav-content a {
    pointer-events: auto;
    margin: 0 auto;
}

#nav-content ul li.btn_contact a {
    display: block;
    width: 147px;
    height: 46px;
    background-color: #3c9fd5;
    color: #fff;
    text-align: center;
    line-height: 46px;
    position: relative;
    top: 14px;
    padding: 0;
}

.nav_core {
    position: relative;
    top: 77px;
}

@media only screen and (max-width:1380px) {

header .container {
    max-width: none;
    padding: 0;
    margin: 0;
}
header nav {
    position: relative;
    top: -18px;
    right: inherit;
	transition: all 0.8s ease-out;
	border-top: 1px solid #d3cbc6;
}

}

/* -------------------------------- 
header sp transform
-------------------------------- */

@media only screen and (max-width:1380px) {

header.bg_header.transform nav {
    top: 105px;
    transition: all 0.8s ease-out;
}
header.bg_header.transform #toggle {
    top: 21px;
	transition: all 0.8s ease-out;
}

}

/* -------------------------------- 
bottom_link
-------------------------------- */

#bottom_link {
    position: fixed;
    bottom: 0;
    z-index: 1000;
    width: 100%;
    height: 60px;
    background-color: #000000b3;
    padding: 10px 22px;
}

#bottom_link .tel_call {}

#bottom_link .mail {}

#bottom_link a {
    display: flex;
    justify-content: center;
    align-items: anchor-center;
    width: calc(50% - 5px);
    height: 40px;
    color: #fff;
    border-radius: 6px;
    font-size: 15px;
    font-weight: bold;
}

#bottom_link .tel_call a {
    background-color: #e2803a;
    float: left;
    margin: 0 5px 0 0;
}

#bottom_link .mail a {
    background-color: #009e96;
    float: left;
	margin: 0 0 0 5px;
}

#bottom_link a img {
    padding: 0 10px 0 0;
}

/* -------------------------------- 

mainimg

-------------------------------- */

main {
    width: 100%;
    height: 100vh;
}

#slider {
    width: 100%;
    height: 100vh;
    padding-top: 110px;
}

.box_mainimg {
    width: 100%;
    position: relative;
    z-index: 50;
    top: 50%;
    margin-top: -95px;
    text-align: center;
}

.box_mainimg h1.main_title {
    color: #fefeff;
    font-size: clamp(36px, calc(36px + (80 - 36) * ((100vw - 375px) / (1140 - 375))), 80px);
    font-weight: bold;
    line-height: 1.13;
    padding: 0 0 23px;
    margin: 0 auto;
    text-indent: 25px;
}

.box_mainimg h2.sub_title {
    color: #fefeff;
	font-size: clamp(16px, calc(16px + (24 - 16) * ((100vw - 375px) / (1140 - 375))), 24px);
    font-weight: 500;
	line-height: 1.42;
    padding: 0 26px;
}

.br_sp {
    display: none;
}

@media only screen and (max-width:1140px) {}

@media only screen and (max-width:768px) {

.br_sp {
    display: block;
}

}

/* -------------------------------- 

top

-------------------------------- */

#top {
    background-color: #fff;
}

#top h2 {
    font-size: 44px;
	font-size: clamp(36px, calc(36px + (44 - 36) * ((100vw - 375px) / (1140 - 375))), 44px);
    font-weight: bold;
    text-align: center;
    color: #009e96;
    padding: 0 0 22px;
}

#top h3 {
    font-size: 26px;
    font-weight: bold;
    text-align: center;
    color: #009e96;
    padding: 0 0 17px;
}

/* -------------------------------- 

top_our_strengths

-------------------------------- */

#top_our_strengths {
    background-color: #e0f1f4;
    padding: 90px 23px 110px;
}

#top_our_strengths .container {
    max-width: 802px;
}

#top_our_strengths h2 {
	font-size: clamp(36px, calc(36px + (44 - 36) * ((100vw - 375px) / (1140 - 375))), 44px);
    font-weight: bold;
    text-align: center;
    color: #009e96;
    padding: 0 0 22px;
}

#top_our_strengths h3 {
    font-size: 26px;
    font-weight: bold;
    text-align: center;
    color: #009e96;
    padding: 0 0 17px;
}

#top_our_strengths p {
    font-size: 18px;
    text-align: center;
    line-height: 1.56;
    color: #000;
    margin: 0 0 40px;
}

.link_btn {
    width: 240px;
    height: 48px;
    margin: 0 auto;
}

.link_btn a {
    display: block;
    width: 240px;
    height: 48px;
    padding: 10px 0 0 20px;
    background-color: #009e96;
	border: 1px solid #009e96; 
    color: #fff;
    font-size: 16px;
    font-weight: 500;
    text-align: center;
	transition: all 0.2s ease-out;
}

.link_btn a:hover {
    background-color: #fff;
	color: #009e96;
		transition: all 0.2s ease-out;
}

.link_btn a::after {
    content: "→";
    position: relative;
    display: block;
    float: right;
    right: 18px;
}

@media only screen and (max-width: 830px) {

#top_our_strengths {
    padding: 55px 23px 60px;
}
#top_our_strengths p {
    font-size: 16px;
    margin: 0 0 13px;
}

}

/* -------------------------------- 

top_info

-------------------------------- */

#top_info {
    background-color: #fff;
    padding: 90px 20px 110px;
}

#top_info .container {
    max-width: 800px;
}

.box_info {}

.box_info ul {
    border-top: 1px solid #000;
    margin: 0 0 60px;
}

.box_info ul li {
    display: flex;
    align-items: flex-start;
    border-bottom: 1px solid #000;
    padding: 17px 22px;
    color: #000;
}

.box_info ul li time {
    font-size: 14px;
    font-weight: normal;
	margin: 3px 0 0;
}

.box_info ul li span.cate_name {
    min-width: 130px;
    width: 130px;
    line-height: 24px;
    border-radius: 12px;
    text-align: center;
    font-size: 14px;
    color: #fff;
    background-color: #000;
    margin: 4px 20px 0;
}

span.cate_name.news {background-color: #25abc3 !important;}
span.cate_name.media {background-color: #c3af25 !important;}
span.cate_name.exhibitor {background-color: #e6955a !important;}

#top h2.info_title, #page h2.info_title {
    max-width: 486px;
    width: 100%;
    font-size: 16px;
    font-weight: bold;
    padding: 0 20px 0 0;
    margin: 2px 0 0;
    color: #000;
    text-align: left;
}

.box_info ul li a.btn_info {
    background-color: #009e96;
    color: #fff;
    font-size: 18px;
    min-width: 30px;
    width: 30px;
    height: 30px;
    border-radius: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: auto;
    margin-bottom: auto;
    flex: 0 0 30px;
}

.box_info ul li a:hover.btn_info {
    background-color: #5ebcb8;
	transition: background-color 0.2s ease-out;
}

@media only screen and (max-width: 830px) {

#top_info {
    padding: 42px 20px 62px;
}
.box_info ul {
    margin: 0 0 30px;
}
.box_info ul li {
    display: block;
}
.box_info ul li time {
    float: left;
}
.box_info ul li span.cate_name {
    display: block;
	float: left;
}
#top h2.info_title, #page h2.info_title {
    display: block;
    padding: 16px 20px 0 0;
    clear: both;
	max-width: fit-content;
}
.box_info ul li a.btn_info {
    position: absolute;
    right: 5px;
    top: 50%;
	margin-top: 7.5px;
}

}

/* -------------------------------- 

top_link

-------------------------------- */

#top_link {
    background-color: #fff;
    padding: 0 0 110px;
}

.box_link_all {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
}

.box_link {
    overflow: hidden;
    max-width: 390px;
    max-height: 390px;
}

.box_link a {}

.box_link figure {
    position: relative;
	overflow: hidden;
}

.box_link figure img {
    max-width: 390px;
    width: 100%;
    height: auto;
	transition: transform 0.4s ease;
}

.box_link figure figcaption {
    position: absolute;
    bottom: 22px;
    font-size: 20px;
    font-weight: bold;
    color: #fff;
    width: 100%;
    padding: 0 24px;
}

.box_link figure figcaption::after {
    content: "→";
    position: absolute;
    background-color: #009e96;
    color: #fff;
    font-size: 18px;
    width: 30px;
    height: 30px;
    border-radius: 15px;
    text-align: center;
    right: 24px;
	transition: background-color 0.3s ease;
}

.box_link a:hover figure img {
    transform: scale(1.08);
	opacity: 1;
}

.box_link a:hover figure figcaption::after {
    background-color: #5ebcb8;
}

@media only screen and (max-width:1240px) {

.box_link {
    margin: 0 15px;
}

}

@media only screen and (max-width:830px) {

#top_link {
    padding: 0 23px 20px;
}

}

@media only screen and (max-width:768px) {

.box_link {
    margin: 0 0 40px;
    height: 240px;
}
.box_link_all {
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
}
.box_link figure {
    height: 240px;
}

}

/* -------------------------------- 

top_processing

-------------------------------- */

#top_processing {
    background-color: #009e96;
    padding: 90px 0 110px;
}

#top_processing h2 {
    color: #fff;
}

.img_processing {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 10px 0 56px;
}

.img_processing figure {
    max-width: 280px;
    width: 100%;
    max-height: 280px;
    height: auto;
    overflow: hidden;
}

.img_processing img {
    max-width: 280px;
    width: 100%;
    height: auto;
	transition: all 0.2s ease-out;
}

.img_processing a:hover img {
    transform: scale(1.08);
	opacity: 1;
	transition: all 0.2s ease-out;
}

#top_processing .link_btn a {
    background-color: #fff;
    border: 1px solid #fff;
    color: #009e96;
	transition: all 0.2s ease-out;
}

#top_processing .link_btn a:hover {
    background-color: #009e96;
	color: #fff;
	transition: all 0.2s ease-out;
}

@media only screen and (max-width:1240px) {

#top_processing {
    padding: 55px 23px 60px;
}
.img_processing {
    margin: 0 auto 10px;
    justify-content: center;
    max-width: 610px;
}
.img_processing figure {
    width: 50%;
    text-align: center;
    padding: 0 3.5% 4%;
}

}

/* -------------------------------- 

top_contact

-------------------------------- */

#top_contact {
    background-color: #fff;
    padding: 90px 0 110px;
}

#top_contact .container {
    max-width: 900px;
}

#top_contact h2 {
    padding: 0 0 16px;
}

#top_contact p.catch {
    text-align: center;
}

.box_contact {
    max-width: 800px;
    width: 100%;
    margin: 40px 0 0;
    overflow: hidden;
    position: relative;
    left: 50%;
    transform: translate(-50%, 0);
}

.box_contact p {
    text-align: center;
    color: #000;
    font-size: 16px;
    font-weight: 500;
}

.box_contact_l {
    width: 400px;
    float: left;
    border-right: 1px solid #000;
    padding: 0 55px 0 0;
}

#top_contact .box_contact_l p {
    padding: 0 0 2px 0;
}

.tel {
    font-family: 'Roboto Condensed', sans-serif;
    font-size: 50px;
	font-size: clamp(45px, calc(45px + (50 - 45) * ((100vw - 375px) / (1140 - 375))), 50px);
    font-weight: bold;
    color: #000;
    text-align: center;
    line-height: 1.2;
    margin: 10px 0 0;
}

.tel span {
    font-size: 30px;
}

.box_contact_r {
    width: 338px;
    float: left;
    margin: 0 0 0 59px;
}

.btn_contact {
    margin: 6px 0 0;
}

.btn_contact a {
    display: block;
    font-size: 20px;
    font-weight: 500;
    text-align: center;
    border: 1px solid #000;
    border-radius: 24px;
    max-width: 338px;
    width: 100%;
    height: 48px;
    padding: 6px 0 0 0;
    color: #000;
    margin: 0 auto;
}

.btn_contact a:hover {
    border: solid 1px #009e96;
	color: #009e96;
	transition: all 0.2s ease-out;
}

@media only screen and (max-width:768px) {

#top_contact {
    padding: 39px 23px 60px;
}
#top_contact p.catch {
    line-height: 1.4;
}
.box_contact {
    margin: 17px 0 0;
}
.box_contact_l {
    width: auto;
    float: unset;
    border-right: none;
    padding: 0;
}
.box_contact_r {
    width: auto;
    float: unset;
    margin: 16px 0 0;
}
.btn_contact {
    margin: 0;
}
.btn_contact a {
    margin: 0 auto;
}

}

/* -------------------------------- 

top_gmap

-------------------------------- */

#top_gmap {
    background-color: #fff;
}

#top_gmap .gmap {}

@media only screen and (max-width:1240px) {}

@media only screen and (max-width:830px) {}

@media only screen and (max-width:768px) {}

/* -------------------------------- 

footer

-------------------------------- */

footer {
    background-color: #fff;
    padding: 95px 23px 0;
}

.box_footer {
    display: flex;
    flex-wrap: wrap;
    margin: 0 0 145px;
}

.box_footer_l {
    margin: 0 190px 0 0;
}

.box_footer_l .footer_logo {
    margin: 0 0 13px;
}

.box_footer_l .footer_logo img {
    max-width: 429px;
    width: 100%;
    height: auto;
}

.box_footer_l .footer_add {
    font-size: 16px;
    line-height: 1.88;
    color: #3e3a39;
}

.box_footer_r {
    display: flex;
    flex-wrap: wrap;
}

.box_footer_r ul {
    margin: 0 69px 0 0;
}

.box_footer_r ul li {
    padding: 0 0 1px 15px;
}

.box_footer_r ul li::before {
    content: "●";
    position: absolute;
    font-size: 8px;
    color: #28ac72;
    padding: 10px 0 0;
    margin: 0 0 0 -15px;
}

.box_footer_r ul li a {
    font-size: 16px;
    font-weight: normal;
    color: #3e3a39;
    line-height: 1.88;
}

.box_footer_r ul li.link_x {
    padding: 15px 0 0 0;
}

.box_footer_r ul li.link_x::before {
    content: "";
}

.box_footer_r ul li.link_x a {}

.box_footer_r ul li a:hover {
    color: #9b8f88;
    transition: color 0.2s ease-out;
}

.copy {
    font-size: 14px;
    text-align: right;
    color: #3e3a39;
    padding: 22px 0 25px;
    border-top: 1px solid #000;
}

@media only screen and (max-width:1240px) {

footer {
    padding: 50px 23px 0;
}
#footer_banner {
    padding: 50px 5px 20px;
}
.box_banner {
    justify-content: space-evenly;
	flex-direction: column;
	align-items: center;
}
.banner_img {
	margin: 0 0 30px;
}
.box_footer_l {
	margin: 0 108px 35px 0;
}

}

@media only screen and (max-width: 1140px) {
    footer {
        padding: 50px 23px 60px;
    }
	.copy {
        text-align: center;
	}
}

@media only screen and (max-width:650px) {

.box_footer {
    margin: 0 0 60px;
}
.box_footer_l {
    margin: 0 0 35px;
}

}

@media only screen and (max-width:500px) {

.banner_img {
    max-width: 330px;
}
.box_banner {
	flex-direction: column;
}
.box_footer_r ul {
    margin: 0 25px 0 0;
}
.box_footer_r ul:last-child {
    margin: 0;
}

}

/* -------------------------------- 

page

-------------------------------- */

#page {
    padding: 110px 0 0;
}

#page h2 {
	font-size: clamp(25px, calc(25px + (36 - 25) * ((100vw - 375px) / (1140 - 375))), 36px);
    font-weight: bold;
    text-align: center;
	color: #009e96;
    padding: 0 0 35px;
}

#page h3 {
	font-size: clamp(22px, calc(22px + (32 - 22) * ((100vw - 375px) / (1140 - 375))), 32px);
    text-align: left;
    color: #000;
    padding: 0 0 22px 9px;
}

#page h3::before {
    content: "";
    position: relative;
    display: inline-block;
    width: 6px;
	height: clamp(21px, calc(21px + (30 - 21) * ((100vw - 375px) / (1140 - 375))), 30px);
    background-color: #009e96;
	top: 3px;
	left: -9px;
}

#page h4 {
    font-size: 20px;
    font-weight: 500;
    text-align: left;
    padding: 0 0 16px;
}

.title_bg {
    width: 100%;
    height: 250px;
    background: url(images/title_bg.jpg) no-repeat 50%;
	background-size: cover;
    margin: 0 0 75px;
}

#page h2.page_title {
	font-size: clamp(30px, calc(30px + (44 - 30) * ((100vw - 375px) / (1140 - 375))), 44px);
    font-weight: bold;
    color: #fefeff;
    text-align: center;
    padding: 73px 0 0;
    margin: 0;
}

#page h2.page_title span.sub_page_title {
    display: block;
	font-size: clamp(16px, calc(16px + (20 - 16) * ((100vw - 375px) / (1140 - 375))), 20px);
    font-weight: bold;
}

.bg_white {background-color: #fff;}
.bg_green {background-color: #e0f1f4;}


@media only screen and (max-width:1380px) {

#page {
    padding: 60px 0 0;
}

}

@media only screen and (max-width:1140px) {

.title_bg {
    height: auto;
    margin: 0 0 50px;
}
#page h2.page_title {
    padding: 33px 0 33px;
}

}

/* -------------------------------- 

our_strengths

-------------------------------- */

#our_strengths {}

.our_strengths_1 {
    padding: 0 23px 90px;
}

.our_strengths_1 ul {
    max-width: 800px;
	width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 auto;
}

.our_strengths_1 ul li {
    width: 250px;
    height: 80px;
    font-size: 20px;
    font-weight: bold;
    text-align: center;
    color: #fff;
    line-height: 1.2;
    background: url(images/bg_our_strengths_1.png) no-repeat 50%;
    margin: 0 0 24px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.our_strengths_2 {
    padding: 85px 23px 90px;
}

.our_strengths_2 .container {
    max-width: 1000px;
}

.col_strengths {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    flex-direction: row;
    margin: 0 0 60px;
}

.col_strengths.row-reverse {
    flex-direction: row-reverse;
}

.col_strengths.last {
    margin: 0;
}

.col_txt {
    max-width: 470px;
    padding: 56px 0 0;
}

.col_txt p {
    font-size: 16px;
    font-weight: normal;
    line-height: 1.5;
}

.col_img {
    max-width: 480px;
}

.col_img img  {
    max-width: 480px;
	width: 100%;
	height: auto;
}

@media only screen and (max-width:768px) {

.our_strengths_1 ul{
	max-width: 524px;
}
.our_strengths_2 {
    padding: 50px 23px 56px;
}
.col_txt {
    max-width: 100%;
    padding: 0;
}
.col_strengths {
    margin: 0 0 30px;
}
.col_strengths.row-reverse {
    flex-direction: row;
}

}

@media only screen and (max-width:556px) {

.our_strengths_1 {
    padding: 0 23px 56px;
}
.our_strengths_1 ul{
	max-width: 342px;
}
.our_strengths_1 ul li {
    max-width: 157px;
    width: 46%;
    height: auto;
    font-size: 14px;
    padding: 8px 0;
    border-radius: 6px;
    background-size: 100%;
    margin: 2% 2%;
	font-weight: 500;
}

}

/* -------------------------------- 

business

-------------------------------- */

#business {
    border-bottom: 1px solid #d3cbc6;
}

.business_1 {
    padding: 0 0 30px;
}

.business_1 .container {
    max-width: 800px;
}

#page .business_1 h2 {
    padding: 0 0 45px;
}

.cont_business {
    margin: 0 0 60px;
}

table {
    width: 100%;
    border-top: 3px solid #009e96;
    border-bottom: 3px solid #009e96;
}

table tr {
    border-bottom: 1px solid #009e96;
}

table th {
    width: 20%;
    background-color: #e0f1f4;
    font-size: 16px;
    font-weight: bold;
    color: #009e96;
    padding: 9px 0;
	border-right: 1px solid #009e96;
	vertical-align: middle;
}

table td {
    font-size: 18px;
    color: #000;
    padding: 9px 10px;
    vertical-align: middle;
}

table td.bold {
    font-weight: bold;
}

ul.service_list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-width: 590px;
    margin: 20px auto -6px;
}

ul.service_list li {
    width: 140px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 1px solid #009e96;
    font-size: 16px;
    font-weight: bold;
    color: #009e96;
    margin: 0 0 10px;
}

.col_business {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    flex-direction: row;
    margin: 0 0 60px;
}

.col_business .col_txt {
    max-width: 270px;
    padding: 0;
}

.col_business .col_txt .font18_b {
    display: block;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.67;
	padding: 6px 0 0;
}

@media only screen and (max-width:1240px) {

.business_1 {
    padding: 0 23px 30px;
}

}

@media only screen and (max-width:768px) {

table th {
    width: 33%;
}
table td {
    font-size: 16px;
	padding: 9px 7px;
}

}

@media only screen and (max-width:488px) {

ul.service_list {
    max-width: 289px;
}

}

/* -------------------------------- 

technology

-------------------------------- */

#technology {
    border-bottom: 1px solid #d3cbc6;
}

.technology_1 {
    padding: 0 23px 30px;
}

#page #technology .technology_1 h2 {
    padding: 0 0 63px;
}

.technology_1 .container {
    max-width: 1000px;
}

.col_technology {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    flex-direction: row;
    margin: 0 0 65px;
}

.col_technology .col_txt {
    max-width: 540px;
	width: 100%;
    padding: 0;
}

#page .col_technology .col_txt h3 {
    padding: 0 0 15px 9px;
}

.col_technology .col_txt p {
    padding: 0 0 8px;
}

.col_technology .col_txt ul {
    font-weight: bold;
    line-height: 1.88;
    margin: 0 0 6px;
}

.col_technology .col_txt ul li {
    list-style: disc;
    margin: 0 0 0 23px;
}

.col_technology .col_txt table {
    margin: 30px 0 0;
}

.col_technology .col_txt table th {
    padding: 9px 0;
    border-right: none;
    text-align: center;
}

.col_technology .col_txt table th:nth-child(1) {width: 50%;}
.col_technology .col_txt table th:nth-child(2) {
    width: 35%;
    border-left: 1px solid #009e96;
    border-right: 1px solid #009e96;
}
.col_technology .col_txt table th:nth-child(3) {width: 15%;}

.col_technology .col_txt table td {
    word-break: break-all;
}

.col_technology .col_txt table td:nth-child(2) {
    border-left: 1px solid #009e96;
    border-right: 1px solid #009e96;
	text-align: center;
}

.col_technology .col_txt table td:nth-child(3) {
	text-align: center;
}

.col_technology .col_img {
    max-width: 410px;
}

.col_technology .col_img img  {
    max-width: 410px;
	width: 100%;
	height: auto;
}

.technology_img {
    width: 100%;
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    margin: 50px 0 0;
}

.technology_img img {
    max-width: 300px;
	width: 100%;
	height: auto;
}

.col_technology .col_txt table.kensa th {
    width: 44%;
    text-align: left;
    padding: 0 26px;
}

.col_technology .col_txt table.kensa td {
    border-right: none;
}

.col_5050 {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.col_5050 .cont_technology {
    max-width: 470px;
    width: 100%;
    margin: 0 0 60px;
}

.col_img_2 {
    max-width: 470px;
	width: 100%;
	height: auto;
}

#page .col_5050 .cont_technology h3 {
    padding: 0 0 14px 9px;
}

.col_5050 .cont_technology p {
    padding: 0 0 24px;
}

@media only screen and (max-width:768px) {

#page #technology .technology_1 h2 {
    padding: 0 0 30px;
}
.col_technology {
    margin: 0 0 25px;
}
.col_technology .col_img {
    margin: 30px 0 0;
}
.col_technology .col_txt table th:nth-child(1) {
    width: unset;
}
.col_technology .col_txt table th:nth-child(2) {
    width: 47%;
}
.col_technology .col_txt table th:nth-child(3) {
    width: 13%;
}
.technology_img {
    margin: 14px 0 0;
}
.technology_img .img_2 {
	margin: 0 16px;
}
.col_technology .col_txt table.kensa th {
    padding: 0 15px;
}
.col_5050 .cont_technology {
    margin: 0 0 30px;
}

}

/* -------------------------------- 

processing_example

-------------------------------- */

#processing_example {
    border-bottom: 1px solid #d3cbc6;
}

#processing_example .container {
    max-width: 1000px;
}

.processing_1 {
    margin: 0 23px 20px;
}

#page #processing_example .processing_1 h2 {
    padding: 0 0 63px;
}

.box_processing {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
	margin: 0 0 7px;
}

.cont_processing {
    max-width: 470px;
    width: 100%;
    margin: 0 0 70px;
	scroll-margin-top: 110px;
}

.sub_img_processing {
    margin: 0 0 35px;
}

.sub_img_processing img {
    max-width: 470px;
    width: 100%;
}

table.processing th {
    width: 26%;
}

table.processing td {
    text-align: center;
}

@media only screen and (max-width:768px) {

#page #processing_example .processing_1 h2 {
    padding: 0 0 30px;
}
.box_processing {
    justify-content: center;
}
.sub_img_processing {
    margin: 0 0 26px;
}
.cont_processing {
    margin: 0 0 45px;
}
table.processing th {
    width: 31%;
    padding: 0 5px;
}

}

/* -------------------------------- 

company

-------------------------------- */

#company {
    border-bottom: 1px solid #d3cbc6;
}

.company_1 {
    padding: 0 23px 70px;
}

.company_rinen {
    text-align: center;
    margin: 0 0 95px;
}

.company_rinen img {
    max-width: 800px;
    width: 100%;
}

.company_catch {
	font-size: clamp(32px, calc(32px + (40 - 32) * ((100vw - 375px) / (1140 - 375))), 40px);
    font-weight: bold;
    text-align: center;
    color: #000;
    margin: 0 0 10px;
}

#page #company .company_1 h2 {
    padding: 0 0 6px;
}

.company_1 p {
    text-align: center;
}

.company_2 {
    padding: 90px 23px 68px;
}

.company_2 .container {
    max-width: 1000px;
}

.col_company {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

#page #company .col_company h3 {
    padding: 0 0 10px 9px;
    margin: -12px 0 0;
}

.col_company .col_txt {
    max-width: 640px;
    padding: 0;
}

.col_company .col_txt p {
    line-height: 1.88;
    text-align: justify;
    padding: 0 0 10px;
}

span.font26_b {
	font-size: clamp(20px, calc(20px + (26 - 20) * ((100vw - 375px) / (1140 - 375))), 26px);
    font-weight: bold;
    padding: 0 0 0 37px;
}

.col_company .col_txt p.right_txt_500 {
    font-size: 18px;
    font-weight: 500;
    text-align: right;
}

.col_company .col_img {
    max-width: 310px;
}

.company_3 {
    padding: 85px 23px 90px;
}

.company_3 .container {
    max-width: 1000px;
}

.company_3 table th {
    width: 14%;
    font-weight: 500;
    color: #000;
    vertical-align: top;
    text-align: left;
    letter-spacing: 0;
    padding: 9px 1em;
}

.company_3 table td {
    font-size: 16px;
}

.company_4 {
    padding: 85px 23px 75px;
}

.company_4 .container {
    max-width: 1000px;
}

.company_4 .col_company .col_txt {
    max-width: 540px;
    padding: 0;
}

.company_4 .col_company .col_img {
    max-width: 410px;
}

.pdf_link {
    position: relative;
}

.pdf_link a {
    display: flex;
    align-items: center;
    position: absolute;
    bottom: 16px;
    right: 0;
    font-size: 14px;
    font-weight: 500;
    color: #000;
}

.pdf_link a img {
    margin: 0 0 0 14px;
}

.company_5 {
    padding: 85px 23px 45px;
}

.company_5 .container {
    max-width: 1000px;
}

.company_5 .col_company .col_txt {
    max-width: 360px;
    padding: 0;
}

.company_5 .col_company .col_img {
    max-width: 600px;
}

.company_5 .col_company .col_img img {
    max-width: 600px;
    width: 100%;
    height: auto;
}

.company_5 .col_company .col_txt p {
    padding: 0 0 22px;
}

.route {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 67px 0 0;
}

.img_route img {
    margin: 0 0 44px;
}

.img_route img {
    max-width: 480px;
    width: 100%;
    height: auto;
}

@media only screen and (max-width:768px) {

.company_rinen {
    margin: 0 0 25px;
}
.company_1 {
    padding: 0 23px 25px;
}
span.font26_b {
    padding: 0;
}
.col_company .col_img {
    margin: 11px 0 0;
}
.company_2 {
    padding: 45px 23px 33px;
}
.company_3 {
    padding: 34px 23px 42px;
}
.company_3 table th {
    width: 30%;
}
.company_4 {
    padding: 43px 23px 35px;
}
.pdf_link {
    margin: 0 0 20px;
}
.pdf_link a {
    justify-content: end;
    position: relative;
    bottom: 0;
}
.company_5 {
    padding: 41px 23px 7px;
}
.route {
    margin: 24px 0 0;
}
.img_route img {
    margin: 0 0 24px;
}

}

/* -------------------------------- 

info

-------------------------------- */

#info {
    border-bottom: 1px solid #d3cbc6;
}

.info_1 {
    padding: 0 23px 70px;
}

.info_1 .container {
    max-width: 800px;
}

ul.info_cate {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 0 0 65px;
}

ul.info_cate li {}

ul.info_cate li a {
    font-size: 18px;
    font-weight: bold;
    color: #000;
    margin: 0;
	position: relative;
	transition: all 0.2s ease-out;
}

ul.info_cate li.active a,
ul.info_cate li a:hover {
    color: #009e96;
	transition: all 0.2s ease-out;
}

ul.info_cate li.active a::after,
ul.info_cate li a:hover::after {
    content: "";
    position: absolute;
	left: 0;
	bottom: -6px;
	width: 100%;
	height: 4px;
	background-color: #009e96;
	transition: all 0.2s ease-out;
}

.wp-pagenavi {
    text-align: center;
    padding: 23px 0 0;
}

.wp-pagenavi a, .wp-pagenavi span {
    padding: 3px 5px !important;
    color: #333;
}

.wp-pagenavi span.current {
    font-weight: normal !important;
    background-color: #009e96 !important;
    border-color: #009e96 !important;
    color: #fff !important;
}

.info_single {
    padding: 0 23px 120px;
}

.info_single .container {
    max-width: 1000px;
}

.info_post {
    background-color: #fff;
    padding: 100px 100px 80px;
    margin: 0 0 100px;
}

.info_post .cate_name {
    min-width: 130px;
    width: 130px;
    line-height: 24px;
    border-radius: 12px;
    text-align: center;
    font-size: 14px;
    color: #fff;
    background-color: #000;
    margin: 0 0 25px;
}

.info_post .cate_name.news {background-color: #25abc3 !important;}
.info_post .cate_name.media {background-color: #c3af25 !important;}
.info_post .cate_name.exhibitor {background-color: #e6955a !important;}

#page h3.info_title {
	font-size: clamp(20px, calc(20px + (26 - 20) * ((100vw - 375px) / (1140 - 375))), 26px);
    line-height: 1.4;
    padding: 0 0 11px;
}

#page h3.info_title::before {display: none;}

.info_content {
    margin: 33px 0 0;
}

.info_content ul {
    list-style: disc;
    margin: 0 0 0 23px;
}

.info_content ul li {
    margin: 0 0 1em;
}

.info_content img {
    max-width: 800px;
    width: 100%;
    height: auto;
}

.info_post time {
    font-size: 14px;
    font-weight: normal;
	margin: 3px 0 0;
}

.btn_back a {
    display: block;
    width: 240px;
    height: 48px;
    padding: 10px 0 0 0;
    background-color: #009e96;
    border: 1px solid #009e96;
    color: #fff;
    font-size: 16px;
    font-weight: 500;
    text-align: center;
    transition: all 0.2s ease-out;
    margin: 0 auto;
}

.btn_back a:hover {
    background-color: #fff;
	color: #009e96;
	transition: all 0.2s ease-out;
}

@media only screen and (max-width:768px) {

ul.info_cate {
    margin: 0 auto 21px;
    width: 310px;
}
ul.info_cate li {
    width: 50%;
    margin: 0 0 20px 0;
}
.info_single {
    padding: 0 23px 60px;
}
.info_post {
    padding: 40px 25px 30px;
    margin: 0 0 45px;
}







}

/* -------------------------------- 

recruit

-------------------------------- */

#recruit {
    border-bottom: 1px solid #d3cbc6;
}

.recruit_1 {
    padding: 0 23px 90px;
}

.recruit_1 .container {
    max-width: 640px;
}

.recruit_1_txt {
    margin: 10px 0 57px;
}

.recruit_1 table {
    max-width: 480px;
    margin: 0 auto;
}

.recruit_1 table tr {
	border-bottom: none;
}

.recruit_1 table tr:nth-child(1) {
	border-bottom: 1px solid #009e96;
}

.recruit_1 table th {
	border-right: none;
}
.recruit_1 table th:nth-child(2) {
	border-left: 1px solid #009e96;
	border-right: 1px solid #009e96;
}

.recruit_1 table td {
    text-align: center;
    padding: 2px 12px;
}

.recruit_1 table tr:nth-child(2) > td {
    padding: 10px 12px 0;
}

.recruit_1 table tr:nth-child(4) > td {
    padding: 0 12px 10px;
}

.recruit_1 table td a {
    font-size: 16px;
}

.recruit_2 {
    padding: 82px 23px 90px;
}

.recruit_2 .container {
    max-width: 1000px;
}

.miryoku {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.inn_miryoku {
    max-width: 300px;
    width: 100%;
}

.inn_miryoku figure {
    max-width: 300px;
}

.inn_miryoku figure img {
    max-width: 300px;
    width: 100%;
}

.inn_miryoku figcaption {
    font-size: 22px;
    font-weight: bold;
    text-align: center;
    line-height: 1.36;
    margin: 20px 0 22px;
}

.inn_miryoku p {
    line-height: 1.5;
    padding: 0;
}

.recruit_3 {
    padding: 85px 23px 25px;
}

.recruit_3 .container {
    max-width: 1000px;
}

#page .recruit_3 h3 {
    padding: 0 0 55px 9px;
}

.box_voice {
    position: relative;
    padding: 100px;
    margin: 0 0 60px;
}

.box_voice::before {
    content: "";
    position: absolute;
    width: 100px;
    height: 100px;
    background-color: #fff;
    border-top: 16px solid #e0f1f4;
    border-left: 16px solid #e0f1f4;
    top: 0;
    left: 0;
}

.box_voice::after {
    content: "";
    position: absolute;
    width: 100px;
    height: 100px;
    background-color: #fff;
    border-bottom: 16px solid #e0f1f4;
    border-right: 16px solid #e0f1f4;
    bottom: 0;
    right: 0;
}

.cont_voice {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 0 40px;
}

.cont_voice_txt {
    max-width: 68.8%;
    width: 100%;
}

.cont_voice_txt .affiliation {
	font-size: clamp(20px, calc(20px + (24 - 20) * ((100vw - 375px) / (1140 - 375))), 24px);
    font-weight: bold;
    color: #009e96;
    line-height: 1;
    padding: 0 0 24px;
}

.cont_voice_txt span.name {
    display: block;
	font-size: clamp(16px, calc(16px + (18 - 16) * ((100vw - 375px) / (1140 - 375))), 18px);
    color: #000;
    padding: 8px 0 0;
}

table.voice th {
    width: 23%;
    background-color: #fff;
    color: #000;
    font-weight: 500;
    text-align: left;
    padding: 7px 1em;
}

table.voice td {
    font-size: 16px;
    font-weight: 500;
    padding: 7px 23px;
}

.cont_voice_img {
    width: 200px;
}

.three_voice {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    border-bottom: 3px solid #009e96;
    padding: 0 0 26px;
}

.inn_voice {
    max-width: 240px;
    width: 100%;
}

.inn_voice .inn_voice_title {
    height: 36px;
    background-color: #009e96;
    font-size: 20px;
    font-weight: bold;
    text-align: center;
    line-height: 36px;
    color: #fff;
    margin: 0 0 16px;
}

.inn_voice p {
    font-weight: 500;
    line-height: 1.63;
}

.youkou {}

#page .youkou h3 {
    padding: 0 0 25px 9px;
}

.box_youkou .cate {
    font-size: 24px;
    font-weight: bold;
    color: #009e96;
    padding: 0 0 19px;
}

.box_youkou table {
    margin: 0 0 70px;
}

.box_youkou table th {
    width: 18%;
    color: #000;
    font-size: 16px;
    font-weight: 500;
    text-align: left;
    padding: 8px 0 8px 1em;
    vertical-align: top;
}

.box_youkou table td {
    font-size: 16px;
    font-weight: 500;
    text-align: left;
    padding: 8px 0 8px 1em;
    vertical-align: top;
}

@media only screen and (max-width:962px) {

.miryoku {
    justify-content: space-evenly;
}
.inn_miryoku {
    margin: 0 0 40px;
}

}

@media only screen and (max-width:768px) {

.recruit_1 {
    padding: 0 23px 60px;
}
.recruit_1_txt {
    margin: -8px 0 17px;
}
.recruit_1 table {
    margin: -14px auto 0;
}
.recruit_1 table th:nth-child(1) {width: 25%;}
.recruit_1 table th:nth-child(2) {width: 30%;}
.recruit_1 table th:nth-child(3) {width: 45%;}
.recruit_2 {
    padding: 50px 23px 16px;
}
.recruit_3 {
    padding: 56px 23px 0;
}
.box_voice {
    margin: 0 0 33px;
	padding: 0;
}
.box_voice::before {display: none;}
.box_voice::after {display: none;}
#page .recruit_3 h3 {
    padding: 0 0 30px 9px;
}
.box_youkou table th {
    width: 144px;
}
table.voice th {
    width: 30%;
}

}

@media only screen and (max-width:767px) {

.cont_voice_txt {
    max-width: unset;
    margin: 0 0 33px;
}
.cont_voice_img {
    margin: 0 auto;
}
.cont_voice {
    margin: 0 0 24px;
}
.inn_voice {
    max-width: unset;
    margin: 0 0 13px;
}
.three_voice {
    padding: 0 0 5px;
}

}

/* -------------------------------- 

faq

-------------------------------- */

#faq {
    border-bottom: 1px solid #d3cbc6;
}

.faq_1 {
    padding: 0 23px 90px;
}

.faq_1 .container {
    max-width: 800px;
}

.box_faq {
    border-top: 1px solid #898989;
    border-bottom: 1px solid #898989;
    padding: 30px 20px;
    margin: 0 0 -1px;
}

.box_faq_q {
    display: flex;
    align-items: center;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.56;
    color: #000;
    padding: 0;
}

.box_faq_a {
    display: flex;
    align-items: baseline;
}

.box_faq_q .faq_icon {
    font-size: 32px;
    font-weight: bold;
    color: #009e96;
    padding: 0 15px 0 0;
}

.box_faq_a .faq_icon {
    font-size: 32px;
    font-weight: bold;
    color: #000;
    padding: 0 19px 0 38px;
}

.box_faq_a .faq_a_txt {
    font-size: 16px;
    line-height: 1.75;
    text-align: justify;
    color: #000;
}

@media only screen and (max-width:768px) {

.faq_1 {
    padding: 0 23px 60px;
}
.box_faq {
    padding: 24px 10px;
}

}

/* -------------------------------- 

contact

-------------------------------- */

#contact {
    border-bottom: 1px solid #d3cbc6;
}

.contact_1 {
    padding: 0 23px 55px;
}

.contact_1 .container,
.contact_2 .container,
.contact_3 .container {
    max-width: 1000px;
}

#page .contact_1 h2 {
    line-height: 1.3;
    padding: 0 0 56px;
}

.contact_1_txt p {
    text-align: center;
}

.box_tel {
    margin: 18px 0 0;
}

.box_tel p {
    text-align: center;
    padding: 0;
}

.contact_2 {
    padding: 0 23px 46px;
}

.box_step {
    margin: 0 0 37px;
}

#page .box_step h3 {
    padding: 0 0 15px 9px;
}

.box_step p {
    line-height: 1.5;
}

.box_step img {
    max-width: 1000px;
    width: 100%;
    height: auto;
    margin: 16px 0 15px;
}

.contact_3 {
    padding: 0 23px 43px;
}

.contact_form {
    margin: 33px 0 70px;
}

.box_form {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    margin: 0 0 16px;
}

.box_form_l {
    max-width: 20%;
    width: 100%;
    padding: 3px 0 0;
}

.box_form_r {
    max-width: 80%;
    width: 100%;
}

img.pc_step {display: block;}
img.sp_step {display: none;}

.kubun {
    display: block;
    padding: 3px 0 0;
    font-weight: bold;
}

.wpcf7-list-item {
    margin: 0 1em 0 0 !important;
}

.file_txt {
    display: block;
    padding: 15px 0 0;
    line-height: 1.7;
}

.pp_link p {}

.pp_link a {
    color: #000;
    text-decoration: underline;
    text-underline-offset: 4px;
}

.pp_link a:hover {
    color: #898989;
	text-decoration: none;
    transition: all 0.2s ease-out;
}

.wpcf7-not-valid-tip {
    font-size: 93% !important;
    color: #fff !important;
    display: block !important;
    border: 2px solid #009e96;
    background: #009e96;
    border-radius: 4px;
    padding: 0 10px;
    margin: 12px 0 0;
    width: fit-content;
    position: relative;
    font-weight: 500;
}

.wpcf7-not-valid-tip::before {
    content: "";
    position: absolute;
    top: -21px;
    left: 50%;
    margin-left: -10px;
    border: 10px solid transparent;
    border-bottom: 10px solid #009e96;
}

.btn_form {}

input[type="text"], input[type="email"], input[type="tel"], select, textarea {
    vertical-align: middle;
    width: 100%;
    line-height: 1.5;
    height: 40px;
    padding: 5px 10px;
    border: 1px solid #c8c8c8;
    font-size: 16px;
    color: #000;
    background: #fff;
    border-radius: 0;
}

textarea {
    width: 100%;
    height: 150px;
    margin: 0;
}

input[type="submit" i] {
    display: block;
    width: 240px;
    height: 48px;
    padding: 0;
    background-color: #009e96;
    color: #fff;
	border: 1px solid #009e96;
    font-weight: 500;
    text-align: center;
    margin: 0 auto;
    border: none;
    font-size: 16px;
    cursor: pointer;
	transition: all 0.2s ease-out;
}

input[type="submit" i]:hover {
    background-color: #fff;
    color: #009e96;
	border: 1px solid #009e96;
	transition: all 0.2s ease-out;
}

input[type="submit" i]::after {
    content: "→";
    position: relative;
    display: block;
    float: right;
    right: 14px;
}

@media only screen and (max-width:768px) {

.contact_2 {
    padding: 0 23px 0;
}
.contact_3 #page h3 {
    padding: 0 0 0 9px;
}
.box_form {
    flex-direction: column;
    margin: 0;
}
.box_form_l {
    max-width: unset;
}
.box_form_l p {
	padding: 0 0 10px;
}
.box_form_r {
    max-width: unset;
}

img.pc_step {display: none;}
img.sp_step {display: block;}

}

/* -------------------------------- 

policy

-------------------------------- */

#policy {
    border-bottom: 1px solid #d3cbc6;
}

.policy_1 {
    padding: 0 23px 90px;
}

.policy_1 .container {
    max-width: 800px;
}

.cont_policy {
    border-top: 1px solid #898989;
    border-bottom: 1px solid #898989;
    padding: 60px 30px 40px;
}

.box_policy {
    margin: 40px 0 0;
}

.box_policy .policy_title {
    font-size: 18px;
    font-weight: bold;
    padding: 0 0 18px;
}

.box_policy p {}

@media only screen and (max-width:768px) {

.cont_policy {
    padding: 60px 0 22px;
}
.box_policy {
    margin: 13px 0 0;
}

}
