@charset "UTF-8";

html {
	overflow: visible;
}
body {
	width: 100vw;
	margin: 0;
	padding: 0;
	font-family: 'Noto Sans JP', "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	font-size: 3.5vw;
	font-weight: 400;
	line-height: 2;
	color: #2d2d2d;
	background: #fff;
/*	overflow-x: hidden;*/
	font-feature-settings: "palt" 1;
	letter-spacing: 0.025em;
}
main, section, footer {
	width: 100%;
	margin: 0;
	padding: 0;
	position: relative;
/*	overflow-x: hidden;*/
}
main {
/*	overflow-x: hidden;
	overflow-y: visible;*/
}
div {
	margin: 0;
	padding: 0;
}
a,a:link,a:hover,a:visited{
text-decoration:none;
}
ol,
ul {
	list-style: none;
	padding-inline-start: 0;
	margin: 0;
	margin-block-start: 0;
	margin-block-end: 0;
	margin-inline-start: 0;
	margin-inline-end: 0;
}
.section_inner {
	width: 90%;
	margin: 0 auto;
}
p {
	font-feature-settings: "palt" 1;
	text-align: justify;
	letter-spacing: 0.025em;
}


/*----------------------------------------------- 共通 */
.en {
	font-family: "Montserrat", sans-serif;
}

.small {
	font-size: 0.8em;
}

.btn,
.btn_grey {
	margin: 5vw auto 10vw;
}
.btn a {
	display: block;
	width: 80%;
	text-align: center;
	line-height: 3;
	font-size: 4vw;
	font-weight: 500;
	color: #fff;
	border-radius: 50px;
	background-color: #003ea2;
	box-shadow: 0 5px rgba(66,66,66,0.25);
	margin: auto;
}
a.btn_line {
	display: inline-block;
	padding: 1vw 4vw;
	border-radius: 50px;
	border: solid 1px #fff;
	color: #fff;
}
.btn_grey a {
	display: flex;
	justify-content: space-between;
	width: 80%;
	text-align: center;
	line-height: 3.5;
	font-size: 4vw;
	font-weight: 500;
	color: #001760;
	border-radius: 50px;
	background-color: #e5e5e5;
	margin: auto;
	padding: 0 7vw;
}
.btn_grey a i {
	color: #b8b8b8;
}

section {
	padding: 20vw 0;
}
h3 {
	display: flex;
	align-items: flex-end;
	font-size: 3vw;
	color: #003ea2;
	line-height: 1;
}
h3 > span:first-of-type {
	margin-bottom: 0.5em;
}
h3 .en {
	display: block;
	font-weight: 300;
	font-size: 7.5vw;
	margin-left: 3vw;
	color: #2d2d2d;
	line-height: 1;
}
h3.long {
	align-items: flex-start;
	flex-direction: column;
}
h3.long .en {
	margin: 0;
	margin-top: 0.25em;
	line-height: 1.25;
}
.strong {
	font-weight: 500;
	font-size: 1.05em;
}
.bnr_w {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
}
.bnr_w li {
	width: 46%;
	margin-bottom: 5vw;
}
.bnr_w li img {
	aspect-ratio: 1200 / 630;
	object-fit: cover;
}
.bnr_w li a {
	display: block;
	width: 100%;
	height: 100%;
}
.bnr_w li img {
	display: block;
	width: 100%;
}

a.btn_more {
	display: flex;
	justify-content: center;
	align-items: center;
	background-image: linear-gradient(45deg, rgba(240, 240, 240, 1), rgba(255, 255, 255, 1));
	padding: 0.65em 2em;
	border-radius: 50px;
	color: #2d2d2d;
	border: solid 1px #fff;
	width: 45vw;
	position: relative;
	box-shadow: 0px 6px 12px -4px rgba(0, 0, 0, 0.15);
}
a.btn_more::before {
	content: "⚫︎";
	width: 0.8em;
	height: 0.8em;
	font-size: 0.8em;
	line-height: 1;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 1.5em;
	margin: auto;
}

a.btn_more.grey {
	background-color: #f0f0f0;
}
a.btn_more.red {
	background-color: #dc3232;
	color: #fff
}
a.btn_more.red i,
a.btn_more.line i{
	color: #fff;
}
a.btn_more.line {
	background: none;
	border: solid 1px #fff;
	color: #fff;
}

.sec_img a {
	display: block;
	width: 100%;
	height: 100%;
}
.sec_img img{
	width: 100%;
}
.sec_img a img {
	filter: drop-shadow(0 3px 15px rgb(0 0 0 / 20%));
}

@keyframes infinity-scroll-left {
	from {
		transform: translateX(0);
	}
		to {
		transform: translateX(-100%);
	}
}
.scroll-infinity__wrap {
	display: flex;
	overflow: hidden;
}
.scroll-infinity__list {
	display: flex;
	list-style: none;
	padding: 0
}
.scroll-infinity__list--left {
	animation: infinity-scroll-left 100s infinite linear 0.5s both;
}


.photo img {
	width: 30vw;
	aspect-ratio: 3 / 2;
	object-fit: cover;
}
.sec_txt p {
	margin-bottom: 5vw;
}
.sec_txt figure {
	margin: 7vw auto;
}
.pg h3 {
	margin-bottom: 18vw;
}

/*下層ページ見出し*/
.top-ttl {
	display: flex;
	flex-direction: column;
	width: 90%;
	margin: auto;
	padding: 10vw 0 5vw;
	border-bottom: solid 1px;
}
.textanimation {
	font-size: 6vw;
	line-height: 1.25;
/*	font-weight: 500;*/
	letter-spacing: 0.25em;
}
.textanimation.en {
	font-size: 3vw;
	font-weight: 300;
	letter-spacing: 0em;
}
@keyframes showTextFromBottom {
	0%{
		transform: translateY( 100% );
	}
	100%{
		transform: translateY( 0px );
	}
}
.textanimation span{
	animation: showText 3s backwards;
	display: inline-block;
}
.textanimation > span{
	overflow: hidden;
}
.textanimation > span > span{
	animation: showTextFromBottom 0.7s backwards;
}


