@charset "utf-8";

/* ================================================================================
	Layout
================================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@700&display=swap');

@font-face {
	font-family: 'CaboRounded';
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url('/shared/font/CaboRounded/CaboRounded.woff2') format('woff2'),
		url('/shared/font/CaboRounded/CaboRounded.woff') format('woff');
}

@font-face {
	font-family: 'Yu Gothic';
	font-weight: 100;
	src: local('Yu Gothic Medium');
}
@font-face {
	font-family: 'Yu Gothic';
	font-weight: 200;
	src: local('Yu Gothic Medium');
}
@font-face {
	font-family: 'Yu Gothic';
	font-weight: 300;
	src: local('Yu Gothic Medium');
}
@font-face {
	font-family: 'Yu Gothic';
	font-weight: 400;
	src: local('Yu Gothic Medium');
}
@font-face {
	font-family: 'Yu Gothic';
	font-weight: bold;
	src: local('Yu Gothic Bold');
}

html {
	/* scroll-behavior: smooth; */
}

body {
	min-width: 1200px;
	color: #111;
	font-family: 'Yu Gothic', 'YuGothic', 'Noto Sans JP', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic ProN', 'メイリオ', 'Meiryo', 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	font-size: 14px;
}

a {
	color: #111;
}
a:active, a:hover, a:focus {
	color: #111;
}

.l-container {
	overflow: hidden;
}


/* ---------------------------------------------------------
	header
---------------------------------------------------------- */
.l-header {
	position: relative;
	z-index: 1000;
}
.l-header_inner {
	display: flex;
	justify-content: space-between;
	height: 120px;
	padding: 0 50px;
}

.header_logo {
	order: 1;
	padding-top: 40px;
	line-height: 1;
}

.header_sns {
	order: 3;
	margin-left: 22px;
	padding-top: 38px;
}
.header_sns_list {
	display: flex;
}
.header_sns_list_item:nth-child(1) {
	margin-right: 15px;
}
.header_sns_list_item a {
	display: block;
	width: 55px;
	height: 55px;
	border-radius: 50%;
	background: #000;
	line-height: 56px;
	color: #fff;
	font-size: 20px;
	text-align: center;
}
.header_sns_list_item:nth-child(2) a {
	font-size: 24px;
}

.header_nav {
	order: 2;
	margin-left: auto;
	padding-top: 38px;
}
.header_nav_list {
	display: flex;
}
.header_nav_list_item {
	float: left;
}
.header_nav_list_item > a {
	display: block;
	height: 55px;
	padding: 0 18px;
	line-height: 55px;
	font-size: 16px;
	font-weight: bold;
	letter-spacing: 0.08em;
}
.header_nav_list_item > a {
	color: inherit;
}

/* subnav */
.header_nav_list li {
	position: relative;
}
.header_nav_list_item ul {
	display: none;
	position: absolute;
	top: 102px;
	left: -10%;
	z-index: 100;
	min-width: 120%;
}
.header_nav_list_item li {
	margin-bottom: 1px;
	background: #fff;
}
.header_nav_list_item li a {
	display: block;
	position: relative;
	padding: 8px 20px 8px 8px;
	background: #000;
	line-height: 1.4;
	color: #fff;
	font-size: 12px;
	white-space: nowrap;
}
.header_nav_list_item li a:hover {
}
.header_nav_list_item li a::after {
	content: '\f105';
	position: absolute;
	top: 50%;
	right: 8px;
	line-height: 1;
	font-family: 'Font Awesome 6 Pro';
	font-size: 12px;
	font-style: normal;
	font-weight: 300;
	font-variant: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: auto;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.header_nav_list_item ul ul {
	top: 0;
	left: calc(100% + 1px);
	min-width: 100%;
}

/* media queries */
@media screen and (max-width: 1280px) {
}


/* ---------------------------------------------------------
	mainvisual
---------------------------------------------------------- */
.l-mainvisual {
	position: relative;
	width: calc(100% - 100px);
	max-width: 1600px;
	margin: 0 auto;
	padding: 20px 0;
}
.l-mainvisual::before,
.l-mainvisual::after {
	content: '';
	position: absolute;
	left: 0;
	width: 100%;
	height: 10px;
	border-style: solid;
	border-color: #000;
}
.l-mainvisual::before {
	top: 0;
	border-width: 1px 1px 0;
	border-radius: 5px 5px 0 0;
}
.l-mainvisual::after {
	bottom: 0;
	border-width: 0 1px 1px;
	border-radius: 0 0 5px 5px;
}
.l-mainvisual_inner {
	position: relative;
	aspect-ratio: 1600 / 870;
}

.mv_slider {
	aspect-ratio: 1600 / 870;
	margin: 0 -10px;
}
.mv_slider_list {
}
.mv_slider .slick-list {
	overflow: visible;
}
.mv_slider_list_item {
	padding: 0 10px;
}
.mv_slider_list_item a {
	display: block;
}
.mv_slider_list_item {
}

.mv_news {
	overflow: hidden;
	position: absolute;
	right: 30px;
	bottom: 50px;
	z-index: 100;
	width: 480px;
	height: 120px;
	padding: 31px 35px 0;
	background: #fff;
}
.mv_news_head {
	position: relative;
	margin-bottom: 23px;
	line-height: 0;
}
.mv_news_ttl {
}
.mv_news_btn {
	position: absolute;
	top: -8px;
	right: 0;
}
.mv_news_btn a {
	display: block;
	width: 70px;
	padding: 7px 0;
	border-bottom: 1px solid #000;
	line-height: 0;
	text-align: center;
}
.mv_news_list {
	margin: 0 -18px; /* 35/2 */
}
.mv_news .slick-list {
	overflow: visible;
}
.mv_news_list_item {
	padding: 0 18px;
}
.slick-slide {
}
.mv_news_list_ttl {
	display: flex;
	height: 20px;
	line-height: 22px;
	font-size: 13px;
	font-weight: bold;
}
.mv_news_list_date {
	margin-right: 14px;
	padding-right: 14px;
	border-right: 1px solid #000;
	letter-spacing: 0.05em;
}
.mv_news_list_ttl a {
	flex: 1;
	color: inherit;
}


/* ---------------------------------------------------------
	content
---------------------------------------------------------- */
.l-content_inner {
	width: 1200px;
	margin: 0 auto;
	padding-bottom: 160px;
}
.home .l-content_inner {
	width: auto;
	padding-bottom: 120px;
}


/* ---------------------------------------------------------
	main
---------------------------------------------------------- */
.l-main {
}
.home .l-main {
}


/* ---------------------------------------------------------
	sidebar
---------------------------------------------------------- */
.l-sidebar {
	padding-top: 80px;
}

.side_blog {
	overflow: hidden;
	margin: 0 -15px;
}
.side_nav {
	float: left;
	width: 25%;
	padding: 0 15px;
}
.side_nav.-recent {
	width: 50%;
}
.side_nav_ttl {
	position: relative;
	margin-bottom: 15px;
	padding-bottom: 15px;
	font-size: 19px;
}
.side_nav_ttl::after {

	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 20px;
	height: 3px;
	/* edit */
	background: #555;
}
.side_nav_scroll {
	height: 285px;
	padding-right: 15px;
}
.side_nav .simplebar-scrollbar {
	right: 0;
	width: 1px;
}
.side_nav .simplebar-scrollbar::before {
	background: rgba(0, 0, 0, 0.3);
}
.side_nav li a {

	display: block;
	position: relative;
	padding: 17px 20px 17px 0;
	/* edit */
	border-bottom: 1px solid #eee;
	color: inherit;
}
.side_nav li a::after {

	content: '\f054';
	position: absolute;
	top: 50%;
	right: 5px;
	line-height: 1;
	/* edit */
	color: #666;
	font-family: 'Font Awesome 5 Pro';
	font-size: 11px;
	font-style: normal;
	font-weight: 400;
	font-variant: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: auto;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}
.side_nav li li a {
	padding-left: 1em;
}
.side_nav li li li a {
	padding-left: 2em;
}
.side_nav li a span {
	margin-right: 15px;
}


/* ---------------------------------------------------------
	footer
---------------------------------------------------------- */
.scroll_top {
	position: fixed;
	right: 70px;
	bottom: 43px;
	z-index: 1000;
}
.scroll_top_btn {
	display: block;
}

.l-footer {
}
.l-footer_inner {
}

.footer_contact {
	display: flex;
	position: relative;
	width: 1200px;
	margin: 0 auto 119px;
}
.footer_contact::before,
.footer_contact::after {
	content: '';
	position: absolute;
	left: 0;
	width: 100%;
	height: 15px;
	border-style: solid;
	border-color: #000;
}
.footer_contact::before {
	top: 0;
	border-width: 1px 1px 0;
	border-radius: 10px 10px 0 0;
}
.footer_contact::after {
	bottom: 0;
	border-width: 0 1px 1px;
	border-radius: 0 0 10px 10px;
}
.footer_contact_item {
	position: relative;
	flex: 0 0 auto;
	width: 50%;
	max-width: 100%;
	padding: 75px 0 80px;
	line-height: 1;
	text-align: center;
}
.footer_contact_item:first-child::after {
	content: '';
	position: absolute;
	inset: 60px 0 60px auto;
	border-right: 1px solid #000;
}
.footer_contact_icon {
	display: block;
	height: 40px;
	margin-bottom: 31px;
	line-height: 40px;
	font-size: 40px;
}
.footer_contact_item.-mail .footer_contact_icon {
	font-size: 37px;
}
.footer_contact_label {
	margin-bottom: 13px;
	font-size: 16px;
	font-weight: bold;
}
.footer_contact_item.-mail .footer_contact_label {
	margin-bottom: 3px;
}
.footer_contact_tel {
	font-size: 25px;
	font-weight: bold;
	letter-spacing: 0.05em;
}
.footer_contact_btn {
}
.footer_contact_btn a {
	display: inline-block;
	width: 120px;
	padding: 11px 0;
	border-bottom: 1px solid #000;
	line-height: 0;
}

.footer_detail {
	padding: 0 70px;
}

.footer_about {
	float: left;
	width: 390px;
}
.footer_about_logo {
	margin-bottom: 29px;
}
.footer_about_txt {
	line-height: 1.75;
	font-size: 16px;
	font-weight: bold;
}

.footer_link {
	float: right;
}

.footer_nav {
	margin: -10px 0 65px;
}
.footer_nav_list {
	display: flex;
	gap: 35px;
	justify-content: flex-end;
	margin-bottom: 11px;
}
.footer_nav_list:last-child {
	margin: 0;
}
.footer_nav_list_item {
	font-size: 16px;
	font-weight: bold;
}
.footer_nav_list_item a {
	color: inherit;
}

.footer_shopping {
	display: flex;
	align-items: center;
	justify-content: flex-end;
}
.footer_shopping_ttl {
	margin-right: 26px;
	line-height: 1;
}
.footer_shopping_list {
	display: flex;
	gap: 15px;
	justify-content: flex-end;
}
.footer_shopping_list_item {
}

.footer_copyright {
	clear: both;
}
.footer_copyright span {
	display: inline-block;
	min-width: 220px;
	padding: 54px 0 44px;
	border-bottom: 5px solid #000;
	line-height: 1;
	font-size: 16px;
}


/* ================================================================================
	Content
================================================================================ */

/* ---------------------------------------------------------
	Top
---------------------------------------------------------- */
.js-sr_item {
	visibility: hidden;
}

.top_btn {
	display: flex;
	justify-content: flex-end;
	line-height: 0;
}
.top_btn a {
	width: 100px;
	padding: 9px 0;
	border-bottom: 1px solid #000;
}

.top_concept {
	position: relative;
	margin-bottom: 130px;
	padding-top: 235px;
}
.top_concept::before {
	content: '';
	position: absolute;
	top: 48px;
	left: 0;
	width: 100%;
	height: 64px;
	background: url(/shared/img/pc/top_concept_ticker.png) repeat-x 0 0;
	-webkit-animation: concept_ticker 25s linear infinite;
	animation: concept_ticker 25s linear infinite;
}
.top_concept_inner {
	width: 1200px;
	margin: 0 auto;
}
.top_concept_detail {
	float: left;
	width: 600px;
}
.top_concept_ttl {
	margin: -5px 0 27px;
	line-height: 0;
}
.top_concept_ttl_ja {
	margin-bottom: 38px;
	line-height: 1.477;
	font-family: 'Zen Kaku Gothic New', sans-serif;
	font-size: 44px;
	font-weight: 700;
}
.top_concept_ttl_en {
	display: inline-block;
	position: relative;
	padding-right: 9px;
}
.top_concept_ttl_en::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 100%;
	width: 40px;
	border-bottom: 1px solid #000;
}
.top_concept_txt {
	margin-bottom: 42px;
	line-height: 1.882;
	font-size: 17px;
	font-weight: bold;
}
.top_concept_img {
	float: right;
	width: 510px;
	min-height: 530px; /* scrollreveal.min.js 対応 */
}
.top_concept_img_list {
	display: grid;
	grid-template-rows: auto auto;
	grid-template-columns: 245px 245px; /* ← 固定幅指定 */
	gap: 20px; /* お好みで */
}
.top_concept_img_list_item:nth-child(1) {
	grid-column: 1 / 3; /* 上段で2列分を跨ぐ */
}