/*----------------------------------------------- parallax */
.parallax_bk {
	width: 100%;
	height: 50vw;
	overflow: hidden;
	pointer-events: none;
}
.parallax {
	width: 100vw;
	height: 50vw;
	background-size: cover;
	background: url("../img/poster.jpg") no-repeat;
}
.parallax video {
	width: 100vw;
	height: 50vw;
	object-fit: cover;
	object-position: bottom;
	pointer-events: none;
}
.parallax_bk {
	width: 100vw;
	height: 50vw;
}
.pg .parallax {
	width: 100vw;
	height: 50vw;
	background: none;
}
.pg .parallax img {
	width: 100vw;
	height: 50vw;
	object-fit: cover;
}
.philos .parallax,
.parallax_bk.philos,
.philos .parallax img {
	height: 30vw;
}
.philos .parallax img {
	object-position: 70%;
}
.csr_bk .parallax img {
	object-position: left;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  header
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
header {
	background-color: #f4f4ed;
	min-height: 4.5rem;
}
.header_inner {
	position: relative;
}
.hd_img img {
	width: 100vw;
	height: 60vw;
	object-fit: cover;
}
.hd_fix_area {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	position: fixed;
	height: 4.5rem;
	background-color: #f4f4ed;
	z-index: 100;
	padding-right: 5rem;
	right: 0;
	left: 0;
	top: 0;
	box-shadow: none;
	animation: scroll-anim linear;
	animation-timeline: scroll();
	-webkit-overflow-scrolling:auto;
}

@keyframes scroll-anim {
	0% {
		box-shadow: none;
	}
	5% {
		box-shadow: 0px 6px 12px -4px rgba(0, 0, 0, 0.15);
	}
	100% {
		box-shadow: 0px 6px 12px -4px rgba(0, 0, 0, 0.15);
	}
}


.hd_fix_area .logo img {
	width: 30vw;
	height: 4.5rem;
	object-fit: contain;
	object-position: center;
	margin-left: 1em;
}
.logo a {
	display: block;
	width: 100%;
	height: 100%;
}
.hd_fix_area .btn a {
	width: 43vw;
	font-size: 3vw;
}
.hd_fix_area .btn {
	margin: auto;
	margin-left: 4vw;
}
.hd_fix_area .btn img.cart {
	display: inline-block;
	width: 4.25vw;
	margin: auto;
	margin-right: 1.25vw;
	vertical-align: middle;
}
.hd_fix_area .btn img.arrow {
	display: inline-block;
	width: 1.25vw;
	margin: auto;
	margin-left: 1.25vw;
	padding-bottom: 0.5vw;
	vertical-align: middle;
}

/**** header ハンバーガー ****/
.nav_toggle {
	display: block;
	position: fixed;
	width: 1.5rem;
	height: 1.25rem;
	right: 1.75em;
/*	top: 1.75em;*/
	z-index: 99;
	-webkit-overflow-scrolling:auto;
}
.nav_toggle::after {
	content: '';
	display: block;
	width: 3rem;
	height: 3rem;
	border: solid 2px #2d2d2d;
	left: -0.725rem;
	position: absolute;
	z-index: -1;
	top: -0.85rem;
	border-radius: 50%;
}
.nav_toggle.active {
	display: block;
}
.nav_toggle i {
	display: block;
	width: 100%;
	height: 2px;
	background-color: #2d2d2d;
	position: absolute;
	transition: transform .5s, opacity .5s;
}
.nav_toggle i:nth-child(1) {
	top: 0;
}
.nav_toggle i:nth-child(2) {
	top: 0;
	bottom: 0;
	margin: auto;
}
.nav_toggle i:nth-child(3) {
	bottom: 0;
}
.nav_toggle.show i:nth-child(1) {
	transform: translateY(9px) rotate(-45deg);
	background-color: #fff;
}
.nav_toggle.show i:nth-child(2) {
	opacity: 0;
}
.nav_toggle.show i:nth-child(3) {
	transform: translateY(-9px) rotate(45deg);
	background-color: #fff;
}
.nav_toggle.show::after {
	border-color: #fff;
}
.nav {
	position: fixed;
	top: 0;
	right: 0;
	z-index: 1;
	width: 100vw;
	height: 100vh;
	padding: 4rem 3rem 1rem;
	opacity: 0;
	visibility: hidden;
	transition: opacity .5s, visibility .5s;
}
.nav.show {
	opacity: 1;
	visibility: visible;
	background-color: #003ea2;
	z-index: 98;
}


/* メニューアニメーション */
.nav {
	transform-origin: top left;
	transform: rotateZ(-90deg);
	transition: all .3s ease;
}
.nav.show {
	transform: rotateZ(0deg);
}
.nav_menu_li.mail a {
	font-size: 4vw;
}
.nav_menu_li a i {
	margin-right: 10px;
}
.global_nav {
	display: none;
}
.more_link i {
	color: #a7bfbe;
	margin-left: 5px;
}
.nav_menu_ul {
	margin-top: 5vw;
}
.nav_menu_ul li a {
	display: block;
	color: #fff;
	line-height: 3.5;
	font-size: 1.2em;
}
.nav_menu_ul li a i {
	margin-left: 1vw;
	color: #89daf8;
}
.nav_menu_ul hr {
	border: none;
	border-bottom: solid 1px #fff;
	margin: 8vw auto 15vw;
}
.fix_contact .btn {
	margin: auto;
}
.fix_contact .btn.tel {
	margin-top: 7vw;
}
.fix_contact .btn a {
	width: 50vw;
	background-color: #fff;
	color: #2d2d2d;
	font-size: 1rem;
}
.fix_contact .btn a i {
	color: #003ea2;
	font-size: 1.1rem;
}
.btn.tel img {
	width: 5.5vw;
	display: inline-block;
	vertical-align: middle;
}
.fix_contact .btn a i,
.btn.tel img {
	margin-right: 1vw;
}
.header_inner {
	padding-top: 4.5rem;
}

header.front_page .header_inner {
	padding-bottom: 20vw;
}
header.front_page {
	position: relative;
}
header.front_page .nav_toggle i {
	background-color: #2d2d2d;
}
header.front_page {
	background-color: #f4f4ed;
}

.thunks_35th {
	width: 40vw;
	margin-left: 0.7em;
}
.fv_catch {
	display: flex;
	justify-content: center;
}
.fv_catch p {
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-orientation: upright;
	font-size: 5vw;
	font-weight: 600;
	margin: 10vw auto;
	position: relative;
}

.fv_catch p::after {
	content: "";
	background-image: url(../img/bk_hd_3S.svg);
	background-repeat: no-repeat;
	height: 23vw;
	width: 29vw;
	position: absolute;
	right: -32vw;
	bottom: 0;
}

.card {
	display: flex;
	align-items: flex-end;
	height: 80vw;
	overflow-x: hidden;
}
.card .swiper {
	overflow: visible;
	width: 50vw;
}
.card .slide {
	overflow: hidden;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
}
.card .slide_img img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: 10px;
}
.card .swiper-slide {
	transition: 0.3s ease !important;
	position: relative;
	box-shadow: none;
	margin-bottom: 16px;
}
.card .swiper-slide .slide_content {
	position: static;
	line-height: 1;
}
.card .swiper-slide .slide_content .pick_products {
	color: #ababab;
	font-weight: 500;
	line-height: 1.5;
	font-size: 0.9em;
	margin-top: 0.5em;
	width: 100%;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.card .swiper-slide .slide_content .cat {
	color: #003ea2;
	font-weight: 400;
	font-size: 0.7em;
	line-height: 1.75;
}
.cat .screen::after {
	content: "Screen";
}
.cat .lattice::after {
	content: "Lattice";
}
.cat .partition::after {
	content: "Partition";
}
.cat .handrail::after {
	content: "Handrail";
}
.cat .panel::after {
	content: "Panel";
}
.cat .drying-rack::after {
	content: "Drying rack";
}
.cat .plamake-e::after {
	content: "Plamake-E";
}
.cat .key::after {
	content: "Key";
}
.cat .material::after {
	content: "Material";
}
.card .swiper-slide-active {
	width: 140% !important;
}
.card .swiper {
	/*幅を大きくする分swiperが中央揃えじゃなくなるので位置を調整する*/
	transform: translateX(-40%);
}
.card .swiper-slide.swiper-slide-active {
	border-radius: 15px;
	box-shadow: 0px 4px 16px -6px rgba(0, 0, 0, 0.8);
}
.card .slide_img.swiper-slide-active img {
	border-radius: 15px;
}
.card .swiper-slide.swiper-slide-active::after {
	position: absolute;
	font: var(--fa-font-solid);
	content: "\f138";
	color: #003ea2;
	right: 10px;
	bottom: 10px;
	font-size: 7vw;
	pointer-events: none;
	background-color: #fff;
	border-radius: 50%;
	width: 6.5vw;
	height: 6.5vw;
}
.card .swiper-slide.swiper-slide-active::before {
	content: "";
	display: inline-block;
	width: 35vw;
	height: 12vw;
	background-image: url("../img/ico_pickup.svg");
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	position: absolute;
	left: -8vw;
	top: -6vw;
	margin: auto;
	transition: transform .4s;
	z-index: 2;
}
.card .swiper-wrapper {
	display: flex;
	align-items: flex-end;
}
.card .swiper-slide-active .slide_content {
	display: flex;
	flex-direction:column-reverse;
	align-items: flex-start;
	position: absolute;
	bottom: 10px;
	left: 10px;
}
.card .swiper-slide-active .slide_content .pick_products {
	color: #2d2d2d;
	font-weight: 500;
	font-size: 1.1em;
	line-height: 1;
	background-color: #fff;
	padding: 0.35em 0.5em;
	margin-top: 0;
}
.card .swiper-slide-active .slide_content .cat {
	color: #fff;
	font-size: 1em;
	background-color: #003ea2;
	padding: 0.35em 0.5em;
	margin-bottom: 0.35em;
	line-height: 1;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  フロントページ
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

/*  ニュース  ----------------------------------------------*/
.top_txt p {
	margin-bottom: 5vw;
}
.btn_sp_center a.btn_more {
	margin: auto;
	margin-top: 12vw;
}
.top_news .news_item {
	background-color: #fff;
}
.top_news .news_item_w {
	margin: 10vw auto 15vw;
}
.top_news hr {
	border: none;
	border-bottom: solid 1px #eee;
	margin: 5vw 1em;
}
.top_news .news_item a {
	padding: 1em 1em 0;
	box-shadow: none;
}
.top_news .news_item_w hr:last-of-type {
	display: none;
}
.top_news .news_item .news_title::before {
	background: #003ea2;
	bottom: 0;
	content: '';
	display: block;
	height: 1px;
	left: 0;
	position: absolute;
	transition: all .4s ease-in-out;
	width: 0;
	z-index: 0;
}


/*  About  ----------------------------------------------*/
.top_about {
	background-color: #f4f4ed;
	position: relative;
	overflow-x: hidden;
}
.top_about h3 {
	position: relative;
	z-index: 2;
}
.top_about h3 > span {
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-orientation: upright;
	font-size: 5vw;
	line-height: 1.5;
	font-weight: 600;
	color: #2d2d2d;
	margin: 0 auto 10vw;
}
.top_about h3 .space,
.fv_catch .space {
	margin: 0.25em 0;
}
.top_about h3 .bk_white,
.fv_catch .bk_white {
	background-color: #fff;
	padding: 0.25em 0;
	margin: 0.5em 0 0;
}
.top_about h3::before {
	content: "";
	display: block;
	width: 18vw;
	height: 10vw;
	background-image: url("../img/ico_about.svg");
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	position: absolute;
	left: 15vw;
	top: 5vw;
	margin: auto;
	transition: transform .4s;
}
.top_about::after {
	content: "";
	display: block;
	width: 140vw;
	height: 120vw;
	background-image: url("../img/bk_about.svg");
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	position: absolute;
	left: -40vw;
	top: 0;
	z-index: 0;
}
.top_about_lead h4 {
	font-weight: 600;
	font-size: 1.2em;
	margin: 10vw 0 0.5em;
}
.top_about_lead {
	text-align: justify;
}
.about_item {
	border-radius: 5px;
	overflow: hidden;
	margin-bottom: 10vw;
}
.about_item:last-of-type {
	margin-bottom: 3vw;
}
.about_item a {
	display: block;
	position: relative;
}
.about_item_img {
	width: 100%;
	aspect-ratio: 3 / 2;
	overflow: hidden;
}
.about_item_img img {
	width: 100%;
	aspect-ratio: 3 / 2;
	object-fit: cover;
}
.about_item a > p {
	position: absolute;
	left: 2vw;
	bottom: 2vw;
	color: #fff;
	line-height: 1.5;
	font-size: 4vw;
	z-index: 2;
}
.about_item a > p span {
	display: block;
	font-size: 0.9em;
}
.about_item a::after {
	position: absolute;
	font: var(--fa-font-solid);
	content: "\f138";
	color: #fff;
	right: 2vw;
	bottom: 3vw;
	font-size: 7vw;
	pointer-events: none;
	z-index: 2;
}
.about_item a::before {
	content: "";
	display: block;
	width: 100%;
	height: 35%;
	background-image: linear-gradient(0deg, rgba(0, 0, 0, 1), rgba(0, 0, 0, 0));
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	mix-blend-mode: multiply;
	z-index: 1;
}
.three_s_top {
	width: 80%;
	margin: 10vw auto 15vw;
}


/*  主要製品  ----------------------------------------------*/
.top_products h3 {
	margin-bottom: 15vw;
}
.p_cat_w {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
}
.p_cat_item {
	width: 40%;
	margin-bottom: 7vw;
}
.p_cat_item:last-of-type {
	margin-bottom: 0;
}
.p_cat_item a {
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	align-items: center;
}
.p_cat_img {
	width: 80%;
}
.p_cat_img img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: 50%;
	box-shadow: 0px 5px 0px 0 rgba(0, 0, 0, 0.15);
}
.p_cat_name {
	width: 80%;
	color: #2d2d2d;
	display: flex;
	flex-direction: column;
	position: relative;
	padding-right: 5vw;
	margin-top: 3vw;
	min-height: 15vw;
}
.p_cat_name .en {
	color: #003ea2;
	line-height: 1.25;
	font-size: 0.85em;
}
.p_cat_name::after {
	display: flex;
	align-items: center;
	content: '\f105';
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	font-size: 1em;
	color: #003ea2;
	position: absolute;
	margin: auto;
	bottom: 0;
	top: 0;
	right: 0;
	z-index: 1;
}


/*  写真スクロール  ----------------------------------------------*/
.top_img_scroll {
	margin: 10vw 0 0;
}
.top_img_scroll.photo a {
	display: block;
	width: 50vw;
	overflow: hidden;
	border-radius: 5px;
}
.top_img_scroll.photo img {
	width: 100%;
	aspect-ratio: 1 / 1;
}


/*  CSR  ----------------------------------------------*/
.top_csr {
	background-color: #f4f4ed;
}
.top_csr_lead {
	margin: 10vw 0;
	text-align: justify;
}
.certification {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}
.certification li {
	width: 20%;
}
.certification li img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: contain;
}
.go_cert a {
	display: block;
	width:-moz-fit-content;
	width:fit-content;
	margin: auto;
	margin-right: 5px;
	color: #2d2d2d;
	font-weight: 500;
}
.go_cert a i {
	color: #003ea2;
	margin-left: 0.5em;
	font-size: 0.8em;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  企業理念
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
.pg.philosophy {
	background-color: #f4f4ed;
}
#s3 {
	overflow-x: hidden;
}
.philosophy .top_about {
/*	padding: 10vw 0;*/
	overflow: visible;
}
.philosophy .top_about::after {
	left: -43vw;
	top: -25vw;
}
.pg.philosophy .top_about h3 {
	margin-bottom: 10vw;
}
.three_s_title {
	display: block;
	text-align: center;
	font-weight: 500;
	width: -moz-fit-content;
	width: fit-content;
	margin: auto;
	margin-bottom: 10vw;
	font-size: 1.1em;
	border-bottom: dashed 1px #2d2d2d;
	padding: 0.5em 0;
}
.about {
	background-color: #fff;
}
.about a.btn_more {
	width: 55vw;
	margin: auto;
	margin-right: 0;
	margin-top: 10vw;
}
.policy {
	background-color: #fff;
}
.policy_img {
	width: 100%;
	max-width: 500px;
	margin: auto;
}
.policy_img img {
	width: 100%;
}
.policy_img_w p {
/*	color: #003ea2;*/
	letter-spacing: 0.5em;
	margin-top: 1em;
}
.policy_img_w {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-bottom: 10vw;
}
.policy h4 {
	font-weight: 600;
	text-align: center;
	letter-spacing: 0.5em;
	font-size: 1.5em;
	margin-bottom: 1em;
}
.policy ul {
	margin-bottom: 5vw;
}
.policy ul li {
	position: relative;
	padding: 1em 1em 01em 2.5em;
	margin-bottom: 1em;
	line-height: 1.5;
	border-bottom: 1px solid #ccc;
}
.policy ul li:after,
.policy ul li:before {
	position: absolute;
	content:'';
	transform: rotate(45deg);
}
.policy ul li:before {
	top: 1.25em;
	left: 0.2em;
	width: 0.8em;
	height: 0.8em;
	border:2px solid #003ea2;
}
.policy ul li:after {
	top: 1.5em;
	left: 0.7em;
	width: 1em;
	height: 1em;
	background: rgba(0, 160, 236,0.5);
	transform: rotate(60deg);
}
.about_ico {
	margin-bottom: 3vw;
}
.about_ico img {
	height: 8.5vw;
	width: 100vw;
	object-fit: contain;
	object-position: left;
}
.three_s_item {
	margin-bottom: 7vw;
}
.three_s_item:last-of-type {
	margin-bottom: 0;
}
.message_info {
	width: -moz-fit-content;
	width: fit-content;
	margin: auto;
	margin-right: 0;
}
.sec_txt .message_info p {
	margin: 0;
}
.sec_txt .message_info span {
	font-size: 1.2em;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  CSR
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
.pg.csr {
	background-color: #f4f4ed;
}
.csr .textanimation {
	font-family: "Montserrat", 'Noto Sans JP';
}
.csr [class*=swiper]:focus {
	outline: none;
}
.csr .slide-media {
	position: relative;
	overflow: hidden;
}
.csr .slide-media img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}
.csr .swiper-fade .swiper-slide {
	-webkit-transition-property: opacity, -webkit-transform !important;
	transition-property: opacity, -webkit-transform !important;
	transition-property: opacity, transform !important;
	transition-property: opacity, transform, -webkit-transform !important;
	pointer-events: none;
}
.csr .slide {
	display: grid;
	place-content: center;
	width: 100%;
	aspect-ratio: 3 / 2;
}
.csr .slide-media {
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.csr .slide-media img {
	width: 100%;
	aspect-ratio: 3 / 2;
	object-fit: cover;
	-webkit-transition: 5s 1s linear;
	transition: 5s 1s linear;
	-webkit-transform: translateX(-1.5%) scale(1.1);
	transform: translateX(-1.5%) scale(1.1);
}
.csr .swiper-slide[class*=-active] .slide-media img {
	-webkit-transition-delay: 0s;
	transition-delay: 0s;
	-webkit-transform: translateX(1.5%) scale(1.05);
	transform: translateX(1.5%) scale(1.05);
}
.strategy .swiper {
	margin: 10vw auto 0;
}
.ttl_background {
	padding: 0.5em 1em;
	background-color:#7cafc7;
	color: #fff;
	overflow: hidden;
	position: relative;
	font-size: 4vw;
	margin-bottom: 2vw;
	line-height: 1.35;
}
.ttl_background::after {
	content: '';
	background-color: #f4f4ed;
	transform: rotate(-65deg);
	position: absolute;
	bottom: -250px;
/*	right: -250px;*/
	right: -400px;
	width: 300px;
	height: 500px;
}
.strategy ul {
	margin-top: 10vw;
}
.strategy ul li,
.conduct ul li {
	margin-bottom: 10vw;
	text-align: justify;
}
.strategy ul li:last-of-type,
.conduct ul li:last-of-type {
	margin-bottom: 0;
}
.conduct {
	background-color: #fff;
}
.conduct h3 {
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	align-items: flex-start;
	flex-direction: column;
}
.conduct h3 .en {
	margin: 0;
	margin-top: 0.25em;
	line-height: 1.25;
}
.conduct .ttl_background {
	background-color: #949494;
}
.conduct .ttl_background::after {
	background-color: #fff;
}
/*.conduct h4 {
	color: #003ea2;
	font-size: 4.5vw;
	margin-bottom: 3vw;
}*/
.action {
/*	background-color: #fff;*/
}
.certifications {
/*	background-color: #fff;*/
}
.cert_desc {
	margin: 5vw 0 3vw 4vw;
}
.cert_desc_txt {
	position: relative;
	border: transparent;
	text-align: justify;
	padding: 0 4vw;
	line-height: 0;
	opacity: 0;
	transition: line-height 0.4s, padding 0.4s, opacity 0.4s;
}
.cert_desc_txt.is-open {
	padding: 3vw 4vw;
	font-size: 0.9em;
	line-height: 1.75;
	color: #555;
	opacity: 1;
	background-color: #fff;
	border-radius: 0 0 5px 5px;
}
.cert_desc button {
	display: flex;
	align-items: center;
	position: relative;
	text-align: left;
	padding: 1.5vw 4vw;
	cursor: pointer;
	font-size: 0.95em;
	width: 100%;
	background-color: #e8e8e0;
/*	border-bottom: solid 1px #2d2d2d;*/
	border-radius: 5px;
}
.cert_desc button.is-open {
	border-radius: 5px 5px 0 0;
}
.cert_desc button i {
	color: #7cafc7;
	margin-right: 1em;
}
.cert_desc button:after {
	content: "";
	display: inline-block;
	width: 3vw;
	height: 3vw;
	background-image: url(../img/ico_plus.svg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	position: absolute;
	right: 4vw;
	top: 0;
	bottom: 0;
	margin: auto;
	transition: transform .4s;
}
.cert_desc button.is-open::after {
	background-image: url(../img/ico_minus.svg);
}
.cert_item {
	border-bottom: dashed 1px #cdcdcd;
	padding-bottom: 7vw;
	margin-bottom: 7vw;
}
.cert_item:first-of-type {
	padding-top: 7vw;
	border-top: dashed 1px #cdcdcd;
}
.cert_title {
	display: flex;
/*	align-items: center;*/
	position: relative;
	text-align: left;
	padding: 1.5vw 4vw 1.5vw 0;
	font-size: 1.1em;
	line-height: 1.5;
}
.cert_title::before {
	display: block;
	content: "⚫︎";
	line-height: 1.5;
	margin: 0;
	margin-right: 5px;
	color: #ccc;
}
.cert_url a {
	font-size: 0.9em;
	display: block;
	text-decoration: underline;
	width:-moz-fit-content;
	width:fit-content;
	margin: auto;
	margin-right: 0;
	color: #003ea2;
}
.cert_url a i {
	margin-left: 5px;
}
.cert_logo {
	width: 80%;
	margin: 5vw auto;
}
.cert_logo img {
	width: 100%;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  ニュース
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
.news_li,
.news_post {
	background-color: #f4f4ed;
}
.news_list a {
	color: #2d2d2d;
}
.news_ico_title {
	margin-bottom: 3vw;
	color: #003ea2;
	line-height: 1;
}
.news_cat_w {
	margin-bottom: 5vw;
}
.news_cat {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
.news_ico {
	width: -moz-fit-content;
	width: fit-content;
	display: block;
	color: #003ea2;
	font-weight: 500;
	margin-right: 0.5em;
	line-height: 1;
}
.news_cat .news_ico,
.news_post .news_info .news_ico{
	line-height: 2;
	border: solid 1px #003ea2;
	border-radius: 100px;
}
.news_cat .news_ico {
	margin-bottom: 0.5em;
	font-size: 0.9em;
}
.news_ico.current {
	background-color: #003ea2;
}
.news_ico.current a {
	color: #fff;
}
.news_ico a {
	display: block;
	width: 100%;
	height: 100%;
	color:  #003ea2;
	padding: 0 1em;
}
.news_item .news_ico {
	font-size: 0.9em;
}
.news_ico_w {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
.news_current {
	margin-bottom: 10vw;
	font-size: 0.9em;
}
.news_current span {
	font-weight: 500;
	font-size: 1rem;
}
.news_cat_name {
	margin: auto 0.25em;
	color: #003ea2;
}
.news_info {
	display: flex;
	justify-content: flex-start;
	align-content: center;
	flex-wrap: wrap;
	margin-bottom: 0.35em;
}
.news_date {
	display: block;
	color: #aaa;
	font-size: 0.9em;
	font-weight: 500;
	line-height: 1.5;
	margin-right: 0.5em;
	align-self: center;
}
.news_item {
	border-radius: 5px;
	margin-bottom: 3vw;
	background-color: #fff;
}
.news_item a {
	display: block;
	color: #2d2d2d;
	width: 100%;
	height: 100%;
	border-radius: 3px;
	padding: 5vw 6vw 3vw;
	box-shadow: 0px 3px 0px 0 rgba(0, 0, 0, 0.15);
}
.news_item .news_title {
	display: block;
	line-height: 1.5;
	margin-top: 1em;
	padding-bottom: 1em;
	padding-right: 18vw;
	text-align: justify;
	position: relative;
}
.news_item .news_title::after {
	display: flex;
	align-items: center;
	content: '\f054';
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	font-size: 1em;
	color: #003ea2;
	position: absolute;
	margin: auto;
	bottom: 0;
	top: 0;
	right: 0;
	pointer-events: none;
	z-index: 1;
	padding-bottom: 1em;
}
.page-navigation {
	margin-top: 25vw;
}
.page-navigation > .page-numbers {
	width: -moz-fit-content;
	width: fit-content;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	align-items: center;
	position: relative;
	margin: auto;
	padding: 0 2.5em;
}
.page-navigation a,
.page-navigation span {
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #fff;
	width: 2.5em;
	height: 2.5em;
	line-height: 1;
	text-align: center;
	margin: auto 0.25em;
	border-radius: 50%;
}
.page-navigation span {
	color: #fff;
	background-color: #003ea2;
}
.page-navigation .page-numbers.dots {
	color: #2d2d2d;
	background: none;
}
.page-navigation a.prev,
.page-navigation a.next {
	background: none;
	position: absolute;
	top: 0;
}
.page-navigation a.next {
	right: 0;
}
.page-navigation a.prev {
	left: 0;
}
.news_post h3 {
	color: #2d2d2d;
	font-size: 5vw;
	font-weight: 600;
	line-height: 1.75;
	text-align: justify;
	margin: 0 0 15vw;
}
.news_post h4 {
	font-size: 4.5vw;
	font-weight: 500;
	line-height: 1.5;
	margin-bottom: 7vw;
	padding-left: 5vw;
	border-left: solid 5px #2d2d2d;
}
.news_post .news_info {
	margin-bottom: 5vw;
}
.news_post .news_ico {
	font-size: 0.9em;
}
.news_post .news_cat_w {
	margin-top: 20vw;
}
.news_post .news_date {
	margin-right: 1em;
}
.news_content figure,
.news_content p {
	margin-bottom: 10vw;
}
.news_post .wp-block-image img {
	display: block;
	vertical-align: bottom;
	margin: auto;
}
.news_nav {
	margin: 25vw 0 0;
}
.news_nav a {
	color: #8e8e8e;
}
.nav-links {
	clear:both;
}
.nav-links > div {
	display: inline-block;
	width: 45vw;
	margin: 0;
	vertical-align: top;
}
.nav-links > div.nav-next {
	float: right;
}
.nav-links > div a {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	flex-wrap: wrap;
}
.nav-links > div.nav-next a {
	justify-content: flex-end;
}
.nav-links > div > a > div {
	width: 40vw;
	display: flex;
	flex-direction: column;
}
.nav-links > div.nav-next a > div {
	align-items: flex-end;
	padding-right: 3vw;
}
.nav-links > div.nav-previous a > div {
	padding-left: 3vw;
}
.nav-links > div i {
	font-size: 5vw;
	color: #003ea2;
}
.meta-nav {
	display: block;
	width: -moz-fit-content;
	width: fit-content;
	text-align: center;
	color: #fff;
	background-color: #aaa;
	font-size: 0.8em;
	padding: 0 1em;
	margin-bottom: 0.5em;
}
.post-title {
	line-height: 1.5;
	font-size: 0.9em;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}
.news_nav a.btn_line {
	color: #001760;
	border-color: #001760;
}
.news_nav_golist {
	display: flex;
	justify-content: center;
	margin: 5vw auto 0;
}
.clear {
	display: block;
	clear: both;
}
.news_content a {
	color: #003ea2;
	text-decoration: underline;
	padding: 0 0.5em;
}
.no_news {
	display: flex;
	align-items: center;
	height: 100%;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  会社概要
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
.company_info h3 .en{
	font-size: 7vw;
}
.company_info h3 {
	margin-left: 0;
	margin-right: 0;
}
.com_info li {
	display: flex;
	flex-direction: column;
}
.com_info_th {
	background-color: #e8e8e0;
	border-bottom: solid 1px #dcdcd2;
}
.com_info_th {
	padding: 1vw 5vw;
}
.com_info > li > div {
	padding: 3vw 5vw;
	background-color: #fff;
}
.com_info_sub_th {
	width: -moz-fit-content;
	width: fit-content;
	border: solid 1px #003ea2;
	color: #003ea2;
	padding: 0 0.5em;
	line-height: 1.85;
}
.com_info_sub > li {;
	margin: 2vw 0 3vw;
}
.office .com_info_sub > li {
	display: flex;
	justify-content: space-between;
	flex-direction: row;
	flex-wrap: wrap;
}
.com_info li.office > div {
	padding-bottom: 5vw;
}
.office .com_info_sub > li > div {
	width: 60%;
}
.office .com_info_sub > li > div > div {
	line-height: 1.5;
	margin-top: 0.5em;
}
.office .com_info_sub > li > p {
	display: flex;
	width: 40%;
	justify-content: flex-end;
	align-items: flex-end;
}
.com_info_sub > li:last-of-type {
	margin-bottom: 0;
}
.com_info a {
	text-decoration: underline;
	color: #999;
	word-break: break-all;
	line-height: 1.5;
	margin-bottom: 0.5em;
}
.com_info .go_cert a {
	margin: 0.25em auto 0.25em 0;
}
.company_add_info {
	padding-top: 0;
}
.company_add_info  .ttl_background {
	background-color: #949494;
}
.com_add_title {
	font-weight: 500;
	font-size: 1.15em;
	border-bottom: solid 1px #2d2d2d;
	padding-bottom: 0.25em;
	margin-bottom: 0.25em;
}
.com_add_inner {
	margin-bottom: 10vw;
}
.com_add_w {
	margin-bottom: 7vw;
}
.com_add_w:last-of-type,
.com_add_inner:last-of-type {
	margin-bottom: 0;
}
.com_info a.btn_line {
	display: block;
	width: -moz-fit-content;
	width: fit-content;
	border-color: #999;
	padding: 1vw 3vw;
	margin-top: 0.5em;
	text-decoration: none;
}
.com_info a.btn_line i:first-of-type {
	margin-right: 0.5em;
}
.com_info a.btn_line i:last-of-type {
	margin-left: 0.5em;
}
.access {
	background-color: #fff;
}
.map_w {
	padding-top: 10vw;
}
.map_w:first-of-type {
	padding-top: 0;
	margin-bottom: 10vw;
}
.map {
	margin-top: 5vw;
}
.map iframe {
	width: 100%;
	height: 40vw;
	filter: grayscale(100%);
	transition: all 0.7s ease;
}
.map_txt {
	display: flex;
}
.map_txt > i {
	font-size: 4.5vw;
	color: #003ea2;
	display: block;
	height: auto;
	line-height: 1.25;
}
.map_txt >div {
	width: calc(100% - 4.5vw);
	padding-left: 3vw;
}
.map_th {
	font-size: 5vw;
	line-height: 1;
	margin-bottom: 0.5em;
	font-weight: 500;
}
.access hr {
	border: none;
	border-bottom: solid 1px #ccc;
}
.map_way {
	font-size: 0.9em;
	margin-top: 5vw;
}
.map_way > div {
	display: flex;
	flex-wrap: wrap;
}
.map_way > div > i {
	font-size: 4vw;
	display: block;
	width: 5%;
	height: auto;
	margin: auto;
	text-align: center;
	color: #999;
}
.map_way > div > p {
	width: 95%;
	padding-left: 3vw;
}
.history_year {
	font-size: 7vw;
	line-height: 1.5;
	font-weight: 300;
}
.history_txt {
	padding: 3vw 0;
	padding-left: 10vw;
	border-left: solid 1px #333;
	margin: 3vw 5vw;
}
.history_txt p {
	line-height: 1.75;
	margin-bottom: 1.5em;
	text-indent: -0.5em;
}
.history_txt p:last-of-type {
	margin-bottom: 0;
}
.history_txt p a {
	text-decoration: underline;
	color: #999;
	word-break: break-all;
	line-height: 1.5;
}
.history_txt p::before {
	display: inline-block;
	content: "●";
	margin-right: 1em;
	font-size: 0.5em;
	color: #949494;
	vertical-align: middle;
	height: 3.75vw;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  主要製品 リストページ
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
.products_li {
	background-color: #f4f4ed;
}
.products_all h3 {
	margin-bottom: 10vw;
}
.products_li section {
	padding: 10vw 0 0;
}
.products_li section.products_all {
	padding: 0;
}
.products_list {
	padding: 15vw 0;
}
.products_list:last-of-type {
	padding-bottom: 25vw;
}
.products_nav nav ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.products_nav nav ul li {
	width: 30%;
}
.products_nav nav ul li .p_cat_name {
	padding: 0.5em 0 0.25em;
	font-size: 0.9em;
	align-items: center;
	background-color: #e8e8e0;
	width: 100%;
	border-radius: 5px;
}
.products_nav nav ul li .p_cat_name::after {
	content: '\f107';
	position: static;
	justify-content: center;
}
.products_li .oth_products {
	white-space: normal;
}
.products_list {
	border-top: solid 1px #2d2d2d;
}
.products_list:first-of-type {
	border: none;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  主要製品 個別商品ページ
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
.products {
	background-color: #f4f4ed;
}
.product_img {
	width: 100%;
	margin-bottom: 10vw;
}
.product_img img {
	width: 100%;
/*	aspect-ratio: 1 / 1;
	object-fit: contain;*/
	border-radius: 15px;
/*	background-color: #fff;*/
}
.products .cat {
	color: #003ea2;
	font-weight: 400;
	font-size: 0.9em;
	line-height: 1.75;
}
.product_txt {
	text-align: justify;
}
.cat_name {
	font-weight: 400;
	line-height: 1.75;
	margin-right: 0.5em;
}
.cat_name .screen::after {
	content: "[ 網戸 ]";
}
.cat_name .lattice::after {
	content: "[ 面格子 ]";
}
.cat_name .partition::after {
	content: "[ 間仕切り ]";
}
.cat_name .handrail::after {
	content: "[ 手すり笠木 ]";
}
.cat_name .panel::after {
	content: "[ パネル ]";
}
.cat_name .drying-rack::after {
	content: "[ 物干金物 ]";
}
.cat_name .plamake-e::after {
	content: "[ プラメイク-EⅡ ]";
}
.cat_name .key::after {
	content: "[ 防犯錠 ]";
}
.cat_name .material::after {
	content: "[ アルミ形材 ]";
}
.cat_w {
	display: flex;
	align-items: center;
}
h3.product_name {
	color: #2d2d2d;
	font-size: 8vw;
	font-weight: 300;
	margin-top: 3vw;
	line-height: 1.75;
	margin-bottom: 10vw;
}
.products .ttl_background {
	background-color: #949494;
	padding-right: 3em;
	margin-bottom: 4vw;
}
.products .ttl_background::after {
	right: -385px;
}
.btn.catalog a {
	width: -moz-fit-content;
	width: fit-content;
	font-size: 0.95em;
	padding-left: 2em;
	padding-right: 2em;
}
.btn.catalog {
	margin: 10vw auto 0;
}
.btn.catalog a i {
	margin-right: 5px;
}
.others {
	padding-top: 0;
}
.others .section_inner {
	border-top: solid 1px #2d2d2d;
	padding-top: 20vw;
}
.oth_title {
	margin-bottom: 10vw;
}
.oth_title .screen::after {
	content: "網戸";
}
.oth_title .lattice::after {
	content: "面格子";
}
.oth_title .partition::after {
	content: "間仕切り";
}
.oth_title .handrail::after {
	content: "手すり笠木";
}
.oth_title .panel::after {
	content: "パネル";
}
.oth_title .drying-rack::after {
	content: "物干金物";
}
.oth_title .plamake-e::after {
	content: "プラメイク-EⅡ";
}
.oth_title .key::after {
	content: "防犯錠";
}
.oth_title .material::after {
	content: "アルミ形材";
}
.oth_w {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.oth_w::after{
	content: '';
	width: 28%;
	height: 0;
	display: block;
}
.oth_item {
	width: 28%;
	margin-bottom: 10vw;
}
.oth_item:last-of-type,
.oth_item:nth-last-of-type(2),
.oth_item:nth-last-of-type(3) {
	margin-bottom: 0;
}
.oth_item img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: 5px;
	box-shadow: 0px 2px 8px -4px rgba(0, 0, 0, 0.8);
}
.oth_products {
/*	color: #ababab;*/
	color: #2d2d2d;
/*	font-weight: 500;*/
	line-height: 1.5;
	font-size: 13px;
	margin-top: 0.5em;
	width: 100%;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.oth_item .cat {
	color: #003ea2;
	font-weight: 400;
	font-size: 0.7em;
	line-height: 1.75;
}
.products .p_cat_item {
	width: 100%;
}
.products .p_cat_item a {
	flex-direction: row;
	justify-content: center;
}
.products .p_cat_img {
	width: 25%;
}
.products .p_cat_name {
	width: 50%;
	padding-left: 10vw;
}
.category {
	background-color: #fff;
}
.category.screen .p_cat_item.screen{
	display: none;
}
.category.lattice .p_cat_item.lattice{
	display: none;
}
.category.partition .p_cat_item.partition{
	display: none;
}
.category.handrail .p_cat_item.handrail{
	display: none;
}
.category.panel .p_cat_item.panel{
	display: none;
}
.category.drying-rack .p_cat_item.drying-rack{
	display: none;
}
.category.plamake-e .p_cat_item.plamake-e{
	display: none;
}
.category.key .p_cat_item.key{
	display: none;
}
.category.material .p_cat_item.material{
	display: none;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  固定ページ共通
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
.fix_pg {
	background-color: #f4f4ed;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  プライバシーポリシー
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
.header_inner.privacy_header h2 img {
	width: 80vw;
}
.privacy_content h4 {
	font-weight: 600;
	font-size: 1.25em;
	margin: 10vw 0 3vw;
}
.privacy_content h4:first-of-type {
	margin-top: 0;
}
.privacy_content ul {
	margin-top: 1em;
}
.privacy_content ul li::before {
	content: "-";
	margin-right: 0.5em;
}
.privacy_sign {
	margin-top: 15vw;
}
.privacy_sign p {
	text-align: right;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  お問い合わせ 
/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
.form_w {
	max-width: 800px;
	margin: auto;
}
.contact_form {
	padding-top: 10vw;
}
.contact_tel {
	background-color: #2d2d2d;
	color: #fff;
	padding: 5vw 0 7vw;
}
.contact_tel > div {
	width: 90%;
	margin: auto;
}
.contact_tel p.tel {
	font-size: 6.5vw;
	text-align: center;
}
.contact_tel p.tel a {
	color: #fff;
}
.contact_form .item_tit label {
	display: flex;
	align-items: center;
	color: #2d2d2d;
	font-weight: 500;
	margin-bottom: 0.5em;
}
.contact_form .item_cont {
	font-weight: 400;
}
.contact_page .contact_top p {
	line-height: 1.5;
}
.contact_page .contact_top .notice {
	font-weight: 400;
	line-height: 1;
	text-align: center;
}
.contact_form .wpcf7 form .wpcf7-response-output {
	border-color: #f4f4ed;
	margin: 0;
	padding: 0;
}
.contact_form .wpcf7 form.invalid .wpcf7-response-output,
.contact_form .wpcf7 form.unaccepted .wpcf7-response-output,
.contact_form .wpcf7 form.payment-required .wpcf7-response-output {
	margin: 3em 0.5em 1em;
	padding: 0.2em 1em;
	border-color: #dc3232;
}
.contact_form .section_inner {
	padding-bottom: 0;
/*	max-width: 800px;*/
}
.contact_form .item_wrap {
/*	background-color: #fff;*/
	margin-bottom: 0;
	padding: 5vw 0;
	border-bottom: solid 1px #CECECE;
}
.contact_form .item_wrap.check {
	border: none;
}
.contact_form .item_tit {
	font-size: 0.9em;
}
.contact_form .item_tit span {
	display: block;
	font-size: 0.75em;
	background-color: #dc3232;
	color: #fff;
	text-align: center;
	width: 3em;
	margin-right: 5px;
	line-height: 1.5;
}
.contact_form .item_tit span.option {
	background-color: #9d9d9d;
}
.contact_form .item_cont {
	font-size: 0.85em;
}
.contact_form input,
.contact_form textarea,
.contact_form select {
	display: block;
	width: 100%;
	background-color: #fff;
	border: solid 1px #919191;
	border-radius: 3px;
	padding: 0.35em 0.5em;
	font-size: 1em;
	box-shadow: 0px 2px 4px 1px rgb(26 26 26 / 13%) inset;
}
.contact_form .your-item input {
	width: auto;
	display: inline-block;
}
.contact_form .your-item .wpcf7-list-item {
	display: inline-block;
	margin: 0.5em 1.5em 0 0;
}
.contact_form .your-item .item_cont {
	font-size: 1em;
}
.contact_form .zip_w > p,
.your-tel .item_cont,
.btn > p {
	display: flex;
	align-items: center;
	margin: 1em 0;
}
.your-addr p {
	margin: 0.5em 0;
}
.your-tel .item_cont {
	margin: 0;
}
.contact_form .check .item_cont .wpcf7-list-item {
	margin-left: 0;
}
.contact_form .btn {
	margin: 10vw auto;
}
.contact_form .btn > p {
	justify-content: center;
}
.contact_form .btn input {
	width: 40vw;
	text-align: center;
	border-radius: 5px;
	line-height: 2;
	margin: 0 5vw;
	background-color: #2d2d2d;
	color: #fff;
	border: none;
	max-width: 300px;
}
.contact_form .wpcf7-submit:disabled {
background-color: #999;
}
.contact_form  .wpcf7-spinner {
	display: none;
}
.privacy_check {
	color: #2d2d2d;
}
.privacy_check a {
	color: #919191;
	text-decoration: underline;
}
.contact_form .notice {
	margin-bottom: 3vw;
}
.your-ken {
	width: 40%;
	position: relative;
}
.your-ken::after {
	position: absolute;
	font: var(--fa-font-solid);
	content: "\f078";
	color: #9d9d9d;
	right: 0.5em;
	top: 2vw;
	font-size: 4vw;
	pointer-events: none;
}
::placeholder {
 color: #d1d1d1;
}
.contact_form .wpcf7 form.invalid .wpcf7-response-output, .contact_form .wpcf7 form.unaccepted .wpcf7-response-output, .contact_form .wpcf7 form.payment-required .wpcf7-response-output {
	margin: 3em 0;
	padding: 1em 2em;
	line-height: 1.5;
}
.contact_form .wpcf7 form .wpcf7-response-output {
	margin: 0;
	padding: 1em 2em;
	line-height: 1.5;
}
.zip_w .mark {
	font-size: 1.2em;
	margin-right: 0.5em;
}
/* チェックボックス */
.contact_form .wpcf7-list-item {
	margin: 0;
}
.contact_form input[type="checkbox"] {
	position: relative;
	height: 20px;
	width: 20px;
	display: inline-block;
	border: 2px solid #ccc;
	background: #fff;
	-webkit-appearance: none;
	appearance: none;
	box-shadow: none;
	margin-right: 10px;
	padding: 0;
}
.contact_form input[type="checkbox"]:checked {
	border: none;
	background-image: url("data:image/svg+xml;utf8,<svg version='1.1' xmlns='http://www.w3.org/2000/svg' width='16' height='16'><rect fill='%23dc3232' width='16' height='16'/><path fill='none' stroke='%23fff' stroke-width='2' d='M12.6,5.17l-5.66,5.66L3.4,7.29'/></svg>");
	background-repeat: no-repeat;
	background-size: cover;
}
.item_wrap a {
	color: #003ea2;
}
.contact_form .wpcf7 form.sent,
.contact_form .wpcf7-response-output {
	border-color: #003ea2;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  footer
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
footer {
	background-color: #f4f4ed;
	padding: 20vw 0 10vw;
	margin: 0;
	margin-bottom: -10vw;
}
.footer_inner {
	width: 90%;
	margin: 0 auto;
}
footer a {
	color: #2d2d2d;
}
.ft_logo {
	width: 60%;
	max-width: 180px;
	margin-bottom: 5vw;
}
.ft_logo img {
	display: block;
	width: 100%;
	margin: auto;
	text-align: center;
}
.ft_right {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 5vw 0;
}
.ft_menu_w {
	width: 47%;
	margin: 10vw 0 0;
}
.ft_menu {
	font-weight: 500;
}
.ft_menu i {
	color: #003ea2;
	margin-left: 0.5em;
	font-size: 0.8em;
}
.ft_menu_sub {
	font-size: 0.9em;
}
.ft_menu a,
.ft_menu_sub li a {
	display: flex;
	align-items: center;
	width: 100%;
}
.ft_menu_sub li a::before {
	content: "●";
	margin-right: 0.5em;
	font-size: 0.5em;
	color: #ccc;
}
.ft_menu_w hr {
	border: none;
	border-bottom: solid 1px #2d2d2d;
	margin: 5vw 0;
}
footer .bnr_w {
	margin-top: 15vw;
}
.copy {
	display: block;
	line-height: 2.5;
	text-align: center;
	margin: 15vw auto 0;
	color: #2d2d2d;
	margin-bottom: 5vw;
}
.copy small::before {
	content: '\f1f9';
	font-family: "Font Awesome 5 Free";
	font-size: 0.85em;
	font-weight: 400;
	margin-right: 5px;
}
.copy p {
	font-size: 0.65em;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  404
/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
.page_404 {
	background-color: #f4f4ed;
}
.page_404 p {
	text-align: center;
	margin-top: 2em;
}
.page_404 a.btn_more {
	width: 55vw;
	max-width: 250px;
	margin: 4em auto 0;
}
.img_404 {
	margin: auto;
	max-width: 600px;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  レスポンシブ調整
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
.pc,
.pc_flex {
	display: none;
}
.tb,
.tb_flex {
	display: none;
}
.sp {
	display: block;
}
.sp_flex {
	display: flex;
}


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  構築中暫定
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
p.prep {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	height: 100%;
}