@-webkit-keyframes concept_ticker {
	from {
		background-position: 0 0;
	}
	to {
		background-position: -1002px 0; /* 画像幅1枚分 */
	}
}
@keyframes concept_ticker {
	from {
		background-position: 0 0;
	}
	to {
		background-position: -1002px 0; /* 画像幅1枚分 */
	}
}

.top_oem {
	width: 1200px;
	margin: 0 auto 165px;
}
.top_oem_ttl {
	margin-bottom: 60px;
	line-height: 1;
}
.top_oem_inner {
}
.top_oem_detail {
	float: right;
	width: 625px;
}
.top_oem_txt {
	margin-bottom: 25px;
	padding-top: 28px;
	line-height: 1.882;
	font-size: 17px;
	font-weight: bold;
}
.top_oem_txt h3,
.top_oem_txt p {
	margin-bottom: 21px;
}
.top_oem_txt h3 {
	font-size: inherit;
	font-weight: inherit;
}
.top_oem_txt :last-child {
	margin-bottom: 0;
}
.top_oem_btn {
}
.top_oem_main_img {
	float: left;
	min-height: 345px; /* scrollreveal.min.js 対応 */
}
.top_oem_sub_img {
	clear: both;
	min-height: 310px; /* scrollreveal.min.js 対応 */
	padding-top: 90px;
}
.top_oem_sub_img_list {
	display: flex;
	margin: 0 -13px;
}
.top_oem_sub_img_list_item {
	flex: 0 0 auto;
	width: 25%;
	max-width: 100%;
	padding: 0 13px;
}
.top_oem_result {
	min-height: 280px; /* scrollreveal.min.js 対応 */
	margin-top: 68px;
}
.top_oem_result_ttl {
	position: relative;
	z-index: 100;
	margin-bottom: 47px;
	line-height: 1;
	font-family: 'Zen Kaku Gothic New', sans-serif;
	font-size: 22px;
	font-weight: 700;
	text-align: center;
}
.top_oem_result_ttl::before {
	content: '';
	position: absolute;
	top: 13px;
	left: 0;
	z-index: -100;
	width: 100%;
	height: 10px;
	border-width: 1px 1px 0;
	border-style: solid;
	border-color: #000;
	border-radius: 5px 5px 0 0;
}
.top_oem_result_ttl span {
	display: inline-block;
	padding: 0 25px;
	background: #fff;
}
.top_oem_result_list {
	display: flex;
	margin: 0 -13px;
}
.top_oem_result_list_item {
	flex: 0 0 auto;
	width: 25%;
	max-width: 100%;
	padding: 0 13px;
}

.top_factory_group {
	margin-bottom: 160px;
	padding: 140px 0 150px;
	background: #f6f6f6;
}

.top_factory {
	margin-bottom: 81px;
}
.top_factory_ttl {
	position: relative;
	width: 1200px;
	margin: 0 auto 71px;
	line-height: 1;
}
.top_factory_ttl::after {
	content: '';
	position: absolute;
	top: 22px;
	right: calc(100% + 50px);
	left: -200%;
	border-bottom: 1px solid #000;
}
.top_factory_img {
	height: 560px;
	margin-bottom: 110px;
	background: url(/shared/img/pc/top_factory_img_bg.png) repeat-x 0 0;
	-webkit-animation: factory_ticker 50s linear infinite;
	animation: factory_ticker 50s linear infinite;
}

/*
.top_factory_img_list {
	display: grid;
	grid-template-rows: repeat(2, 1fr);
	grid-template-columns: 210fr 375fr 350fr 645fr;
	gap: 40px; 固定
	aspect-ratio: 1700 / 560; 固定gapでもOK
}

.top_factory_img_list_item img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.top_factory_img_list_item:nth-child(1) { grid-row: 1 / 3; grid-column: 1; }
.top_factory_img_list_item:nth-child(2) { grid-row: 1 / 3; grid-column: 2; }
.top_factory_img_list_item:nth-child(3) { grid-row: 1; grid-column: 3; }
.top_factory_img_list_item:nth-child(4) { grid-row: 2; grid-column: 3; }
.top_factory_img_list_item:nth-child(5) { grid-row: 1 / 3; grid-column: 4; }
*/

.top_factory_inner {
	width: 1200px;
	margin: 0 auto;
}
.top_factory_logo {
	float: left;
}
.top_factory_detail {
	float: right;
	width: 950px;
	padding-top: 29px;
}
.top_factory_txt {
	margin-bottom: 42px;
	padding-right: 10px;
	line-height: 2;
	font-size: 16px;
	font-weight: bold;
}
.top_factory_txt h3,
.top_factory_txt p {
	margin-bottom: 12px;
}
.top_factory_txt h3 {
	font-size: inherit;
	font-weight: inherit;
}
.top_factory_txt :last-child {
	margin-bottom: 0;
}
.top_factory_btn {
}

@-webkit-keyframes factory_ticker {
	from {
		background-position: 0 0;
	}
	to {
		background-position: -2175px 0; /* 画像幅1枚分 */
	}
}
@keyframes factory_ticker {
	from {
		background-position: 0 0;
	}
	to {
		background-position: -2175px 0; /* 画像幅1枚分 */
	}
}

.top_gallery {
	width: 1200px;
	min-height: 409px; /* scrollreveal.min.js 対応 */
	margin: 0 auto 72px;
}
.top_gallery_ttl {
	position: relative;
	z-index: 100;
	margin-bottom: 47px;
	line-height: 0;
	text-align: center;
}
.top_gallery_ttl::before {
	content: '';
	position: absolute;
	top: 14px;
	left: 0;
	z-index: -100;
	width: 100%;
	height: 10px;
	border-width: 1px 1px 0;
	border-style: solid;
	border-color: #000;
	border-radius: 5px 5px 0 0;
}
.top_gallery_ttl img {
	padding: 0 25px;
	background: #f6f6f6;
}
.top_gallery_inner {
}
.top_gallery_list {
	display: flex;
	margin: 0 -13px 35px;
}
.top_gallery_list_item {
	flex: 0 0 auto;
	width: 25%;
	max-width: 100%;
	padding: 0 13px;
}
.top_gallery_list_img {
	margin-bottom: 22px;
}
.top_gallery_list_ttl {
	line-height: 1.8;
	font-size: 15px;
	font-weight: bold;
}
.top_gallery_list_ttl a {
	color: inherit;
}
.top_gallery_btn {
	line-height: 0;
	text-align: center;
}
.top_gallery_btn a {
	display: inline-block;
	width: 120px;
	padding: 11px 0;
	border-bottom: 1px solid #000;
}

.top_shopping {
	width: 1200px;
	min-height: 139px; /* scrollreveal.min.js 対応 */
	margin: 0 auto;
}
.top_shopping_ttl {
	position: relative;
	z-index: 100;
	margin-bottom: 49px;
	line-height: 1;
	font-family: 'Zen Kaku Gothic New', sans-serif;
	font-size: 20px;
	font-weight: 700;
	text-align: center;
}
.top_shopping_ttl::before {
	content: '';
	position: absolute;
	top: 12px;
	left: 0;
	z-index: -100;
	width: 100%;
	height: 10px;
	border-width: 1px 1px 0;
	border-style: solid;
	border-color: #000;
	border-radius: 5px 5px 0 0;
}
.top_shopping_ttl span {
	display: inline-block;
	padding: 0 25px;
	background: #f6f6f6;
}
.top_shopping_inner {
}
.top_shopping_list {
	display: flex;
	margin: 0 -12px;
}
.top_shopping_list_item {
	flex: 0 0 auto;
	width: 20%;
	padding: 0 12px;
}
.top_shopping_list_item a {
	display: block;
	height: 70px;
	background: #000;
	line-height: 70px;
	color: #fff;
	font-size: 16px;
	font-weight: bold;
	text-align: center;
}

.top_showcase {
	width: 1200px;
	min-height: 505px; /* scrollreveal.min.js 対応 */
	margin: 0 auto 224px;
}
.top_showcase_detail {
	float: left;
	width: 600px;
	padding-top: 2px;
}
.top_showcase_ttl {
	margin-bottom: 31px;
	line-height: 0;
}
.top_showcase_ttl_ja {
	margin-bottom: 32px;
	line-height: 1;
	font-family: 'Zen Kaku Gothic New', sans-serif;
	font-size: 44px;
	font-weight: 700;
	/* letter-spacing: -0.025em; */
}
.top_showcase_ttl_ja span {
	margin-right: 0.125em;
	letter-spacing: -0.035em;
}
.top_showcase_ttl_en {
	display: inline-block;
	position: relative;
	padding-right: 9px;
}
.top_showcase_ttl_en::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 100%;
	width: 40px;
	border-bottom: 1px solid #000;
}
.top_showcase_txt {
	margin-bottom: 12px;
	line-height: 1.882;
	font-size: 17px;
	font-weight: bold;
}
.top_showcase_txt h3,
.top_showcase_txt p {
	margin-bottom: 24px;
}
.top_showcase_txt h3 {
	font-size: inherit;
	font-weight: inherit;
}
.top_showcase_txt :last-child {
	margin-bottom: 0;
}
.top_showcase_btn {
}
.top_showcase_img {
	float: right;
	width: 510px;
}
.top_showcase_img_list {
	display: grid;
	grid-template-rows: auto auto;
	grid-template-columns: 245px 245px; /* ← 固定幅指定 */
	gap: 20px; /* お好みで */
}
.top_showcase_img_list_item:nth-child(1) {
	grid-column: 1 / 3; /* 上段で2列分を跨ぐ */
}

.top_blog {
	width: 1200px;
	min-height: 408px; /* scrollreveal.min.js 対応 */
	margin: 0 auto;
}
.top_blog_head {
	position: relative;
	margin-bottom: 58px;
}
.top_blog_ttl {
	position: relative;
	line-height: 1;
}
.top_blog_ttl::after {
	content: '';
	position: absolute;
	top: 17px;
	right: calc(100% + 50px);
	left: -200%;
	border-bottom: 1px solid #000;
}
.top_blog_btn {
	position: absolute;
	top: 5px;
	right: 0;
}
.top_blog_inner {
}
.top_blog_list {
	display: flex;
	margin: 0 -18px;
}
.top_blog_list_item {
	flex: 0 0 auto;
	width: 33.333333%;
	max-width: 100%;
	padding: 0 18px;
}
.top_blog_list_img {
	margin-bottom: 21px;
}
.top_blog_list_ttl {
	display: -webkit-box;
	overflow: hidden;
	-webkit-box-orient: vertical;
	margin-bottom: 5px;
	line-height: 1.8;
	font-size: 16px;
	font-weight: bold;
	-webkit-line-clamp: 2;
}
.top_blog_list_ttl a {
	color: inherit;
}
.top_blog_list_date {
	display: block;
	line-height: 1;
	color: #888;
	font-weight: bold;
}


/* ---------------------------------------------------------
	Lower
---------------------------------------------------------- */
.l-page_header {
	position: relative;
	margin: 0 50px;
	margin-bottom: 105px;
	padding: 20px 0;
	text-align: center;
	transition: all 0.3s ease;
}
.l-page_header::before,
.l-page_header::after {
	content: '';
	position: absolute;
	left: 0;
	width: 100%;
	height: 10px;
	border-style: solid;
	border-color: #000;
}
.l-page_header::before {
	top: 0;
	border-width: 1px 1px 0;
	border-radius: 5px 5px 0 0;
}
.l-page_header::after {
	bottom: 0;
	border-width: 0 1px 1px;
	border-radius: 0 0 5px 5px;
}
.l-page_header_mod {
	background: #f6f6f6;
}
.l-page_header_inner {
	display: flex;
	align-items: center;
	justify-content: center;
	max-width: 1200px;
	height: 300px;
	margin: 0 auto;
	padding-top: 5px;
}

/* media queries */
@media screen and (max-width: 1300px) {
	.l-page_header {
		width: 1200px;
		margin: 0 auto 105px;
	}
}

.page_ttl_group {
	padding-top: 20px;
}
.page_ttl_en {
}
.page_ttl {
	margin-bottom: 4px;
	line-height: 1.3;
	/* font-family: 'Zen Kaku Gothic New', sans-serif; */
	font-size: 35px;
	font-weight: bold;
	letter-spacing: 0.05em;
}
.page_ttl span {
	margin-left: 15px;
	font-size: 20px;
}

.bread_wrap {
}
.bread {
}
.bread_item {
	display: inline-block;
	position: relative;
	/* float: left; */
	font-size: 12px;
	font-weight: 500;
}
.bread_item.-home {
}
.bread_item.-home::before {
}
.bread_item::after {
	content: '\f105';
	position: relative;
	margin: 0 10px;
	line-height: 1;
	font-family: 'Font Awesome 6 Pro';
	font-size: 13px;
	font-style: normal;
	font-weight: 300;
	font-variant: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: auto;
}
.bread_item a {
	color: inherit;
}
.bread_item:last-child::after {
	content: none;
}
.bread_item:last-child a {
	color: inherit;
	pointer-events: none;
}


/* ================================================================================
	Entry
================================================================================ */
.entry {
	margin-bottom: 50px;
}
.entry:last-of-type {
	margin: 0;
}

.entry_thumb {
	margin-bottom: 40px;
}

.no_entry_txt {
	padding: 60px 0;
	text-align: center;
}

.entry_meta {
	margin: 50px 0 0;
	padding: 15px 0;
	border-width: 1px 0;
	border-style: solid;
	border-color: #ddd;
	line-height: 20px;
	font-size: 11px;
	text-align: right;
}
.entry_meta_detail {
	float: right;
}
.entry_meta_date {
	color: #888;
}
.entry_meta_cat {
	margin-left: 10px;
}
.entry_meta_cat::before {
	content: 'a';
	margin-right: 5px;
	font-family: 'CONDENSEicon';
}
.entry_share {
	float: left;
}
.entry_share_list {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.entry_share_list_item {
	padding: 0 4px 0 0;
}
.entry_share_list_item * {
	vertical-align: top !important;
}
/* Facebook レイアウト崩れ対応 */
.entry_share_list_item .fb_iframe_widget span,
.entry_share_list_item .fb_iframe_widget iframe {
	display: block !important;
	min-width: 157px !important;
	height: 20px !important;
}

.entry_body, .mceContentBody {
	line-height: 2.2;
	font-size: 16px;
}

.entry_body h2, .mceContentBody h2,
.entry_body h3, .mceContentBody h3,
.entry_body h4, .mceContentBody h4,
.entry_body h5, .mceContentBody h5 {
	clear: both;
}
.entry_body h2 img, .mceContentBody h2 img,
.entry_body h3 img, .mceContentBody h3 img,
.entry_body h4 img, .mceContentBody h4 img,
.entry_body h5 img, .mceContentBody h5 img {
	vertical-align: middle;
}

/* entry_ttl */
.entry_ttl, .entry_body h2, .mceContentBody h2 {
	position: relative;
	margin: 80px 0 30px;
	line-height: 1.6;
	font-size: 30px;
	font-weight: bold;
}
.entry_ttl::before, .entry_body h2::before, .mceContentBody h2::before {
	content: '';
	position: absolute;
	top: 22px;
	right: calc(100% + 50px);
	left: -200%;
	border-bottom: 1px solid #000;
}
.entry_ttl a, .entry_body h2 a, .mceContentBody h2 a {
	color: inherit;
}

/* h3 */
.h3, .entry_body h3, .mceContentBody h3 {
	position: relative;
	margin: 2.2em 0 1.2em;
	padding: 0 0 14px 20px;
	border-bottom: 1px solid #000;
	line-height: 1.6;
	font-size: 22px;
	font-weight: bold;
}
.h3::before, .entry_body h3::before, .mceContentBody h3::before {
	content: '';
	position: absolute;
	top: 6px;
	left: 0;
	width: 4px;
	height: 22px;
	background: #39406e;
}

/* h4 */
.h4, .entry_body h4, .mceContentBody h4 {
	position: relative;
	margin: 1.8em 0 0.6em;
	padding: 0 0 0 25px;
	font-size: 17px;
	font-weight: bold;
}
.h4::before, .entry_body h4::before, .mceContentBody h4::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 0;
	width: 13px;
	height: 13px;
	border: 4px solid #97423e;
	border-radius: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

/* h5 */
.h5, .entry_body h5, .mceContentBody h5 {
	margin: 1.8em 0 0.8em;
	padding-bottom: 5px;
	line-height: 1.6;
	font-size: 16px;
	font-weight: bold;
}

.entry_body h2 + h3, .mceContentBody h2 + h3,
.entry_body h2 + h4, .mceContentBody h2 + h4,
.entry_body h2 + h5, .mceContentBody h2 + h5 {
	margin-top: 0;
}

.entry_body p, .entry_body hr, .entry_body table,
.mceContentBody p, .mceContentBody hr, .mceContentBody table {
	margin: 0 0 1em 0;
}
.entry_body hr,
.mceContentBody hr {
	height: 1px;
	margin: 30px 0;
	border-width: 1px 0 0;
	border-style: dashed;
	border-color: #ccc; /* edit */
}
.entry_body strong,
.mceContentBody strong {
}
.entry_body code,
.mceContentBody code {
	display: inline-block;
	padding: 4px 5px;
	border: 1px solid #d6d6d6;
	border-radius: 2px;
	background: #f8f8f8;
	font-family: inherit;
}
.entry_body * code,
.mceContentBody * code {
	margin: 0 5px;
}

.entry_body table,
.mceContentBody table {
	width: 100%;
}
.entry_body table th, .entry_body table td,
.mceContentBody table th, .mceContentBody table td {
	padding: 10px;
	border: 1px solid #ccc; /* edit */
	text-align: left;
	vertical-align: top;
}
.entry_body table th p, .entry_body table td p,
.mceContentBody table th p, .mceContentBody table td p {
	margin: 10px 0;
}
.entry_body table th,
.mceContentBody table th {
	background: #f7f7f7; /* edit */
}
.entry_body table thead th,
.mceContentBody table thead th {
	padding: 8px 10px;
	text-align: center;
}

.entry_body .tbl_std th, .mceContentBody .tbl_std th {
	width: 30%;
}

.entry_body .tbl_underline th, .entry_body .tbl_underline td,
.mceContentBody .tbl_underline th, .mceContentBody .tbl_underline td {
	border-width: 0 0 1px;
	background: none;
}

.entry_body .tbl_fixed,
.mceContentBody .tbl_fixed {
	table-layout: fixed;
}

.entry_body ul, .entry_body ol,
.mceContentBody ul, .mceContentBody ol {
	margin: 10px 0;
}
.entry_body ul ul, .entry_body ol ul,
.mceContentBody ul ul, .mceContentBody ol ul {
	margin: 5px 0 5px 2em !important;
}
.entry_body ul ol, .entry_body ol ol,
.mceContentBody ul ol, .mceContentBody ol ol {
	margin: 5px 0 !important;
}
.entry_body ol,
.mceContentBody ol {
	counter-reset: num;
	list-style: none;
}
.entry_body ol > li,
.mceContentBody ol > li {
	position: relative;
	padding-left: 2em;
}
.entry_body ol > li::before,
.mceContentBody ol > li::before {
	content: counter(num) '. ';
	counter-increment: num;
	position: absolute;
	top: 0;
	left: 0;
	font-weight: bold;
}
.entry_body .list_disc li, .entry_body .list_check li,
.mceContentBody .list_disc li, .mceContentBody .list_check li {
	font-size: 14px;
}
.entry_body .list_disc li::before, .entry_body .list_check li::before,
.mceContentBody .list_disc li::before, .mceContentBody .list_check li::before {
	position: relative;
	top: 1px;
	left: 0;
	margin-right: 10px;
	line-height: 1;
	font-family: 'Font Awesome 6 Pro';
	font-style: normal;
	font-weight: 400;
	font-variant: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: auto;
}
.entry_body .list_disc ul, .entry_body .list_check ul,
.mceContentBody .list_disc ul, .mceContentBody .list_check ul {
	margin: 5px 0 5px 25px !important;
}
.entry_body .list_disc li::before,
.mceContentBody .list_disc li::before {
	content: '\f111';
}
.entry_body .list_check li::before,
.mceContentBody .list_check li::before {
	content: '\f00c';
}
.entry_body .list_l li,
.mceContentBody .list_l li {
	margin-bottom: 15px;
}
.entry_body .list_l ul,
.mceContentBody .list_l ul {
	margin: 15px 0 15px 2em !important;
}
.entry_body img,
.mceContentBody img {
	max-width: 100%;
	height: auto;
}
.entry > .entry_ttl:first-child,
.entry_body .entry_ttl:first-child, .mceContentBody .entry_ttl:first-child,
.entry_body h2:first-child, .mceContentBody h2:first-child,
.entry_body h3:first-child, .mceContentBody h3:first-child,
.entry_body h4:first-child, .mceContentBody h4:first-child,
.entry_body h5:first-child, .mceContentBody h5:first-child,
.entry_body p:first-child, .mceContentBody p:first-child,
.entry_body ul:first-child, .mceContentBody ul:first-child,
.entry_body ol:first-child, .mceContentBody ol:first-child,
.entry_body dl:first-child, .mceContentBody dl:first-child,
.entry_body hr:first-child, .mceContentBody hr:first-child,
.entry_body table:first-child, .mceContentBody table:first-child,
.entry_body div:first-child, .mceContentBody div:first-child {
	margin-top: 0;
}
.entry_body .entry_ttl:last-child, .mceContentBody .entry_ttl:last-child,
.entry_body h2:last-child, .mceContentBody h2:last-child,
.entry_body h3:last-child, .mceContentBody h3:last-child,
.entry_body h4:last-child, .mceContentBody h4:last-child,
.entry_body h5:last-child, .mceContentBody h5:last-child,
.entry_body p:last-child, .mceContentBody p:last-child,
.entry_body ul:last-child, .mceContentBody ul:last-child,
.entry_body ol:last-child, .mceContentBody ol:last-child,
.entry_body dl:last-child, .mceContentBody dl:last-child,
.entry_body hr:last-child, .mceContentBody hr:last-child,
.entry_body table:last-child, .mceContentBody table:last-child,
.entry_body div:last-child, .mceContentBody div:last-child {
	margin-bottom: 0;
}


/* ---------------------------------------------------------
Wordpress editor style
---------------------------------------------------------- */
.entry_body .aligncenter, .entry_body div.aligncenter,
.mceContentBody .aligncenter, .mceContentBody div.aligncenter {
	display: block;
	margin-right: auto;
	margin-left: auto;
}
.entry_body .alignleft,
.mceContentBody .alignleft {
	float: left;
}
.entry_body .alignright,
.mceContentBody .alignright {
	float: right;
}
.entry_body .wp-caption,
.mceContentBody .wp-caption {
	margin: 10px;
	padding-top: 4px;
	border-top: 1px dotted #d1d1d1;
	border-radius: 3px;
	background-color: #f3f3f3;
	text-align: center;
}
.entry_body .wp-caption img,
.mceContentBody .wp-caption img {
	margin: 0;
	padding: 0;
	border: 0 none;
}
.entry_body .wp-caption p.wp-caption-text,
.mceContentBody .wp-caption p.wp-caption-text {
	margin: 0;
	padding: 0 4px 5px;
	line-height: 17px;
	font-size: 11px;
}
.entry_body dl.gallery-item dt.gallery-icon,
.mceContentBody dl.gallery-item dt.gallery-icon {
	margin: 0;
	padding: 0;
	border: none;
	background: none;
	font-size: 13px;
	font-weight: normal;
}
.entry_body dl.gallery-item dt.gallery-icon::after,
.mceContentBody dl.gallery-item dt.gallery-icon::after {
	display: none;
}
.entry_body dl.gallery-item dt.gallery-icon img,
.mceContentBody dl.gallery-item dt.gallery-icon img {
	margin-bottom: 0;
}
.entry_body dl.gallery-item dd.gallery-caption,
.mceContentBody dl.gallery-item dd.gallery-caption {
	margin: 4px 0;
}


/* ================================================================================
	Pager
================================================================================ */
/* pager */
.pager {
	margin-top: 50px;
	text-align: center;
}
.pager a, .pager span {
	display: inline-block;
	min-width: 32px;
	height: 32px;
	margin: 0 4px;
	padding: 0 7px;
	border: 1px #333 solid;
	background: #fff;
	line-height: 30px;
	color: #333;
	font-size: 12px;
}
.pager span.extend {
	padding: 0;
	border: none;
	background: none;
}
.pager a {
	color: inherit;
	text-decoration: none;
}
.pager a:hover {
	opacity: 1;
	background: #333;
	color: #fff;
}
.pager .current {
	background: #333;
	color: #fff;
}
.pager .first, .pager .last, .pager .previouspostslink, .pager .nextpostslink {
	padding: 0 10px;
}

/* single */
.single_pager {
	margin-top: 40px;
}
.single_pager_item.-prev {
	float: left;
}
.single_pager_item.-next {
	float: right;
}


/* ================================================================================
	Blog
================================================================================ */
.blog_list {
	margin-bottom: 30px;
}
.blog_list_item {
	margin-bottom: 60px;
}
.blog_list_body {
	position: relative;
}
.blog_list_ttl {
	margin-top: 0;
}
.list_blog_inner {
	overflow: hidden;
	position: relative;
}
.blog_list_img {
	float: left;
	width: 240px;
	margin-right: 30px;
}
.blog_list_img a {
	display: block;
	overflow: hidden;
	height: 180px;
}
.blog_list_img.-blank a {
	position: relative;
	background: #eee;
}
.blog_list_img.-blank a::before,
.blog_list_img.-blank a::after {
	position: absolute;
	top: 50%;
	left: 50%;
	line-height: 1;
	color: #ccc;
	font-family: 'Font Awesome 6 Pro';
	font-size: 35px;
	font-style: normal;
	font-weight: 300;
	font-variant: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: auto;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}
.blog_list_img.-blank a::before {
	content: '\f03e';
}
.blog_list_img.-blank a::after {
	content: '\f715';
}

.blog_list_txt {
	overflow: hidden;
	margin-bottom: 15px;
	line-height: 2;
	font-size: 15px;
}
.blog_list_more {
	position: absolute;
	right: 0;
	bottom: 0;
	font-size: 13px;
}
.blog_list_more a {
}
.blog_list_more i {
	margin-left: 10px;
}


/* ================================================================================
	Gallery
================================================================================ */
/* list */
.gallery_list {
	display: flex;
	flex-wrap: wrap;

	margin: 0 -15px;
}
.gallery_list_item {
	flex: 0 0 auto;
	width: 33.333333%;
	max-width: 100%;

	padding: 0 15px 30px;
}
.gallery_list_img {
	margin-bottom: 10px;
}
.gallery_list_ttl {
	line-height: 1.8;
	font-size: 15px;
	font-weight: bold;
}
.gallery_list_ttl a {
	color: inherit;
}

/* detail */
.single-gallery .l-content_inner {
	width: 1100px;
}
.gallery_detail {
	margin-bottom: 20px;
}

.gallery_detail_main {
	overflow: hidden;
	position: relative;
	height: 825px;
	margin-bottom: 10px;
	line-height: 0;
	text-align: center;
}

.gallery_detail_control .prev,
.gallery_detail_control .next {
	position: absolute;
	top: 50%;
	z-index: 1000;
	-webkit-transition: all 0.3s ease;
	transition: all 0.3s ease;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
.gallery_detail_control .prev {
	left: 15px;
}
.gallery_detail_control .next {
	right: 15px;
}
.gallery_detail_control .prev:hover,
.gallery_detail_control .next:hover {
	opacity: 0.7;
}
.gallery_detail_control .prev::before,
.gallery_detail_control .next::before {
	opacity: 0.75;
	line-height: 1;
	color: #333;
	font-family: 'Font Awesome 6 Pro';
	font-size: 40px;
	font-style: normal;
	font-weight: 300;
	font-variant: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: auto;
}
.gallery_detail_control .prev::before {
	content: '\f053';
}
.gallery_detail_control .next::before {
	content: '\f054';
}

.gallery_detail_control .prev span,
.gallery_detail_control .next span {
	display: none;
}

.gallery_detail_loading {
	position: absolute;
	top: 50%;
	z-index: 100;
	width: 100%;
	margin-top: -7px;
}

.gallery_detail_screen {
	width: 100%;
	height: 100%;
}
.gallery_detail_screen a,
.gallery_detail_screen span {
	display: inline-block;
}
.gallery_detail_screen a {
	transition: all 0.3s ease;
}
.gallery_detail_screen a:hover {
	opacity: 0.85;
}
.gallery_detail_screen a img { /* chromeで画像左側に隙間が入るため */
	display: block;
}
.gallery_detail_main .image-wrapper {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	line-height: 0;
}
.gallery_detail_sub{
}
.gallery_detail_sub ul {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;

	margin: 0 -6px;
}
.gallery_detail_sub ul li {
	-ms-flex: 0 0 12.5%;
	flex: 0 0 12.5%;
	width: 12.5%;
	max-width: 12.5%;

	padding: 0 6px 12px;
}
.gallery_detail_sub ul li a {
	opacity: 0.6;
	transition: all 0.3s ease;
}
.gallery_detail_sub ul li a:hover { opacity: 0.8; }
.gallery_detail_sub ul li.selected a { opacity: 1; }
.gallery_detail_sub ul li img { image-rendering: high-quality; }

.gallery_detail_meta {
	margin-bottom: 60px;
}
.gallery_detail_meta th,
.gallery_detail_meta td {
	padding: 15px 10px 10px !important;
	border-color: #d6d6d6 !important;
	border-top: none !important;
	border-right: none !important;
	border-left: none !important;
	background: none !important;
	/* font-size: 15px; */
}
.gallery_detail_meta th {
	width: 12.5%;
	background: none !important;
}
.gallery_detail_meta td {
	font-weight: bold !important;
}

.gallery_shopping {
	margin-top: 85px;
}
.gallery_shopping_ttl {
	position: relative;
	z-index: 100;
	margin-bottom: 49px;
	line-height: 1;
	font-family: 'Zen Kaku Gothic New', sans-serif;
	font-size: 20px;
	font-weight: 700;
	text-align: center;
}
.gallery_shopping_ttl::before {
	content: '';
	position: absolute;
	top: 12px;
	left: 0;
	z-index: -100;
	width: 100%;
	height: 10px;
	border-width: 1px 1px 0;
	border-style: solid;
	border-color: #000;
	border-radius: 5px 5px 0 0;
}
.gallery_shopping_ttl span {
	display: inline-block;
	padding: 0 25px;
	background: #fff;
}
.gallery_shopping_list {
	display: flex;
	margin: 0 -12px;
}
.gallery_shopping_list_item {
	flex: 0 0 auto;
	width: 20%;
	padding: 0 12px;
}
.gallery_shopping_list_item a {
	display: block;
	height: 70px;
	background: #000;
	line-height: 70px;
	color: #fff;
	font-size: 16px;
	font-weight: bold;
	text-align: center;
}

/* ================================================================================
	Contact
================================================================================ */
.form_header {
	margin-bottom: 80px;
}

.form table th, .form table td {
	border-color: #e5e5e5; /* edit */
	border-right: none;
	border-left: none;
	vertical-align: middle;
}
.form table th {
	width: 30%;
	padding: 15px 20px;
	background: none !important;
	line-height: 1.5;
	text-align: left;
}
.form table td {
	padding: 20px 20px 20px 0;
}
.form table tr:first-child th, .form table tr:first-child td {
	padding-top: 0;
	border-top: none;
}

.form table th.va_top {
	padding-top: 15px;
	vertical-align: top;
}

.form input[type='text'], .form input[type='tel'], .form input[type='email'], .form select, .form textarea {
	display: block;
	height: 30px;
	padding: 3px 5px;
	border: 1px solid #ccc;
	border-radius: 1px;
	background: #fff;
	line-height: 1.42857;
	color: #474747;
	-webkit-transition: all 0.15s ease-in-out;
	transition: all 0.15s ease-in-out;
}
.form input[type='text']:focus, .form input[type='tel']:focus, .form input[type='email']:focus, .form select:focus, .form textarea:focus {
	outline: 0;
	border-color: #333;
}
.form select {
	/* height: 30px; */
}
.form textarea {
	height: auto;
}
.form input[type='radio'], .form input[type='checkbox'] {
	position: relative;
	top: 2px;
	margin-right: 5px;
}
.form ul li {
	margin-bottom: 5px;
}
.form ul li label {
	cursor: pointer;
}
.form ul li:last-child {
	margin-bottom: 0;
}
.form .submessage {
	color: #707070;
	font-size: 10px;
}
.form .require {
	padding-left: 5px;
	color: #dc3545;
}
.form .error {
	padding-top: 5px;
	color: #dc3545;
}

.form .form_footer {
	margin: 0;
	padding-top: 20px;
	text-align: center;
}
.form .form_footer input {
	width: 100px;
	height: 35px;
	margin: 0 5px;
	background: #aaa;
	color: #fff;
}
.form .form_footer input.-primary {
	background: #333;
}
.form .form_footer input:hover, .form .form_footer input:active {
	opacity: 0.8;
	-webkit-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
.form .form_footer .ajax-loader {
	display: block;
	margin: 20px auto 0;
	line-height: 1;
}


/* ================================================================================
	Override
================================================================================ */
/* side_nav */
.side_nav_ttl {
	font-family: 'CaboRounded';
	font-size: 25px;
	font-weight: 700;
	letter-spacing: 0.1em;
}
.side_nav_ttl::after {
	height: 1px;
	background: #000;
}
.side_nav_list,
.side_nav_list li a {
	border-color: #ddd;
}
.side_nav_list li a::after {
	color: inherit;
}


/* entry */
.entry_body hr {
	border-color: #ccc;
}

.entry_body strong,
.mceContentBody strong {
	color: inherit;
}

.entry_body table th, .entry_body table td,
.mceContentBody table th, .mceContentBody table td {
	border-color: #ccc;
}
.entry_body table th {
	background: #f7f7f7;
}

.entry_body ol > li::before,
.mceContentBody ol > li::before,
.entry_body .list_disc li::before, .entry_body .list_check li::before,
.mceContentBody .list_disc li::before, .mceContentBody .list_check li::before {
	color: #000;
}


/* pager */
.pager a, .pager span {
	border-color: #000;
	color: #000;
}
.pager a:hover {
	background: #000;
}
.pager .current {
	background: #000;
}


/* form */
.form table th, .form table td {
	border-color: #e5e5e5;
}

.form input[type='text'], .form input[type='tel'], .form input[type='email'], .form select, .form textarea {
	border-color: #bbb;
}
.form input[type='text']:focus, .form input[type='tel']:focus, .form input[type='email']:focus, .form select:focus, .form textarea:focus {
	border-color: #000;
}

.form .form_footer {
	padding-top: 40px;
}
.form .form_footer input.-primary {
	width: 220px;
	height: 60px;
	background: #000;
	font-size: 16px;
	font-weight: bold;
}