@charset "utf-8";

/* --------------------------------------------------------
	ベース
-------------------------------------------------------- */
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;
	font: inherit;
	font-size: 100%;
	vertical-align: baseline;
}
article, aside, details, figcaption, figure,
footer, header, main, menu, nav, section {
	display: block;
}
html {
	line-height: 1;
}
ul, ol {
	list-style-type: none;
}
table {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
}
caption, th, td {
	text-align: left;
	font-weight: normal;
	vertical-align: middle;
}
q, blockquote {
	quotes: none;
}

q:before, q:after, blockquote:before, blockquote:after {
	content: "";
	content: none;
}
a img {
	border: none;
}
img {
	vertical-align: bottom;
	border: none;
	max-width: 100%;
	height: auto;
}
img[src*=".svg"] {
	width: 100%;
}
a {
	color: inherit;
	text-decoration: none;
}
*,
:before,
:after {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
input,
button,
select,
textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	font: inherit;
	border: none;
	border-radius: 0;
	outline: none;
}
textarea {
	resize: vertical;
}
input[type='checkbox'],
input[type='radio'] {
	display: none;
}
input[type='submit'],
input[type='button'],
label,
button,
select {
	cursor: pointer;
}
select::-ms-expand {
	display: none;
}


/* --------------------------------------------------------
	フォントと背景
-------------------------------------------------------- */
html {
	font-size: 62.5%;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
}
body {
	font-family: "Noto Sans JP", sans-serif;
	color: #fff;
	font-size: 1.8em;
	font-weight: 400;
	background: url("../img/cmn/pattern01.jpg") repeat;
	letter-spacing: 0.1em;
	line-height: 1.6;
}

/* フォント */
.ff_yakuHan { font-family: YakuHanJP, sans-serif; }
.ff_serif { font-family: "Noto Serif JP", serif; }
.bold { font-weight: 700; }
.heavy { font-weight: 900; }
.tal { text-align: left; }
.tac { text-align: center; }
.tar { text-align: right; }

@media screen and (max-width: 768px) {
body { font-size: 1.6em; }
}
@media screen and (max-width: 480px) {
body { font-size: 3.5vw; }
}

/* --------------------------------------------------------
	リンク
-------------------------------------------------------- */
a {
	color: inherit;
	transition: .5s;
}
a:hover { opacity: 0.5; }
::-moz-selection {
	color: #fff;
	background: #4b5252;
}
::selection {
	color: #fff;
	background: #4b5252;
}

/* リンク
-------------------------------------------------------- */
a.underline {
	text-decoration: underline;
}
a.underline:hover {
	opacity: 1;
	text-decoration: none;
}

/* アンカーリンク
-------------------------------------------------------- */
.anchor {
	margin-top: -84px;
	padding-top: 84px;
}
@media screen and (max-width: 768px) {
.anchor {
	margin-top: -65px;
	padding-top: 65px;
}
}


/* --------------------------------------------------------
	共通
-------------------------------------------------------- */
/* パーツ
-------------------------------------------------------- */
/* コンテンツ系 */
.inner {
	max-width: 1500px;
	width: 92%;
	margin: auto;
}
.inner.mw1298 { max-width: 1298px; }
@media screen and (max-width: 768px) {
.inner.is_wide { width: 100%; }
}

/* iframe */
.iframe { position: relative; }
.iframe.youtube { padding-top: 56.25%; }
.iframe iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

/* flex系 */
.flex {
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
}
.nowrap { flex-wrap: nowrap; }
.fd_c {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	flex-direction: column;
}
.fd_rr {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	flex-direction: row-reverse;
}
.ai_fs {
	-webkit-box-align: start;
	align-items: flex-start;
}
.ai_fe {
	-webkit-box-align: end;
	align-items: flex-end;
}
.ai_c {
	-webkit-box-align: center;
	align-items: center;
}
.jc_fs {
	-webkit-box-pack: start;
	justify-content: flex-start;
}
.jc_fe {
	-webkit-box-pack: end;
	justify-content: flex-end;
}
.jc_c {
	-webkit-box-pack: center;
	justify-content: center;
}
.jc_sb {
	-webkit-box-pack: justify;
	justify-content: space-between;
}
.jc_sa {
	justify-content: space-around;
}
.order1 {
	-ms-flex-order: 1;
	-webkit-order: 1;
	order: 1;
}
.order2 {
	-ms-flex-order: 2;
	-webkit-order: 2;
	order: 2;
}


/* --------------------------------------------------------
	アニメーション
-------------------------------------------------------- */
/* ローディング */
#loading {
	width: 100%;
	height: calc(var(--vh, 1vh)* 100);
	background: #fff;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 20;
}
.loading_logo {
	max-width: 200px;
	width: 35%;
}

.trigger {
	opacity: 0;
}
/* 下から上へ */
.animation.animation01 {
	animation: fadeup .8s ease forwards;
}
/* 左から右へ */
.animation.animation02 {
	animation: faderight .8s ease forwards;
}
/* 右から左へ */
.animation.animation03 {
	animation: fadeleft .8s ease forwards;
}

@keyframes fadeup{
	from {
		opacity: 0;
		transform: translateY(2em);
	}
	
	to {
		opacity: 1;
		transform: translateY(0);
	}
}
@keyframes faderight{
	from {
		opacity: 0;
		transform: translateX(-2em);
	}
	
	to {
		opacity: 1;
		transform: translateX(0);
	}
}
@keyframes fadeleft{
	from {
		opacity: 0;
		transform: translateX(2em);
	}
	
	to {
		opacity: 1;
		transform: translateX(0);
	}
}


/* --------------------------------------------------------
	見出し
-------------------------------------------------------- */
.c-title01 {
	font-size: 2.8rem;
	margin: 0 0 40px;
}
@media screen and (max-width: 768px) {
.c-title01 {
	font-size: 2.2rem;
	margin: 0 0 24px;
}
}
@media screen and (max-width: 480px) {
.c-title01 {
	font-size: 4.3vw;
}
}


/* --------------------------------------------------------
	ボタン
-------------------------------------------------------- */
.c-btn01 {
	font-size: 1.6rem;
	display: -webkit-box;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	flex-direction: column;
	-webkit-box-align: start;
	align-items: flex-start;
	-webkit-box-pack: start;
	justify-content: flex-start;
}
.c-btn01 .arrow {
	width: 115%;
	height: 1px;
	background: #b3b3b3;
	margin: 4px 0 0;
	position: relative;
	transition: .5s;
}
.c-btn01 .arrow::before,
.c-btn01 .arrow::after {
	content: "";
	width: 1px;
	height: 8px;
	background: #b3b3b3;
	position: absolute;
	right: 2px;
}
.c-btn01 .arrow::before {
	bottom: -5px;
	rotate: -115deg;
}
.c-btn01 .arrow::after {
	top: -5px;
	rotate: 115deg;
}
.c-btn01:hover { opacity: 1; }
.c-btn01:hover .arrow { width: 140%; }
@media screen and (max-width: 768px) {
.c-btn01 { font-size: 1.4rem; }
}
@media screen and (max-width: 480px) {
.c-btn01 { font-size: 3.5vw; }
}



/* --------------------------------------------------------
	リスト
-------------------------------------------------------- */
.c-note01 > li {
	padding: 0 0 0 16px;
	position: relative;
}
.c-note01 > li:not(:last-child) {
	margin: 0 0 16px;
}
.c-note01 > li::before {
	content: "";
	width: 5px;
	height: 5px;
	background: #b3b3b3;
	position: absolute;
	top: 12px;
	left: 0;
}
@media screen and (max-width: 768px) {
.c-note01 > li::before {
	top: 10px;
}
}
@media screen and (max-width: 480px) {
.c-note01 > li::before {
	top: 2.25vw;
}
}
/* --------------------------------------------------------
	アコーディオン 
-------------------------------------------------------- */
@media screen and (max-width: 1024px) {
}
@media screen and (max-width: 768px) {
}


/* --------------------------------------------------------
	テーブル
-------------------------------------------------------- */
.c-tbl01 { border-top: solid 1px #b3b3b3; }
.c-tbl01 th,
.c-tbl01 td {
	border-bottom: solid 1px #b3b3b3;
	padding: 40px 0;
}
.c-tbl01 th { width: 270px; }
@media screen and (max-width: 1024px) {
.c-tbl01 th,
.c-tbl01 td {
	width: 100%;
	display: block;
	padding: 20px 0;
}
.c-tbl01 th {
	border-bottom: none;
	padding-bottom: 0;
}
.c-tbl01 td {
	padding: 16px 0 24px;
}
}
@media screen and (max-width: 768px) {
}

.c-tbl02 th,
.c-tbl02 td {
	padding: 16px 0;
}
.c-tbl02 tr:not(:last-child) th,
.c-tbl02 tr:not(:last-child) td {
	border-bottom: solid 1px #b3b3b3;
}
.c-tbl02 th {
	width: 178px;
}
@media screen and (max-width: 768px) {
.c-tbl02 th {
	width: 25%;
}
}
@media screen and (max-width: 480px) {
.c-tbl02 th {
	width: 24vw;
}
}

/* --------------------------------------------------------
	パンくず
-------------------------------------------------------- */

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


/* --------------------------------------------------------
	余白
-------------------------------------------------------- */


/* --------------------------------------------------------
	PC SP切替
-------------------------------------------------------- */
.is_sp { display: none; }
@media screen and (max-width: 768px) {
	.is_pc { display: none; }
	.is_sp { display: block; }
}


/* --------------------------------------------------------
	ヘッダー
-------------------------------------------------------- */
header {
	height: 80px;
	display: -webkit-box;
	display: flex;
	-webkit-box-pack: justify;
	justify-content: space-between;
	padding: 20px 3.125% 0;
	position: -webkit-sticky;
	position: sticky;
	top: 0;
	z-index: 100;
}
header.is_fixed {
	width: 100%;
	position: fixed;
}
.hd_logo {
	max-width: 212px;
}
.hd_logo.is_top {
	opacity: 0;
	visibility: hidden;
	transition: .5s;
}
.is_scroll .hd_logo.is_top {
	opacity: 1;
	visibility: inherit;
}
.hd_nav ul {
	display: -webkit-box;
	display: flex;
}
.hd_nav ul li:not(:last-child) {
	margin: 0 clamp(24px, 0.72px + 2.27vw, 28px) 0 0;
}
.hd_nav ul li a,
.hamb_nav ul li a {
	display: inline-block;
	position: relative;
}
.hd_nav ul li a::after,
.hamb_nav ul li a::after {
	content: "";
	width: 0;
	height: 1px;
	background: #fff;
	position: absolute;
	bottom: -2px;
	left: 0;
	transition: .5s;
}
.hd_nav ul li a:hover,
.hamb_nav ul li a:hover { opacity: 1; }
.hd_nav ul li a:hover::after,
.hamb_nav ul li a:hover::after { width: 100%; }
.hd_nav ul li a {
	font-size: clamp(14px, -9.28px + 2.27vw, 18px);
}
.hamb {
	width: 64px;
	background: none;
	display: none;
	-webkit-box-align: center;
	align-items: center;
	-webkit-box-pack: center;
	justify-content: center;
	margin: 0;
	padding: 0 12px;
}
.hamb .icon,
.hamb .icon span {
	width: 100%;
}
.hamb .icon {
	height: 14px;
	position: relative;
}
.hamb .icon span {
	height: 1px;
	background: #fff;
	display: block;
	position: absolute;
	left: 0;
	transition: .5s;
}
.hamb .icon span:nth-child(1) {
	top: 0;
}
.hamb .icon span:nth-child(2) {
	top: 100%;
}
.hamb_menu {
	max-width: 330px;
	width: 100%;
	min-height: 100vh;
	height: 100%;
	background: #999;
	overflow: auto;
	padding: 0 3.125% 100px;
	position: fixed;
	top: 0;
	right: -330px;
	transition: .5s;
	z-index: 0;
}
.hamb_menu .hamb_head {
	height: 80px;
	display: -webkit-box;
	display: flex;
	-webkit-box-pack: justify;
	justify-content: space-between;
	padding: 20px 0 0;
}
.hamb_menu .hamb_head .hd_logo { opacity: 0; }
.hamb_menu .hamb_head .hamb {
	width: 40px;
	padding: 0;
}
.hamb_menu .hamb_head .hamb .icon span:nth-child(1),
.hamb_menu .hamb_head .hamb .icon span:nth-child(2) { top: 6px; }
.hamb_menu .hamb_head .hamb .icon span:nth-child(1) { transform: rotate(25deg); }
.hamb_menu .hamb_head .hamb .icon span:nth-child(2) { transform: rotate(-25deg); }
.hamb_nav {
	border-top: solid 1px #b3b3b3;
	padding: 40px 0 0;
}
.hamb_sns {
	margin: 36px 0 0;
}
.hamb_sns ul li {
	max-width: 14px;
}
@media screen and (min-width: 1025px) {
header {
	-webkit-box-align: center;
	align-items: center;
}
}
@media screen and (max-width: 1024px) {
header {
	padding: 20px calc(3.125% - 12px) 0 3.125%;
}
.hd_nav { display: none; }
.hamb {
	display: -webkit-box;
	display: flex;
}
.is_hamb_open { overflow: hidden; }
.is_hamb_open .hamb_menu { right: 0; }

}
@media screen and (min-width: 769px) {
.hamb_nav ul li:not(:last-child) {
	margin: 0 0 24px;
}
}
@media screen and (max-width: 768px) {
header {
	height: auto;
	padding: 2.6666% 0 0 2.6666%;
}
.hd_logo {
	max-width: 140px;
	width: 30%;
}
.hamb {
	max-width: calc(24px + 5.3332%);
	padding: 0 2.6666%;
}
.hamb .icon {
	height: 8px;
}
.hamb_menu .hamb_head {
	height: auto;
	padding: 2.6666% 0 3.2%;
}
.hamb_menu .hamb_head .hd_logo { opacity: 1; }
.hamb_menu .hamb_head .hamb {
	width: 24px;
}
.hamb_nav {
	padding: 6.9% 0 0 4.5%;
}
.hamb_nav ul {
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
}
.hamb_nav ul li {
	width: 50%;
	margin-top: 5.333%;
}
.hamb_nav ul li:nth-child(-n + 2) {
	margin-top: 0;
}
.hamb_sns {
	margin: 4.3% 0 0;
	padding-left: 4.5%;
}
.is_hamb_open .hamb_menu { max-width: inherit; }
}


/* --------------------------------------------------------
	フッター
-------------------------------------------------------- */
.ft_contact .inner {
	border-bottom: solid 1px #b3b3b3;
	padding: 11% 0;
}
.ft_contact .bg_wrap {
	max-width: 1000px;
	background: #999;
	margin: auto;
}
.ft_contact .bg_wrap > div {
	font-size: clamp(14px, 6.544px + 0.97vw, 18px);
	width: 50%;
	display: -webkit-box;
	display: flex;
	-webkit-box-align: center;
	align-items: center;
	padding: 5.6% 7%;
}
.ft_contact .head {
	line-height: 2.7;
	position: relative;
}
.ft_contact .head::after {
	content: "";
	width: 1px;
	height: 55%;
	background: #b3b3b3;
	position: absolute;
}
.ft_contact .link ul {
	width: 100%;
}
.ft_contact .link ul li:not(:last-child) {
	margin: 0 0 8%;
}
.ft_contact .link ul li.is_mail a {
	display: -webkit-box;
	display: flex;
	-webkit-box-align: center;
	align-items: center;
}
.ft_contact .link ul li.is_mail .arrow {
	width: 28%;
	height: 1px;
	background: #b3b3b3;
	margin: 0 0 0 16px;
	position: relative;
	transition: .5s;
}
.ft_contact .link ul li.is_mail a:hover { opacity: 1; }
.ft_contact .link ul li.is_mail a:hover .arrow {
	width: 35%;
}
.ft_contact .link ul li.is_mail .arrow::before,
.ft_contact .link ul li.is_mail .arrow::after {
	content: "";
	width: 1px;
	height: 8px;
	background: #b3b3b3;
	position: absolute;
	right: 2px;
}
.ft_contact .link ul li.is_mail .arrow::before {
	bottom: -5px;
	rotate: -115deg;
}
.ft_contact .link ul li.is_mail .arrow::after {
	top: -5px;
	rotate: 115deg;
}
@media screen and (min-width: 769px) {
.ft_contact .head {
	-webkit-box-pack: end;
	justify-content: flex-end;
}
.ft_contact .head::after {
	top: calc(50% - 24.5%);
	right: -1px;
}
}
@media screen and (max-width: 768px) {
.ft_contact .inner {
	padding: 19% 0;
}
.ft_contact .bg_wrap {
	-webkit-box-pack: center;
	justify-content: center;
}
.ft_contact .bg_wrap > div {
	font-size: 1.6rem;
	width: 72%;
	-webkit-box-pack: center;
	justify-content: center;
	padding: 5.6% 0;
}
.ft_contact .bg_wrap .head {
	padding-top: 8%;
}
.ft_contact .head::after {
	width: 100%;
	height: 1px;
	bottom: -1px;
	left: 0;
}
.ft_contact .bg_wrap .link {
	padding-bottom: 10%;
}
.ft_contact .link ul { width: auto; }
.ft_contact .link ul li:not(:last-child) {
	margin: 0 0 2.5%;
}
.ft_contact .link ul li.is_mail .arrow { width: 6em; }
.ft_contact .link ul li.is_mail a:hover .arrow { width: 7em; }
}
@media screen and (max-width: 480px) {
.ft_contact .bg_wrap > div {
	font-size: 3.5vw;
}
.ft_contact .link ul li.is_mail .arrow { width: 4em; }
.ft_contact .link ul li.is_mail a:hover .arrow { width: 5em; }
}

.ft_wrap { padding: 80px 0 24px; }
.ft_wrap .logo_wrap { font-weight: 500; }
.ft_logo,
.ft_wrap .logo_wrap address { margin: 0 0 32px; }
.ft_bnr {
	max-width: 290px;
	margin: 32px 0 0;
}
.ft_bnr li {
	width: 48%;
	margin-right: 4%;
}
.ft_bnr li:nth-child(2n) {
	margin-right: 0;
}
.ft_wrap .link_wrap { flex: 1 1 auto; }
.ft_nav ul:not(:last-child) { margin: 0 48px 0 0; }
.ft_nav ul li:not(:last-child) { margin: 0 0 16px; }
#copyright {
	font-size: 1.6rem;
	width: 100%;
	text-align: right;
	margin: 56px 0 0;
}
@media screen and (max-width: 768px) {
.ft_wrap { padding: 18% 0 24px; }
.ft_wrap .logo_wrap {
	width: 100%;
	margin: 0 0 10%;
}
.ft_logo,
.ft_wrap .logo_wrap address { margin: 0 0 16px; }
.ft_logo { font-size: 1.8rem; }
.ft_bnr {
	margin: 24px 0 0;
}
.ft_nav {
	-webkit-box-pack: start;
	justify-content: flex-start;
}
.ft_nav ul { width: 48%; }
.ft_nav ul:not(:last-child) { margin: 0 4% 0 0; }
.ft_nav ul li:not(:last-child) { margin: 0 0 8px; }
#copyright {
	font-size: 1.4rem;
	text-align: center;
	margin: 21% 0 0;
}
}
@media screen and (max-width: 480px) {
.ft_logo { font-size: 4.5vw; }
#copyright { font-size: 3.2vw; }
}


/* --------------------------------------------------------
	トップページ
-------------------------------------------------------- */
/* First View
-------------------------------------------------------- */
.top_firstView {
	display: -webkit-box;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	flex-direction: column;
}
.wide_layout .head {
	width: 19%;
	display: -webkit-box;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	flex-direction: column;
}
.wide_layout .head .btn_wrap {
	display: -webkit-box;
	display: flex;
	margin-top: auto;
}
.wide_layout .list_wrap {
	width: calc(81% - 25% + 50vw);
	margin-right: calc(50% - 50cqi);
}
.wide_layout .list_wrap .btn_wrap { display: none; }
@media screen and (max-width: 1024px) {
.wide_layout .inner { flex-wrap: wrap; }
.wide_layout .head,
.wide_layout .list_wrap {
	width: 100%;
	margin-right: 0;
}
.wide_layout .head { text-align: center; }
.wide_layout .head .btn_wrap { display: none; }
.wide_layout .list_wrap .btn_wrap {
	display: -webkit-box;
	display: flex;
	-webkit-box-pack: center;
	justify-content: center;
	margin: 8% 0 0;
}
}

/* MV
-------------------------------------------------------- */
#mv {
	height: calc(100svh - 69px);
	flex: 1 1 auto;
	position: relative;
}
#mv .scroll_down {
	display: -webkit-box;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	flex-direction: column;
	-webkit-box-align: center;
	align-items: center;
	position: absolute;
	right: 3%;
	bottom: 3.5%;
	z-index: 2;
}
#mv .scroll_down .text {
	color: #b3b3b3;
	font-size: 1.4rem;
	letter-spacing: 0.3em;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	margin: 0 0 4px;
}
#mv .scroll_down .arrow {
	font-size: 0;
	max-width: 6px;
	animation: updown 2s infinite ease-in-out;
	position: relative;
}
@keyframes updown {
	0% {
		transform: translate(0, 0);
	}
	50% {
		transform: translate(0, 10px);
	}
	100% {
		transform: translate(0, 0);
	}
}
.swiper.mv_list,
.swiper.mv_list .swiper-wrapper,
.swiper.mv_list .swiper-slide,
.swiper.mv_list .swiper-slide .img {
	height: 100%;
}
.swiper.mv_list .swiper-slide .img {
	background-color: #999;
	overflow: hidden;
	position: relative;
}
.swiper.mv_list .swiper-slide .img img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	object-fit: cover;
}
@media screen and (max-width: 768px) {
#mv {
	height: 100svh;
}
}
@media screen and (max-width: 480px) {
#mv .scroll_down .text {
	font-size: 2.9vw;
}
#mv .scroll_down .arrow {
	max-width: 4px;
}
}

/* NEWS
-------------------------------------------------------- */
.top_news {
	padding: 24px 0;
}
.top_news .inner {
	line-height: 1.2;
}
.top_news .inner > div {
	width: 49%;
	display: -webkit-box;
	display: flex;
}
.top_news .inner > div:not(:last-child) {
	margin: 0 2% 0 0;
}
.top_news .head {
	width: 90px;
	margin: 0 16px 0 0;
	padding: 0 14px 0 0;
	position: relative;
}
.top_news .head::after {
	content: "";
	width: 1px;
	height: 100%;
	background: #b3b3b3;
	position: absolute;
	top: 0;
	right: 0;
}
.top_news .list_wrap {
	width: calc(100% - 90px);
}
.top_news_list li:not(:last-child) {
	margin: 0 0 2.1%;
}
.top_news_list li a {
	display: -webkit-box;
	display: flex;
	position: relative;
}
.top_news_list li a:hover {
	opacity: 1;
	background-size: 100% 1px;
}
.top_news_list .top_news_date span,
.top_news_list .top_news_title span {
	background: linear-gradient(90deg, #fff, #fff) no-repeat left bottom;
	background-size: 0 1px;
	transition: .5s;
}
.top_news_list li a:hover .top_news_date span,
.top_news_list li a:hover .top_news_title span {
	background-size: 100% 1px;
}
.top_news_list .top_news_date {
	margin: 0 16px 0 0;
}
div:has(.is_pc) .top_news .animation01 { animation: fadeup .8s ease forwards; }

@media screen and (max-width: 1024px) {
.top_news .inner > div {
	width: 100%;
}
.top_news .inner > div:not(:last-child) {
	margin: 0 0 24px;
}
}
@media screen and (max-width: 768px) {
.top_news {
	padding: 15% 0 0;
}
.top_news .head {
	width: 83px;
	margin: 0 3.125% 0 0;
	padding: 0 3.125% 0 0;
}
.top_news .list_wrap {
	width: calc(100% - 83px);
}
.top_news_list li:not(:last-child) {
	margin: 0 0 4.2%;
}
.top_news_list li a { display: block; }
.top_news_list .top_news_date {
	margin: 0 0 4px;
}
}
@media screen and (max-width: 480px) {
.top_news .head {
	width: 18vw;
}
.top_news .list_wrap {
	width: calc(100% - 18vw);
}
}

/* PICKUP
-------------------------------------------------------- */
.pickupWorks_wrap {
	width: 100%;
	height: 100vh;
	overflow: hidden;
	position: relative;
}
.pickupWorks_wrap a:hover {
	opacity: 1;
}
.pickupWorks_detail_title {
	font-size: 2.6rem;
	letter-spacing: 0.3em;
}
.pickupWorks_detail_meta {
	color: #b3b3b3;
	margin: 8% 0 0;
}
.pickupWorks_detail_meta .works_detail_tag > span,
.pickupWorks_detail_meta .works_detail_category > span {
	text-transform: capitalize;
}
.pickupWorks_detail_meta .works_detail_tag > span:not(:last-child)::after,
.pickupWorks_detail_meta .works_detail_category > span:not(:last-child)::after {
	content: ".";
}
.pickupWorks_wrap img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	object-fit: cover;
	z-index: 0;
}
@media screen and (min-width: 769px) {
.pickupWorks_wrap .text_wrap {
	width: 100%;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 1;
}
.pickupWorks_detail {
	max-width: 300px;
	width: 100%;
	background: rgba(0, 0, 0, .5);
	display: inline-block;
	opacity: 0;
	padding: 3% 2.5%;
	transition: .5s;
}
.pickupWorks_wrap a:hover .pickupWorks_detail { opacity: 1; }
.pickupWorks_detail_meta {
	display: -webkit-box;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	flex-direction: column;
}
.pickupWorks_detail_meta > span:not(:last-child) {
	margin: 0 0 2.4%;
}
}
@media screen and (max-width: 768px) {
.pickupWorks_wrap {
	height: auto;
}
.pickupWorks_wrap {
	margin: 0 0 40px;
}
.pickupWorks_wrap .text_wrap {
	padding: 16px 0 0;
}
.pickupWorks_detail_title {
	font-size: 2rem;
}
.pickupWorks_detail_meta {
	font-size: 1.4rem;
	margin: 4px 0 0;
}
.pickupWorks_detail_meta > span:not(:last-child)::after {
	content: ".";
}
.pickupWorks_wrap .img {
	padding-top: 120%;
	position: relative;
}
}
@media screen and (max-width: 480px) {
.pickupWorks_detail_title {
	font-size: 4.3vw;
}
.pickupWorks_detail_meta {
	font-size: 3.5vw;
}
}


/* CONCEPT
-------------------------------------------------------- */
#top_concept {
	padding: 15% 0 17%;
}
#top_concept .text {
	font-size: 2.2rem;
	letter-spacing: 0.3em;
	line-height: 3.2;
}
@media screen and (max-width: 768px) {
#top_concept .text {
	font-size: 1.8rem;
	line-height: 3;
}
}
@media screen and (max-width: 480px) {
#top_concept .text {
	font-size: 4vw;
}
}


/* WORKS
-------------------------------------------------------- */
#top_works {
	container-type: inline-size;
	padding: 15% 0 0;
}


/* VOICE
-------------------------------------------------------- */
#top_voice {
	container-type: inline-size;
	padding: 15% 0;
}


/* COMPANY
-------------------------------------------------------- */
#top_company {
	padding: 14.375% 0;
	position: relative;
}
#top_company::before {
	content: "";
	width: 100%;
	height: 100%;
	background: #000;
	opacity: .2;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
#top_company .text_wrap {
	width: 50%;
	background: rgba(0, 0, 0, .5);
	padding: 13% 7.3%;
	position: relative;
	z-index: 2;
}
#top_company .text_wrap > .text {
	text-align: justify;
	text-justify: inter-ideograph;
	line-height: 3.3;
}
#top_company .btn_wrap {
	margin: 4% 3.5% 0 0;
}
#top_company .btn_wrap .c-btn01 {
	color: #ccc;
}
#top_company .btn_wrap .c-btn01 .arrow,
#top_company .btn_wrap .c-btn01 .arrow::before,
#top_company .btn_wrap .c-btn01 .arrow::after {
	background: #b3b3b3;
}
.infinity_scroll,
.infinity_scroll ul {
	display: -webkit-box;
	display: flex;
}
.infinity_scroll {
	width: 100%;
	height: 100%;
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 0;
}
.infinity_scroll ul {
	animation: infinity-scroll 60s infinite linear 0.5s both;
}
.infinity_scroll ul li {
	width: calc(100vw / 2);
	height: 100%;
	position: relative;
}
.infinity_scroll ul li img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
@keyframes infinity-scroll {
	from {
		transform: translateX(0);
	}
	to {
		transform: translateX(-100%);
	}
}
@media screen and (max-width: 1024px) {
#top_company .text_wrap {
	width: 100%;
}
}
@media screen and (max-width: 768px) {
#top_company .text_wrap .text {
	line-height: 2.3;
}
.infinity_scroll ul li {
	width: 100vw;
}
}
@media screen and (max-width: 480px) {
}


/* --------------------------------------------------------
	下層ページ
-------------------------------------------------------- */
.page_head {
	padding: 7.5% 0 0;
}
.page_head.is_simple { padding-bottom: 5.625%; }
.page_head.is_simple .c-title01 { margin: 0; }
.page_head.is_not_text .page_title {
	margin: 0;
	padding: 0 0 7.8%;
	position: relative;
}
.page_head.is_not_text .page_title::after {
	content: "";
	max-width: 650px;
	width: 100%;
	height: 1px;
	background: #b3b3b3;
	position: absolute;
	bottom: 0;
	left: 0;
}
.page_head .page_text {
	letter-spacing: 0.3em;
	line-height: 2.7777;
}
.page_head .page_text > div {
	border-bottom: solid 1px #b3b3b3;
	display: inline-block;
	padding: 0 0 6.25%;
}
.paga_link {
	padding: 3.5% 0;
}
.paga_link dl {
	font-size: 1.6rem;
	line-height: 1.2;
}
.paga_link dl > div {
	display: -webkit-box;
	display: flex;
}
.paga_link dl dt {
	margin: 0 16px 0 0;
	padding: 0 14px 0 0;
	position: relative;
}
.paga_link dl dt::after {
	content: "";
	width: 1px;
	height: 100%;
	background: #b3b3b3;
	position: absolute;
	top: 0;
	right: 0;
}
.paga_link ul,
.paga_link ul li {
	display: -webkit-box;
	display: flex;
}
.paga_link ul {
	flex-wrap: wrap;
	margin-top: -8px;
}
.paga_link ul li {
	display: -webkit-box;
	display: flex;
	-webkit-box-align: center;
	align-items: center;
	margin-top: 8px;
}
.paga_link ul li:not(:last-child)::after{
	content: "";
	width: 3px;
	height: 3px;
	background: #b3b3b3;
	border-radius: 50%;
	display: inline-block;
	margin: 0 10px;
}
.paga_link ul li a {
	color: #b3b3b3;
	background: linear-gradient(90deg, #fff, #fff) no-repeat left bottom;
	background-size: 0 1px;
}
.paga_link ul li.is_active a,
.paga_link ul li a:hover {
	color: #fff;
	background-size: 100% 1px;
	opacity: 1;
}
@media screen and (max-width: 768px) {
.page_head {
	padding: 15% 0 0;
}
.page_head.is_simple { padding-bottom: 13.3333%; }
.page_head.is_not_text .page_title {
	padding: 0 0 14.9%;
}
.page_head .c-title01 {
	margin: 0 0 12%;
}
.page_head .page_text {
	line-height: 2;
}
.page_head .page_text > div {
	display: block;
	padding: 0 0 17%;
}
.paga_link {
	padding: 9% 0 7.4%;
}
.paga_link dl {
	font-size: 1.4rem;
}
}
@media screen and (max-width: 480px) {
.paga_link dl {
	font-size: 3.4vw;
}
}

.c-page_layout {
	container-type: inline-size;
	margin-bottom: 7%;
}
.c-page_layout.is_mb0 { margin-bottom: 0; }
.c-page_layout .c-page_layout_head {
	max-width: 400px;
	width: 40%;
	text-align: center;
}
.c-page_layout.is_small .c-page_layout_head {
	max-width: 250px;
	text-align: left;
}
.c-page_layout .c-page_layout_head .c-title01 {
	font-size: 1.8rem;
	letter-spacing: 0.3em;
}
.c-page_layout .c-page_layout_content {
	color: #4d4d4d;
	font-size: 1.6rem;
	background: #ccc;
	width: calc(60% - 25% + 50vw);
	margin-right: calc(50% - 50cqi);
}
.c-page_layout .c-page_layout_content:not(.is_wide) {
	padding: 2.5% 3.5%;
}
.c-page_layout .c-page_layout_content:not(.is_wide) > div { max-width: 750px; }
@media screen and (max-width: 768px) {
.c-page_layout,
.c-page_layout.is_small .inner {
	flex-wrap: wrap;
}
.c-page_layout {
	margin-bottom: 14.6666%;
}
.c-page_layout .c-page_layout_head,
.c-page_layout .c-page_layout_content {
	width: 100%;
}
.c-page_layout .c-page_layout_head,
.c-page_layout.is_small .c-page_layout_head {
	max-width: inherit;
}
.c-page_layout.is_small .c-page_layout_head {
	text-align: center;
}
.c-page_layout .c-page_layout_head .c-title01 {
	font-size: 1.6rem;
}
.c-page_layout .c-page_layout_content {
	font-size: 1.4rem;
	margin-right: 0;
}
.c-page_layout .c-page_layout_content:not(.is_wide) {
	padding: 9.6% 6.4%;
}
}
@media screen and (max-width: 480px) {
.c-page_layout .c-page_layout_head .c-title01 {
	font-size: 3.5vw;
}
.c-page_layout .c-page_layout_content {
	font-size: 3.2vw;
}
}


/* --------------------------------------------------------
	アーカイブ系
-------------------------------------------------------- */
.pager { margin: 4.5% 0 0; }
.wp-pagenavi {
	display: -webkit-box;
	display: flex;
	-webkit-box-align: center;
	align-items: center;
	-webkit-box-pack: center;
	justify-content: center;
}
.wp-pagenavi a,
.wp-pagenavi span {
	color: #b3b3b3;
	background: linear-gradient(90deg, #fff, #fff) no-repeat left bottom;
	background-size: 0 1px;
	border: none;
	line-height: 1.4;
	margin: 0 10px;
}
.wp-pagenavi .current,
.wp-pagenavi a:hover {
	color: #fff;
	background-size: 100% 1px;
	opacity: 1;
}
.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink,
.wp-pagenavi .previouspostslink::before,
.wp-pagenavi .nextpostslink::before {
	width: 100%;
	border: none;
	display: block;
	overflow: hidden;
	text-align: center;
	text-indent: -999999999999px;
	position: relative;
}
.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink {
	max-width: 50px;
	width: 8%;
	background: none;
}

.wp-pagenavi .previouspostslink::before,
.wp-pagenavi .nextpostslink::before {
	content:"";
	background: url("../img/cmn/arrow01_gy.svg") no-repeat;
	background-size: contain;
	display: inline-block;
	padding-top: 12.6666%;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
}
.wp-pagenavi .previouspostslink::before {
	scale: -1 1;
}
/*.wp-pagenavi .extend:last-of-type { display: none; }*/
@media screen and (max-width: 768px) {
.pager { margin: 12% 0 0; }
.wp-pagenavi a,
.wp-pagenavi span {
	margin: 0 4px;
}
}


/* --------------------------------------------------------
	EVENT
-------------------------------------------------------- */
.news_title { letter-spacing: 0.3em; }
.news_meta {
	color: #b3b3b3;
	display: -webkit-box;
	display: flex;
	margin: .5% 0 0;
}
.news_meta .news_category {
	margin: 0 0 0 min(1.25vw, 20px);
}
.news_meta .news_category > span { text-transform: capitalize; }
.news_meta .news_category > span:not(:last-child)::after { content: " . "; }
.news_list li {
	width: 33%;
	margin-top: 5.375%;
	margin-right: 0.5%;
}
.news_list .img {
	background-color: #999;
	overflow: hidden;
	padding-top: 66.603773584%;
	position: relative;
	transition: .5s;
	z-index: 1;
}
.news_list .img img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	transition: .5s;
	object-fit: cover;
}
.news_list .text_wrap { padding: 16px 4% 0; }
.news_list .news_title,
.news_list .news_meta { font-size: clamp(14px, 3.104px + 1.06vw, 18px); }
.news_list li a:hover { opacity: 1; }
.news_list li a:hover .img img {
	scale: 1.1;
}
@media screen and (min-width: 1025px) {
.news_list li:nth-child(-n + 3) { margin-top: 0; }
.news_list li:nth-child(3n) { margin-right: 0; }
}
@media screen and (max-width: 1024px) {
.news_list li { width: 49.75%; }
.news_list li { margin-top: 7%; }
.news_list li:nth-child(-n + 2) { margin-top: 0; }
.news_list li:nth-child(2n) { margin-right: 0; }
}

@media screen and (max-width: 768px) {
.news_list li {
	margin-right: 0;
}
.news_list li {
	width: 100%;
}
.news_list li,
.news_list li:nth-child(-n + 2) {
	margin-top: 12%;
}
.news_list li:nth-child(1) {
	margin-top: 0;
}
.news_list .news_title,
.news_list .news_meta { font-size: 1.6rem; }
}
@media screen and (max-width: 480px) {
.news_list .news_title,
.news_list .news_meta { font-size: 3.5vw; }
}

/* 詳細
-------------------------------------------------------- */
#news.is_single,
#blog.is_single { padding: 7.5% 0 0; }
#news.is_single .btn_wrap,
#blog.is_single .btn_wrap {
	margin: 8.75% 0 0;
}
.article_news .article_head {
	width: 33%;
	display: -webkit-box;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	flex-direction: column;
}
.article_news .article_head .news_title {
	font-size: 2.4rem;
	letter-spacing: 0.3em;
}
.article_news .article_head .news_meta {
	margin: 2% 0 0;
}
.article_news .article_content {
	width: 63%;
}
.article_news .article_content::-webkit-scrollbar { width: 6px; }
.article_news .article_content::-webkit-scrollbar-track { background: none; }
.article_news .article_content::-webkit-scrollbar-thumb { background: #999; }
.article_news .article_content b,
.article_news .article_content strong {
	font-weight: 700;
}
.article_news .article_content a {
	text-decoration: underline;
}
.article_news .article_content a {
	opacity: 1;
	text-decoration: none;
}

.news_info {
	line-height: 2.2;
	margin: 18% 0 0;
}
.news_info > div {
	display: -webkit-box;
	display: flex;
}
.news_info > div:not(:last-child) {
	margin: 0 0 1.4%;
}
.news_info dt {
	width: 115px;
	position: relative;
}
.news_info dt::after {
	content: "";
	width: 1px;
	height: 15px;
	background: #b3b3b3;
	position: absolute;
	top: 13px;
	right: 0;
}
.news_info dd {
	width: calc(100% - 115px);
	padding: 0 0 0 28px;
}
.news_info a {
	text-decoration: underline;
}
.news_info a:hover {
	opacity: 1;
	text-decoration: none;
}
@media screen and (max-width: 1024px) {
.article_news .article_head,
.article_news .article_content {
	width: 100%;
}
.article_news .article_head .news_meta {
	margin: 1% 0 0;
}
.news_info {
	margin: 5% 0 0;
}
.news_info > div:not(:last-child) {
	margin: 0 0 .375%;
}
.article_news .article_content {
	margin: 8.5% 0 0;
}
}
@media screen and (min-width: 769px) {
.article_news .article_content {
	min-height: 420px;
	max-height: 45vh;
	overflow-y: auto;
}
}
@media screen and (max-width: 768px) {
#news.is_single,
#blog.is_single { padding: 15.2% 0 0; }
#news.is_single .btn_wrap,
#blog.is_single .btn_wrap {
	margin: 16% 0 0;
}
.article_news .article_head .news_title {
	font-size: 2rem;
}
.article_news .article_head .news_meta {
	margin: 2.4% 0 0;
}
.news_info dt::after {
	top: 11px;
}
.news_info {
	margin: 8.5% 0 0;
}
.article_news .article_content {
	margin: 9.6% 0 0;
}
}
@media screen and (max-width: 480px) {
.news_info dt {
	width: 24vw;
}
.news_info dt::after {
	height: 3.5vw;
	top: 2.5vw;
}
.news_info dd {
	width: calc(100% - 24vw);
	padding: 0 0 0 5%;
}
.article_voice .article_content {
	font-size: 3.5vw;
}
}


/* --------------------------------------------------------
	WORKS
-------------------------------------------------------- */
/* 一覧
-------------------------------------------------------- */
.works_list li a {
	width: 100%;
	height: 100%;
	display: -webkit-box;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	flex-direction: column;
	position: absolute;
	top: 0;
	left: 0;
}
.works_list li {
	position: relative;
}
.works_list.is_col2 li {
	width: 49.75%;
	margin-top: 0.3125%;
	margin-right: 0.3125%;
	padding-top: 31.9666%;
}
.works_list.is_col3 li {
	width: 33%;
	margin-top: 0.5%;
	margin-right: 0.5%;
	padding-top: 21.999978%;
}
.works_list .img {
	background-color: #999;
	overflow: hidden;
	position: relative;
	transition: .5s;
	z-index: 1;
}
.works_list .img img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	transition: .5s;
	object-fit: cover;
}
.works_list li a:hover { opacity: 1; }
.works_list li a:hover .img img {
	scale: 1.1;
}
.works_list .works_detail .works_detail_title {
	font-size: clamp(16px, -5.792px + 2.13vw, 24px);
	letter-spacing: 0.3em;
	padding: 1.5% 4% 0;
}
.works_list .works_detail .works_detail_meta {
	color: #b3b3b3;
	font-size: clamp(10px, -11.792px + 2.13vw, 18px);
	margin: -1% 0 0;
	padding: 0 4% 1.5%;
}
.works_list .works_detail_tag > span,
.works_list .works_detail_category > span {
	text-transform: capitalize;
}
.works_list .works_detail .works_detail_meta > span:not(:last-child)::after,
.works_list .works_detail_category > span:not(:last-child)::after {
	content: ".";
}

.works_list.is_col3 .works_detail .works_detail_meta {
	margin: -1.5% 0 0;
}
@media screen and (min-width: 769px) {
.works_list.is_col2 li:nth-child(-n + 2) {
	margin-top: 0;
}
.works_list.is_col2 li:nth-child(2n) {
	margin-right: 0;
}
.works_list.is_col3 li:nth-child(-n + 3) {
	margin-top: 0;
}
.works_list.is_col3 li:nth-child(3n) {
	margin-right: 0;
}
.works_list .img {
	flex-grow: 1;
}
.works_list .works_detail {
	width: 100%;
	display: grid;
	grid-template-rows: 0fr;
	transition: grid-template-rows .4s;
	overflow: hidden;
	transition: .5s;
	z-index: 0;
}
.works_list .works_detail > div {
	overflow: hidden;
}
.works_list li a:hover .works_detail {
	grid-template-rows: 1fr;
}
}
@media screen and (max-width: 768px) {
.works_list.is_col2 li {
	width: 100%;
	margin-top: 12%;
	margin-right: 0;
	padding-top: 0;
}
.works_list.is_col2 li:nth-child(1) {
	margin-top: 0;
}
.works_list.is_col3 li {
	width: 49.75%;
	margin-top: 8%;
	padding-top: 0;
}
.works_list.is_col3 li:nth-child(-n + 2) {
	margin-top: 0;
}
.works_list.is_col3 li:nth-child(2n) {
	margin-right: 0;
}
.works_list.is_col3 li:nth-child(n + 9) {
	display: none;
}
.works_list li a {
	position: relative;
}
.works_list .img {
	padding-top: 66.66666%;
}
.works_list .works_detail .works_detail_title {
	font-size: 2rem;
}
.works_list.is_col2 .works_detail .works_detail_title {
	padding-top: 3.2%;
}
.works_list .works_detail .works_detail_meta {
	font-size: 1.4rem;
	margin: 0;
}
}
@media screen and (max-width: 480px) {
.works_list .works_detail .works_detail_title {
	font-size: 4.3vw;
}
.works_list .works_detail .works_detail_meta {
	font-size: 3.5vw;
}
.works_list.is_col3 .works_detail .works_detail_title {
	padding: 1.5% 1% 0;
}
.works_list.is_col3 .works_detail .works_detail_meta {
	padding: 0 1%;
}
}

/* 詳細
-------------------------------------------------------- */
.article_works .article_head {
	height: 380px;
	padding: 150px 0 0;
	position: relative;
}
.article_works .article_head::after {
	content: "";
	width: 100%;
	height: 100%;
	background: #000;
	opacity: .5;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
.article_works .article_head img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	object-fit: cover;
	z-index: 0;
}
.article_works .article_head .inner {
	height: 100%;
	position: relative;
	z-index: 2;
}
.article_works .works_detail_title {
	font-size: 2.4rem;
	letter-spacing: 0.3em;
}
.article_works .works_detail_meta {
	color: #b3b3b3;
	margin: 24px 0 0;
}
.article_works .works_detail_meta > span:not(:last-child) {
	margin: 0 0 10px;
}
.article_works .works_detail_tag > span,
.article_works .works_detail_category > span {
	text-transform: capitalize;
}
.article_works .works_detail_category > span:not(:last-child)::after {
	content: ".";
}

.article_works .article_content {
	padding: 64px 0 0;
}
.article_works .article_content b,
.article_works .article_content strong {
	font-weight: 700;
}
.article_works .article_content a {
	text-decoration: underline;
}
.article_works .article_content a {
	opacity: 1;
	text-decoration: none;
}

.works_detail_desc {
	font-size: 1.6rem;
}
.works_detail_desc > div {
	max-width: 650px;
	width: 100%;
	line-height: 1.75;
}
.works_detail_gallery {
	margin: 72px 0 0;
}
.works_detail_gallery > div:not(:last-child) {
	margin: 0 0 0.3125%;
}
.works_detail_gallery .gallery_wrap img { width: 100%; }
.works_detail_gallery .gallery_wrap.type02 ul,
.works_detail_gallery .gallery_wrap.type03 ul,
.works_detail_gallery .gallery_wrap.type04 {
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
}
.works_detail_gallery .gallery_wrap.type02 ul li,
.works_detail_gallery .gallery_wrap.type03 ul li {
	margin-top: 0.3125%;
	margin-right: 0.3125%;
}
.works_detail_gallery .gallery_wrap.type02 ul li {
	width: 49.84375%;
}
.works_detail_gallery .gallery_wrap.type03 ul li {
	width: 33.125%;
}
.works_detail_gallery .gallery_wrap.type04 > div {
	width: 49.84375%;
	margin-right: 0.3125%;
}
.works_detail_gallery .gallery_wrap.type04 ul {
	height: 100%;
}
.works_detail_gallery .gallery_wrap.type04 ul li {
	height: 49.84375%;
	overflow: hidden;
	margin-bottom: 0.626889785%;
}
.works_detail_gallery .gallery_wrap.type04 ul li:last-child {
	margin-bottom: 0;
}
.works_detail_gallery .gallery_wrap.type04 ul li img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.works_detail_data,
.works_detail_before {
	font-size: 1.6rem;
}
.works_detail_data {
	margin: 80px 0 0;
}
.works_detail_data > dl > dt,
.works_detail_before > dl > dt {
	color: #b3b3b3;
	margin: 0 0 32px;
}
.works_detail_data dl dd dl > div {
	display: -webkit-box;
	display: flex;
}
.works_detail_data dl dd dl > div:not(:last-child) {
	margin: 0 0 24px;
}
.works_detail_data dl dd dl dt {
	width: 110px;
	position: relative;
}
.works_detail_data dl dd dl dt::after {
	content: "";
	width: 1px;
	height: 90%;
	background: #b3b3b3;
	position: absolute;
	top: 50%;
	right: -1px;
	translate: 0 -50%;
}
.works_detail_data dl dd dl dd {
	width: calc(100% - 110px);
	padding: 0 0 0 24px;
}
.works_detail_layout {
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
	margin: 80px 0 0;
}
.works_detail_layout .works_detail_data {
	margin-top: 0;
}
.works_detail_layout > div {
	width: 49.84375%;
	margin-right: 0.3125%;
}
.works_detail_layout > div:last-child {
	margin-right: 0;
}
.before_list_main .swiper-slide .img,
.before_list_thumb .swiper-slide .img {
	overflow: hidden;
	position: relative;
}
.before_list_main .swiper-slide .img img,
.before_list_thumb .swiper-slide .img img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	object-fit: cover;
}
.before_list_main .swiper-slide .img img {
	object-fit: contain;
}
.before_list_main .swiper-slide .img {
	background: #b3b3b3;
	padding-top: 66.563706563%;
}
.before_list_thumb {
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
}
.before_list_thumb .swiper-slide {
	width: 24.4%;
	margin-top: 0.8%;
	margin-right: 0.8%;
	cursor: pointer;
}
.before_list_thumb .swiper-slide .img {
	padding-top: 65.8%;
}

#modal {
	max-width: 1400px;
	width: 92%;
	background: #ccc;
	max-height: 92%;
	display: none;
	overflow: auto;
	padding: 3.28% 3.57%;
	position: fixed;
	z-index: 120;
}
.works_modal_head {
	color: #4d4d4d;
	font-size: 1.8rem;
	text-align: center;
	margin: 0 0 2%;
	position: relative;
}
.modal-close {
	width: 24px;
	cursor: pointer;
	position: absolute;
	top: 50%;
	right: 0;
	translate: 0 -50%;
}
.modal-close .icon,
.modal-close .icon span {
	width: 100%;
}
.modal-close .icon {
	height: 8px;
	position: relative;
}
.modal-close .icon span {
	height: 1px;
	background: #4d4d4d;
	display: block;
	position: absolute;
	left: 0;
	transition: .5s;
}
.modal-close .icon span:nth-child(1),
.modal-close .icon span:nth-child(2) {
	top: 3.5px;
}
.modal-close .icon span:nth-child(1) {
	transform: rotate(25deg);
}
.modal-close .icon span:nth-child(2) {
	transform: rotate(-25deg);
}
.works_modal_content {
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
	-webkit-box-align: start;
	align-items: flex-start;
}
.works_modal_content > div {
	width: 49.84375%;
	margin-right: 0.3125%;
}
.works_modal_content > div:last-child {
	margin-right: 0;
}
.modal-bg {
	width: 100%;
	height: 100%;
	background: #4d4d4d;
	display: none;
	opacity: .8;
	cursor: pointer;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 110;
}
.single_pager {
	margin: 118px 0 0;
}
.single_pager .text_link {
	color: #b3b3b3;
	font-size: 1.6rem;
}
.single_pager .text_link .inner > div {
	max-width: 430px;
	width: 100%;
	text-align: center;
	position: relative;
}

.single_pager .text_link .back,
.single_pager .text_link .prev .text,
.single_pager .text_link .next .text {
	background: linear-gradient(90deg, #fff, #fff) no-repeat left bottom;
	background-size: 0 1px;
}
.single_pager .text_link a:hover {
	color: #fff;
	opacity: 1;
}
.single_pager .text_link .back:hover,
.single_pager .text_link .prev:hover .text,
.single_pager .text_link .next:hover .text {
	background-size: 100% 1px;
}

.single_pager .text_link .prev,
.single_pager .text_link .next {
	display: -webkit-box;
	display: flex;
	-webkit-box-align: center;
	align-items: center;
	position: absolute;
	top: 0;
}
.single_pager .text_link .prev {
	left: 0;
}
.single_pager .text_link .next {
	right: 0;
}
.single_pager .text_link .prev .arrow,
.single_pager .text_link .next .arrow {
	font-size: 0;
	width: 50px;
}
.single_pager .text_link .prev .arrow {
	margin: 0 16px 0 0;
}
.single_pager .text_link .next .arrow {
	margin: 0 0 0 16px;
}

.single_pager .text_link .prev .arrow::before,
.single_pager .text_link .next .arrow::before {
	content:"";
	width: 100%;
	background-image: url("../img/cmn/arrow01_gy.svg");
	background-repeat: no-repeat;
	background-size: contain;
	display: inline-block;
	padding-top: 12.6666%;
	transition: .5s;
}
.single_pager .text_link .prev .arrow::before {
	scale: -1 1;
}
.single_pager .text_link .prev:hover .arrow::before,
.single_pager .text_link .next:hover .arrow::before {
	background-image: url("../img/cmn/arrow01_wh.svg");
}
.single_pager .text_link .prev .text,
.single_pager .text_link .next .text {
	transition: .5s;
}
.single_pager .img_link {
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
	margin: 24px 0 0;
}
.single_pager .img_link a {
	width: 50%;
	padding-top: 25%;
	overflow: hidden;
	position: relative;
}
.single_pager .img_link a:hover {
	opacity: 1;
}
.single_pager .img_link img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	object-fit: cover;
	z-index: 0;
}
.single_pager .img_link .works_detail {
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, .5);
	display: -webkit-box;
	display: flex;
	-webkit-box-align: center;
	align-items: center;
	-webkit-box-pack: center;
	justify-content: center;
	text-align: center;
	opacity: 0;
	position: absolute;
	top: 0;
	left: 0;
	transition: .5s;
	z-index: 1;
}
.single_pager .img_link .works_detail > div {
	width: 100%;
}
.single_pager .img_link .works_detail .works_detail_title {
	font-size: clamp(16px, -5.792px + 2.13vw, 24px);
	letter-spacing: 0.3em;
	padding: 1.5% 4% 0;
}
.single_pager .img_link .works_detail .works_detail_meta {
	color: #b3b3b3;
	font-size: clamp(10px, -11.792px + 2.13vw, 18px);
	margin: -1% 0 0;
}
.single_pager .img_link .prev:hover .works_detail,
.single_pager:has(.text_link .prev:hover) .img_link .prev .works_detail {
	opacity: 1;
}
.single_pager .img_link .next:hover .works_detail,
.single_pager:has(.text_link .next:hover) .img_link .next .works_detail {
	opacity: 1;
}
.single_pager .img_link .prev .works_detail .text,
.single_pager .img_link .next .works_detail .text {
	opacity: 0;
	position: absolute;
}
.single_pager .img_link .prev .works_detail .text {
	top: 4%;
	left: 4%;
}
.single_pager .img_link .next .works_detail .text {
	bottom: 4%;
	right: 4%;
}
.single_pager .img_link .prev .works_detail .text::before,
.single_pager .img_link .next .works_detail .text::after {
	content: "";
	width: 25px;
	height: 3px;
	background: url("../img/cmn/arrow01_wh.svg") no-repeat;
	background-size: contain;
	display: inline-block;
	vertical-align: middle;
}
.single_pager .img_link .prev .works_detail .text::before {
	margin: -4% 8px 0 0;
	scale: -1 1;
}
.single_pager .img_link .next .works_detail .text::after {
	margin: -4% 0 0 8px;
}
.single_pager .works_detail_tag > span,
.single_pager .works_detail_category > span {
	text-transform: capitalize;
}
.single_pager .works_detail_category > span:not(:last-child)::after {
	content: ".";
}
@media screen and (min-width: 769px) {
.works_detail_gallery .gallery_wrap.type02 ul li:nth-child(-n + 2) {
	margin-top: 0;
}
.works_detail_gallery .gallery_wrap.type02 ul li:nth-child(2n) {
	margin-right: 0;
}
.works_detail_gallery .gallery_wrap.type03 ul li:nth-child(-n + 3) {
	margin-top: 0;
}
.works_detail_gallery .gallery_wrap.type03 ul li:nth-child(3n) {
	margin-right: 0;
}
.works_detail_gallery .gallery_wrap.type04 > div:nth-child(2n) {
	margin-right: 0;
}
.before_list_thumb .swiper-slide:nth-child(-n + 4) {
	margin-top: 0;
}
.before_list_thumb .swiper-slide:nth-child(4n) {
	margin-right: 0;
}
}
@media screen and (max-width: 768px) {
.article_works .article_head {
	height: auto;
	padding: 133% 0 0;
}
.article_works .article_head .inner {
	height: auto;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
}
.article_works .works_detail_title {
	font-size: 2rem;
}
.article_works .works_detail_meta {
	margin: 16px 0 0;
}
.article_works .works_detail_meta > span:not(:last-child) {
	margin: 0 0 6px;
}
.article_works .article_content {
	padding: 12.6666% 0 0;
}
.works_detail_desc {
	font-size: 1.4rem;
}
.works_detail_gallery {
	margin: 12% 0 0;
}
.works_detail_gallery > div:not(:last-child) {
	margin: 0 0 1.3333%;
}
.works_detail_gallery .gallery_wrap.type02 ul li,
.works_detail_gallery .gallery_wrap.type03 ul li {
	width: 100%;
	margin-top: 1.3333%;
	margin-right: 0;
}
.works_detail_gallery .gallery_wrap.type02 ul li:nth-child(1),
.works_detail_gallery .gallery_wrap.type03 ul li:nth-child(1) {
	margin-top: 0;
}
.works_detail_gallery .gallery_wrap.type04 > div {
	width: 100%;
	margin-right: 0;
}
.works_detail_gallery .gallery_wrap.type04 ul,
.works_detail_gallery .gallery_wrap.type04 ul li {
	height: auto;
}
.works_detail_gallery .gallery_wrap.type04 > div:nth-child(1),
.works_detail_gallery .gallery_wrap.type04 ul li {
	margin-bottom: 1.3333%;
}
.works_detail_data,
.works_detail_before {
	font-size: 1.4rem;
}
.works_detail_data {
	margin: 13.333% 0 0;
}
.works_detail_data > dl > dt,
.works_detail_before > dl > dt {
	margin: 0 0 5.3333%;
}
.works_detail_data dl dd dl > div:not(:last-child) {
	margin: 0 0 4.2666%;
}
.works_detail_data dl dd dl dt {
	width: 100px;
}
.works_detail_data dl dd dl dd {
	width: calc(100% - 100px);
}
.works_detail_layout {
	margin: 13.333% 0 0;
}
.works_detail_layout > div {
	width: 100%;
	margin-right: 0;
}
.works_detail_layout > div:not(:last-child) {
	margin-bottom: 13%;
}
#modal {
	padding: 8% 4% 7.7%;
}
.works_modal_head {
	font-size: 1.6rem;
	text-align: left;
	margin: 0 0 5.3333%;
}
.works_modal_content > div {
	width: 100%;
	margin-right: 0;
}
.works_modal_content > div:not(:last-child) {
	margin-bottom: 0.95%;
}
.before_list_thumb .swiper-slide {
	width: 32.7%;
	margin-top: 0.95%;
	margin-right: 0.95%;
}
.before_list_thumb .swiper-slide .img {
	overflow: hidden;
	padding-top: 65.8%;
	position: relative;
}
.before_list_thumb .swiper-slide:nth-child(-n + 3) {
	margin-top: 0;
}
.before_list_thumb .swiper-slide:nth-child(3n) {
	margin-right: 0;
}
.single_pager {
	margin: 30% 0 0;
}
.single_pager .text_link .prev,
.single_pager .text_link .next {
	display: none;
}
.single_pager .img_link a {
	width: 100%;
	padding-top: 50%;
}
.single_pager .img_link .works_detail {
	text-align: left;
	opacity: 1;
}
.single_pager .img_link .works_detail > div {
	display: -webkit-box;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	flex-direction: column;
	-webkit-box-align: center;
	align-items: center;
}
.single_pager .img_link .works_detail .works_detail_meta {
	font-size: 1.6rem;
	display: -webkit-box;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	flex-direction: column;
	margin: 1% 0 0;
}
.single_pager .img_link .works_detail .works_detail_title {
	font-size: 2rem;
}
.single_pager .img_link .prev .works_detail .text,
.single_pager .img_link .next .works_detail .text {
	opacity: 1;
}
}
@media screen and (max-width: 480px) {
.works_detail_desc,
.works_detail_data {
	font-size: 3.5vw;
}
.works_detail_data dl dd dl dt {
	width: 28%;
}
.works_detail_data dl dd dl dd {
	width: calc(100% - 28%);
}
.single_pager .img_link .works_detail .works_detail_title {
	font-size: 4.2666vw;
}
.single_pager .img_link .works_detail .works_detail_meta,
.single_pager .text_link {
	font-size: 3.5vw;
}
.works_modal_head {
	font-size: 3.5vw;
}
}


/* --------------------------------------------------------
	DETAIL
-------------------------------------------------------- */
/* 一覧
-------------------------------------------------------- */
.detail_title { letter-spacing: 0.3em; }
.detail_category { color: #b3b3b3; }
.detail_category > span:not(:last-child)::after { content: " . "; }
.detail_list li {
	width: 33%;
	margin-top: 5.375%;
	margin-right: 0.5%;
}
.detail_list .img {
	background-color: #999;
	overflow: hidden;
	padding-top: 66.603773584%;
	position: relative;
	transition: .5s;
	z-index: 1;
}
.detail_list .img img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	transition: .5s;
	object-fit: cover;
}
.detail_list li a:hover { opacity: 1; }
.detail_list li a:hover .img img {
	scale: 1.1;
}
.detail_list .text_wrap { padding: 16px 4% 0; }
.detail_list .detail_title,
.detail_list .detail_category { font-size: clamp(14px, 3.104px + 1.06vw, 18px); }
.detail_list .detail_category { margin: .5% 0 0; }

@media screen and (min-width: 1025px) {
.detail_list li:nth-child(-n + 3) { margin-top: 0; }
.detail_list li:nth-child(3n) { margin-right: 0; }
}
@media screen and (max-width: 1024px) {
.detail_list li { width: 49.75%; }
.detail_list li { margin-top: 7%; }
.detail_list li:nth-child(-n + 2) { margin-top: 0; }
.detail_list li:nth-child(2n) { margin-right: 0; }
}

@media screen and (max-width: 768px) {
.detail_title { letter-spacing: 0.2em; }
.detail_list li {
	margin-right: 0;
}
.detail_list li {
	width: 100%;
}
.detail_list li,
.detail_list li:nth-child(-n + 2) {
	margin-top: 12%;
}
.detail_list li:nth-child(1) {
	margin-top: 0;
}
.detail_list .detail_title,
.detail_list .detail_category { font-size: 1.6rem; }
}
@media screen and (max-width: 480px) {
.detail_list .detail_title,
.detail_list .detail_category { font-size: 3.5vw; }
}

/* 詳細
-------------------------------------------------------- */
#detail.is_single { padding: 20px 0 0; }
.article_detail .article_head .img_wrap {
	height: calc(100svh - 80px);
	margin: 0 0 3.5%;
	position: relative;
}
.article_detail .article_head .img_wrap .scroll_text {
	color: #ccc;
	font-size: 1.6rem;
	opacity: 0;
	visibility: hidden;
	position: absolute;
	right: 4%;
	bottom: 2.6666%;
	z-index: 1;
}
.article_detail .article_head .img_wrap .scroll_text::after {
	content: "";
	width: 36px;
	height: 5px;
	background: url("../img/cmn/arrow01_gy.svg") no-repeat;
	background-size: contain;
	display: inline-block;
	vertical-align: middle;
	margin: -4% 0 0 min(2vw, 16px);
}
.article_detail .article_head .img_wrap .scroll_img {
	height: 100%;
	overflow: hidden;
	position: relative;
	z-index: 0;
}
.article_detail .article_head .img_wrap .scroll_img img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	object-fit: cover;
}
.article_detail .article_head .img_wrap .scroll_img.is_vertical img {
	object-fit: contain;
}
.article_detail .article_head .img_wrap .scroll_img::-webkit-scrollbar {
	height: 4px;
}
.article_detail .article_head .img_wrap .scroll_img::-webkit-scrollbar-track { background: none; }
.article_detail .article_head .img_wrap .scroll_img::-webkit-scrollbar-thumb { background: rgba(153, 153, 153, .8); }
.article_detail .article_head .img_wrap .scroll_img img { width: 100%; }
.article_detail .article_head .detail_title {
	font-size: 2.4rem;
	letter-spacing: 0.3em;
}
.article_detail .article_head .detail_title {
	font-size: 2.4rem;
}
.article_detail .article_head .detail_category {
	margin: 1% 0 0;
}
.article_detail .article_content {
	margin: 3.5% 0 0;
}
.article_detail .article_content b,
.article_detail .article_content strong {
	font-weight: 700;
}
.article_detail .article_content a {
	text-decoration: underline;
}
.article_detail .article_content a {
	opacity: 1;
	text-decoration: none;
}
.article_detail .article_content .inner > div {
	max-width: 650px;
	width: 100%;
	line-height: 1.9;
}
#detail.is_single .btn_wrap {
	margin: 5% 0 0;
}
#detail.is_single .btn_wrap ul {
	display: -webkit-box;
	display: flex;
	-webkit-box-pack: center;
	justify-content: center;
}
#detail.is_single .btn_wrap ul li:not(:last-child) {
	margin: 0 min(8vw, 98px) 0 0;
}
#detail.is_single .btn_wrap ul li.more .c-btn01 .arrow,
#detail.is_single .btn_wrap ul li.more .c-btn01 .arrow::before,
#detail.is_single .btn_wrap ul li.more .c-btn01 .arrow::after {
	background: #fff;
}
#detail.is_single .btn_wrap ul li.back {
	color: #b3b3b3;
}
@media screen and (max-width: 768px) {
#detail.is_single { padding: 2.6666% 0 0; }
.article_detail .article_head .img_wrap {
	margin: 0 0 7.5%;
}
.article_detail .article_head .img_wrap .scroll_text {
	font-size: 1.6rem;
	opacity: 1;
	visibility: inherit;
}
.article_detail .article_head .img_wrap .scroll_img { overflow-x: auto; }
.article_detail .article_head .img_wrap .scroll_img img,
.article_detail .article_head .img_wrap .scroll_img.is_vertical img {
	max-width: initial;
	width: 150%;
}
.article_detail .article_head .img_wrap .scroll_img.is_vertical img {
	width: 125%;
	object-fit: cover;
}
.article_detail .article_head .detail_title {
	font-size: 2rem;
}
.article_detail .article_head .detail_category,
.article_detail .article_content {
	font-size: 1.6rem;
}
.article_detail .article_content {
	margin: 4.8% 0 0;
}
.article_detail .article_content .inner > div {
	line-height: 1.75;
}
#detail.is_single .btn_wrap {
	margin: 12% 0 0;
}
#detail.is_single .btn_wrap ul {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	flex-direction: column;
	-webkit-box-align: center;
	align-items: center;
}
#detail.is_single .btn_wrap ul li:not(:last-child) {
	margin: 0 0 24%;
}
}
@media screen and (max-width: 480px) {
.article_detail .article_head .img_wrap .scroll_text {
	font-size: 3.5vw;
}
.article_detail .article_head .detail_title {
	font-size: 4.2666vw;
}
.article_detail .article_head .detail_category,
.article_detail .article_content {
	font-size: 3.5vw;
}
}


/* --------------------------------------------------------
	LIVING DESIGN
-------------------------------------------------------- */
/* メッセージ
-------------------------------------------------------- */
#message .img {
	position: relative;
}
#message .img::after {
	content: "";
	width: 100%;
	height: 100%;
	background: #000;
	opacity: .5;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
#message .img > div {
	color: #fff;
	font-size: 1.8rem;
	line-height: 2.7;
	padding: 5% 3.5%;
	position: relative;
	z-index: 2;
}
#message .img img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	object-fit: cover;
	z-index: 0;
}
#message .text_wrap {
	padding: 4% 3.5%;
}
#message .text p:not(:last-child) {
	margin: 0 0 24px;
}
#message .btn_wrap {
	margin: 24px 0 0;
}
#message .btn_wrap .c-btn01 .arrow,
#message .btn_wrap .c-btn01 .arrow::before,
#message .btn_wrap .c-btn01 .arrow::after {
	background: #4d4d4d;
}
@media screen and (max-width: 768px) {
#message .img > div {
	font-size: 1.6rem;
	line-height: 2;
	padding: 11% 6.4%;
}
#message .text_wrap {
	padding: 9.6% 6.4%;
}
#message .text p:not(:last-child) {
	margin: 0 0 5%;
}
}
@media screen and (max-width: 480px) {
#message .img > div {
	font-size: 4vw;
}
}

/* 10の特徴
-------------------------------------------------------- */
.feature_list {
	counter-reset: number 0;
}
.feature_list li {
	display: -webkit-box;
	display: flex;
}
.feature_list li:not(:last-child) {
	margin: 0 0 20px;
}
.feature_list .num {
	width: 40px;
	line-height: 1;
	position: relative;
}
.feature_list .num::before {
	counter-increment: number 1;
	content: counter(number, decimal-leading-zero);
	color: #808080;
	font-size: 1.8rem;
}
.feature_list .num::after {
	content: "";
	width: 1px;
	height: 100%;
	background: #b3b3b3;
	position: absolute;
	top: 0;
	right: 0;
}
.feature_list .text {
	width: calc(100% - 40px);
	margin: -4px 0 0;
	padding: 0 0 0 20px;
}
@media screen and (min-width: 769px) {
.feature_list li {
	-webkit-box-align: start;
	align-items: flex-start;
}
}
@media screen and (max-width: 768px) {
.feature_list li:not(:last-child) {
	margin: 0 0 4%;
}
.feature_list .num {
	width: 30px;
	display: -webkit-box;
	display: flex;
	-webkit-box-align: center;
	align-items: center;
}
.feature_list .num::before {
	font-size: 1.6rem;
}
.feature_list .text {
	width: calc(100% - 30px);
	margin: 0;
	padding: 0 0 0 10px;
}
}
@media screen and (max-width: 480px) {
.feature_list .num {
	width: 6.6vw;
}
.feature_list .num::before {
	font-size: 3.5vw;
	width: calc(100% - 6.6vw);
}
.feature_list .text {
	padding: 0 0 0 2vw;
}
}

/* 建築スタイルの違い
-------------------------------------------------------- */
#style .c-page_layout_content:not(.is_wide) > div {
	max-width: 1040px;
}
.style_list > div {
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
}
.style_list > div:not(:last-child) {
	margin: 0 0 32px;
}
.style_list dt {
	color: #808080;
	width: 207px;
	display: -webkit-box;
	display: flex;
	-webkit-box-align: center;
	align-items: center;
	padding: 0 24px;
	position: relative;
}
.style_list dt::before {
	content: "";
	width: 1px;
	height: 100%;
	background: #b3b3b3;
	position: absolute;
	top: 0;
	right: 0;
}
.style_list dd {
	width: calc(100% - 207px);
	padding: 0 24px 0 32px;
}
.style_list > div.is_living-design,
.style_list > div.is_living-design dt {
	color: #fff;
}
.style_list > div.is_living-design {
	background: #999;
	padding: 16px 0;
}
.style_list > div.is_living-design ul {
	display: -webkit-box;
	display: flex;
	margin: 16px 0 0;
}
.style_list > div.is_living-design ul li {
	display: -webkit-box;
	display: flex;
	-webkit-box-align: center;
	align-items: center;
	-webkit-box-pack: center;
	justify-content: center;
	line-height: 1.4;
}
.style_list > div.is_living-design ul li:not(.times) {
	color: #4d4d4d;
	max-width: 150px;
	width: 100%;
	background: #ccc;
	text-align: center;
	padding: 10px;
}
.style_list > div.is_living-design ul li.times::before {
	content: "";
	width: 9px;
	height: 9px;
	background: url("../img/cmn/icon_times_gy.svg") no-repeat;
	background-size: contain;
	display: block;
	margin: 0 6px;
}
@media screen and (max-width: 1024px) {
.style_list dt {
	width: auto;
	line-height: 1;
	margin: 0 0 10px;
	padding: 0 16px;
}
.style_list dd {
	width: 100%;
	padding: 0 16px 0 8.5%;
}
}
@media screen and (max-width: 768px) {
.style_list > div:not(:last-child) {
	margin: 0 0 6%;
}
.style_list > div.is_living-design ul {
	margin: 2% 0 0;
}
.style_list > div.is_living-design ul li:not(.times) {
	padding: 6px 4px;
}
}
@media screen and (max-width: 480px) {
.style_list > div.is_living-design ul li:not(.times) {
	font-size: 3vw;
}
}


/* --------------------------------------------------------
	STORY
-------------------------------------------------------- */
/* 10の大切な工程
-------------------------------------------------------- */
#flow { overflow: hidden; }
#flow .head {
	line-height: 2.7;
	margin: 0 0 6.25%;
}
.swiper.flow_list {
	font-size: 1.6rem;
}
.swiper.flow_list .flow_img {
	overflow: hidden;
	margin: 0 0 24px;
	padding-top: 65%;
	position: relative;
}
.swiper.flow_list .flow_img img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	transition: .5s;
	object-fit: cover;
}
.swiper.flow_list .flow_title {
	font-weight: 700;
}
.swiper.flow_list .flow_text {
	line-height: 1.9;
	margin: 12px 0 0;
}
.swiper.flow_list .swiper-controller {
	max-width: 650px;
	width: 100%;
	display: -webkit-box;
	display: flex;
	-webkit-box-align: center;
	align-items: center;
	margin: 56px 0 0;
}
.swiper.flow_list .swiper-button-next,
.swiper.flow_list .swiper-button-prev,
.swiper.flow_list .swiper-pagination {
	position: relative;
}
.swiper.flow_list .swiper-pagination {
	background: #b3b3b3;
	height: 1px;
}
.swiper.flow_list .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
	background: #fff;
	height: 3px;
	top: -1px;
}
.swiper.flow_list .swiper-button-next,
.swiper.flow_list .swiper-button-prev {
	margin-top: 0;
	margin-right: 18px;
	right: inherit;
	left: inherit;
}
.swiper.flow_list .swiper-button-next,
.swiper.flow_list .swiper-button-prev,
.swiper.flow_list .swiper-button-next::after,
.swiper.flow_list .swiper-button-prev::after {
	width: 50px;
	height: 6px;
}
.swiper.flow_list .swiper-button-next::after,
.swiper.flow_list .swiper-button-prev::after {
	content: "";
	background: url("../img/cmn/arrow01_gy.svg") no-repeat;
	background-size: contain;
}
.swiper.flow_list .swiper-button-prev::after {
	scale: -1 1;
}
@media screen and (min-width: 769px) {
.swiper.flow_list {
	margin-right: calc(50% - 50vw);
	padding-right: calc(50vw - 50%);
}
}
@media screen and (max-width: 768px) {
#flow .head {
	line-height: 2;
	margin: 0 0 15%;
}
.swiper.flow_list {
	font-size: 1.4rem;
}
.swiper.flow_list .swiper-controller {
	max-width: inherit;
	margin: 13% 0 0;
}
.swiper.flow_list .swiper-button-next,
.swiper.flow_list .swiper-button-prev,
.swiper.flow_list .swiper-button-next::after,
.swiper.flow_list .swiper-button-prev::after {
	width: 28px;
	height: 4px;
}
.swiper.flow_list .swiper-button-next,
.swiper.flow_list .swiper-button-prev {
	margin-right: min(5vw, 14px);
}
}
@media screen and (max-width: 480px) {
.swiper.flow_list {
	font-size: 3.5vw;
}
}

/* 安全の保証体制
-------------------------------------------------------- */
#support {
	margin: 9.875% 0 0;
}
#support .head .title {
	font-size: 2.4rem;
}
#support .head .text {
	line-height: 2.7;
	margin: 3% 0 0;
}
#support .flex {
	margin: 6.875% 0 0;
}
#support .flex > div {
	width: 50%;
}
#support .flex dl dt {
	color: #000;
	font-size: 1.6rem;
	font-weight: 700;
	background: #b3b3b3;
	text-align: center;
	padding: 3%;
}
#support .flex dl dd {
	background: #ccc;
	padding: 6.9% 3.7% 9.8%;
}
#support .flex .text_wrap {
	font-size: 1.6rem;
	line-height: 1.9;
	padding: 0 0 0 5%;
}
#support .flex .title {
	font-weight: 700;
}
#support .flex .text {
	margin: 4.9% 0 0;
}
@media screen and (max-width: 768px) {
#support {
	margin: 18% 0 0;
}
#support .head,
#support .flex .text_wrap {
	padding: 0 4%;
}
#support .head .title {
	font-size: 2rem;
}
#support .head .text {
	line-height: 2;
}
#support .flex > div {
	width: 100%;
}
#support .flex dl dt,
#support .flex .text_wrap {
	font-size: 1.4rem;
}
#support .flex .text_wrap {
	margin: 6.6% 0 0;
}
}
@media screen and (max-width: 480px) {
#support .head .title {
	font-size: 4.2666vw;
}
#support .flex dl dt,
#support .flex .text_wrap {
	font-size: 3.5vw;
}
}


/* --------------------------------------------------------
	Q&A
-------------------------------------------------------- */
.faq_list > div { border-bottom: solid 1px #b3b3b3; }
.faq_list dt,
.faq_list dd > div {
	display: -webkit-box;
	display: flex;
}
.faq_list dt {
	cursor: pointer;
	padding: 20px 2.3%;
	position: relative;
	z-index: 0;
}
.faq_list dt::after {
	content: "";
	width: 9px;
	height: 5px;
	background-image: url("../img/cmn/arrow02_wh.svg");
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: calc(50% - 2.5px);
	right: 1.875%;
	transition: .5s;
}
.faq_list dd {
	display: none;
	padding: 0 2.3%;
	position: relative;
	z-index: 1;
}
.faq_list .icon { width: 24px; }
.faq_list .text {
	width: calc(100% - 24px);
	padding: 0 0 0 14px;
}
.faq_list dt.acc.is_acc_open,
.faq_list dt.acc.is_acc_open ~ dd {
	color: #666;
	background: #ccc;
}
.faq_list dt.acc.is_acc_open::after {
	background-image: url("../img/cmn/arrow02_gy.svg");
	scale: 1 -1;
}
.faq_list dt.acc.is_acc_open ~ dd > div {
	padding-bottom: 24px;
}
.faq_list a {
	text-decoration: underline;
}
.faq_list a:hover {
	opacity: 1;
	text-decoration: none;
}
@media screen and (max-width: 768px) {
.faq_list dt {
	padding: 7% 3.7%;
	padding-right: calc(3.7% + 9px);
}
.faq_list dt::after {
	right: 3.7%;
}
.faq_list dd {
	margin-top: -2.7%;
	padding: 0 3.7%;
}
.faq_list .icon { width: 20px; }
.faq_list .text {
	width: calc(100% - 20px);
	padding: 0 0 0 1.8666%;
}
}


/* --------------------------------------------------------
	VOICE
-------------------------------------------------------- */
/* 一覧
-------------------------------------------------------- */
.voice_category { color: #b3b3b3; }
.voice_category > span { text-transform: capitalize; }
.voice_category > span:not(:last-child)::after { content: " . "; }
.voice_list li {
	width: 33%;
	margin-top: 3%;
	margin-right: 0.5%;
}
.voice_list li a:hover { opacity: 1; }
.voice_list .img {
	background-color: #999;
	overflow: hidden;
	padding-top: 66.6666%;
	position: relative;
	transition: .5s;
	z-index: 1;
}
.voice_list .img img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	transition: .5s;
	object-fit: cover;
}
.voice_list li a:hover .img img {
	scale: 1.1;
}
.voice_list .voice_title {
	font-size: clamp(14px, -2.336px + 1.6vw, 20px);
	line-height: 1.4;
	margin: 16px 4% 0;
}
.voice_list .voice_title span {
	background: linear-gradient(90deg, #fff, #fff) no-repeat left bottom;
	background-size: 0 1px;
	transition: .5s;
}
.voice_list li a:hover .voice_title span {
	background-size: 100% 1px;
}
#voice .voice_list li { margin-top: 7%; }
#voice .voice_list li:nth-child(-n + 3) { margin-top: 0; }
#voice .voice_list .text_wrap { padding: 16px 4% 0; }
#voice .voice_list .voice_title,
#voice .voice_list .voice_category { font-size: clamp(14px, 3.104px + 1.06vw, 18px); }
#voice .voice_list .voice_title { margin: 0; }
#voice .voice_list li a:hover .voice_title span { background-size: 0 1px; }


@media screen and (max-width: 1024px) {
#voice .voice_list li { width: 49.75%; }
#voice .voice_list li,
#voice .voice_list li:nth-child(-n + 3) { margin-top: 7%; }
#voice .voice_list li:nth-child(-n + 2) { margin-top: 0; }
#voice .voice_list li,
#voice .voice_list li:nth-child(3n) { margin-right: 0.5%; }
#voice .voice_list li:nth-child(2n) { margin-right: 0; }
}

@media screen and (min-width: 769px) {
.voice_list li:nth-child(-n + 3) { margin-top: 0; }
.voice_list li:nth-child(3n) { margin-right: 0; }
}
@media screen and (max-width: 768px) {
.voice_list li,
#voice .voice_list li {
	width: 100%;
}
.voice_list li {
	margin-top: 9.6%;
	margin-right: 0;
}
#voice .voice_list li,
#voice .voice_list li:nth-child(-n + 2),
#voice .voice_list li:nth-child(-n + 3) {
	margin-top: 12%;
}
.voice_list li:nth-child(1),
#voice .voice_list li:nth-child(1) {
	margin-top: 0;
}
#voice .voice_list li,
#voice .voice_list li:nth-child(3n),
#voice .voice_list li:nth-child(2n) {
	margin-right: 0;
}
.voice_list .voice_title {
	font-size: 1.8rem;
}
#voice .voice_list .voice_title,
#voice .voice_list .voice_category { font-size: 1.6rem; }
}
@media screen and (max-width: 480px) {
.voice_list .voice_title {
	font-size: 3.7333vw;
}
#voice .voice_list .voice_title,
#voice .voice_list .voice_category { font-size: 3.5vw; }
}

/* 詳細
-------------------------------------------------------- */
#voice.is_single { padding: 7.5% 0 0; }
#voice.is_single .btn_wrap {
	margin: 8.75% 0 0;
}
.article_voice .article_head {
	width: 33%;
	display: -webkit-box;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	flex-direction: column;
}
.article_voice .article_head .img {
	margin-top: auto;
	padding-top: 66.511627906%;
	position: relative;
}
.article_voice .article_head .img img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	transition: .5s;
	object-fit: cover;
}
.article_voice .article_head .text_wrap {
	margin: 0 0 19%;
}
.article_voice .article_head .voice_title {
	font-size: 2.4rem;
	letter-spacing: 0.3em;
}
.article_voice .article_head .voice_category {
	margin: 2% 0 0;
}
.article_voice .article_content {
	font-size: 1.6rem;
	width: 63%;
}
.article_voice .article_content b,
.article_voice .article_content strong {
	font-weight: 700;
}
.article_voice .article_content a {
	text-decoration: underline;
}
.article_voice .article_content a {
	opacity: 1;
	text-decoration: none;
}
.article_voice .article_content::-webkit-scrollbar { width: 6px; }
.article_voice .article_content::-webkit-scrollbar-track { background: none; }
.article_voice .article_content::-webkit-scrollbar-thumb { background: #999; }
@media screen and (min-width: 769px) {
.article_voice .article_head .img {
	-webkit-box-ordinal-group: 2;
	order: 1;
}
.article_voice .article_head .text_wrap {
	-webkit-box-ordinal-group: 1;
	order: 0;
}
.article_voice .article_content {
	min-height: 420px;
	max-height: 45vh;
	overflow-y: auto;
}
}
@media screen and (max-width: 768px) {
#voice.is_single { padding: 2.6666% 0 0; }
#voice.is_single .inner { width: 100%; }
#voice.is_single .btn_wrap {
	margin: 16% 0 0;
}
.article_voice .article_head,
.article_voice .article_content {
	width: 100%;
}
.article_voice .article_head .text_wrap {
	margin: 4.9% 0 0;
	padding: 0 4%;
}
.article_voice .article_head .voice_title {
	font-size: 2rem;
}
.article_voice .article_content {
	margin: 8.5% 0 0;
	padding: 0 4%;
}
}
@media screen and (max-width: 480px) {
.article_voice .article_head .voice_title {
	font-size: 4.2666vw;
}
.article_voice .article_content {
	font-size: 3.5vw;
}
}


/* --------------------------------------------------------
	COMPANY
-------------------------------------------------------- */
/* PHILOSOPHY
-------------------------------------------------------- */
#philosophy { padding: 0 0 6.25%; }
#philosophy .text { line-height: 2.7; }
@media screen and (max-width: 768px) {
#philosophy { padding: 0 0 17%; }
#philosophy .text { line-height: 2; }
}

/* PROFILE
-------------------------------------------------------- */
#profile { margin-bottom: 6.25%; }
#profile .img {
	height: 100%;
	position: relative;
}
#profile .img img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	object-fit: cover;
}
#profile .profile_title {
	border-bottom: solid 1px #b3b3b3;
	margin: 0 0 24px;
	padding: 0 0 16px;
}
#profile .profile_text { line-height: 2.5; }
@media screen and (max-width: 768px) {
#profile { margin-bottom: 14.6666%; }
#profile .img {
	padding-top: 60%;
}
#profile .profile_title {
	margin: 0 0 5.3%;
	padding: 0 0 2.6%;
}
#profile .profile_text { line-height: 1.6; }
}

/* ACCESS
-------------------------------------------------------- */
#access .c-page_layout_content > div { position: relative; }
#access address {
	background: #ccc;
	padding: 3% 8%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
#access .google_map {
	overflow: hidden;
	padding-top: 50%;
	position: relative;
	z-index: 0;
}
#access .google_map iframe {
	width: 100%;
	height: calc(100% + (150px * 2));
	position: absolute;
	top: -150px;
	left: 0;
}
@media screen and (max-width: 768px) {
#access address {
	padding: 5.3333% 2.6666%;
	position: static;
}
#access address br { display: none; }
#access .google_map {
	padding-top: 80%;
}
}


/* --------------------------------------------------------
	CONTACT
-------------------------------------------------------- */
.contact_title { margin: 0 0 16px; }
.contact_tel,
.contact_thanks { margin: 3.5% 0 0; }
.contact_tel a {
	font-size: 2rem;
	background: #999;
	display: inline-block;
	line-height: 1;
	padding: 16px 24px;
}
.contact_form { margin: 4.5% 0 0; }
.contact_form .form_wrap {
	font-size: 1.6rem;
	background: #999;
	padding: 0 16px 7.5%;
}
.contact_form .form_list > div:not(:nth-child(1)) { margin: 9% 0 0; }
.contact_form .form_list > div:nth-child(1) .c-tbl01 { border-top: none; }
.contact_form .form_wrap .form_text {
	font-weight: 700;
	margin: 0 0 32px;
}
.contact_form .required span {
	font-size: 1.5rem;
	background: #808080;
	border-radius: 15px;
	display: inline-block;
	line-height: 1;
	margin: 0 0 0 12px;
	padding: 8px 16px;
}
.acceptance_list {
	font-weight: 700;
	margin: 9% 0 0;
}
.acceptance_list li:not(:last-child) {
	margin: 0 0 16px;
}
.acceptance_list a {
	text-decoration: underline;
}
.acceptance_list a:hover {
	opacity: 1;
	text-decoration: none;
}
.submit_wrap {
	margin: 4.5% 0 0;
}
.submit_wrap .submit_text {
	margin: 0 0 20px;
}
.submit_wrap input {
	color: #fff;
	font-size: 1.8rem;
	font-weight: 700;
	max-width: 200px;
	width: 33.3333%;
	background: #4d4d4d;
	display: inline-block;
	line-height: 1;
	padding: 24px 8px;
}
.submit_wrap input:disabled {
	color: #4d4d4d;
	background: #b3b3b3;
}
.contact_thanks .thanks_title {
	font-size: 2.4rem;
	letter-spacing: 0.3em;
	margin: 0 0 3.5%;
}
.contact_thanks .btn_wrap {
	margin: 5% 0 0;
}
.wpcf7-spinner {
	display: none !important;
}
@media screen and (max-width: 768px) {
.contact_tel,
.contact_thanks { margin: 8.5% 0 0; }
.contact_tel a {
	font-size: 1.8rem;
}
.contact_form { margin: 10% 0 0; }
.contact_form .form_wrap {
	font-size: 1.4rem;
	padding-bottom: 18%;
}
.contact_form .form_list > div:not(:nth-child(1)) { margin: 18% 0 0; }
.contact_form .form_wrap .form_text {
	margin: 0 0 16px;
}
.contact_form .required span {
	font-size: 1.3rem;
}
.acceptance_list {
	margin: 9.5% 0 0;
}
.acceptance_list li:not(:last-child) {
	margin: 0 0 8px;
}
.submit_wrap .submit_text {
	margin: 0 0 4.6%;
}
.submit_wrap {
	text-align: center;
	margin: 9.5% 0 0;
}
.submit_wrap > p {
	display: -webkit-box;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	flex-direction: column;
	-webkit-box-align: center;
	align-items: center;
}
.submit_wrap input {
	font-size: 1.6rem;
	padding: 18px 8px;
}
.contact_thanks .thanks_title {
	font-size: 2rem;
	margin: 0 0 4.8%;
}
.contact_thanks .btn_wrap {
	-webkit-box-pack: center;
	justify-content: center;
	margin: 12% 0 0;
}
}
@media screen and (max-width: 480px) {
.contact_tel a {
	font-size: 3.5vw;
	padding: 3.2%;
}
.contact_form .form_wrap {
	font-size: 3.5vw;
}
.contact_form .required span {
	font-size: 3.2vw;
	margin: 0 0 0 2vw;
	padding: 1.5vw 3.5vw;
}
.submit_wrap input {
	font-size: 3.5vw;
}
.contact_thanks .thanks_title {
	font-size: 4.2666vw;
}
}

.contact_form .form_wrap input[type="text"],
.contact_form .form_wrap input[type="email"],
.contact_form .form_wrap input[type="tel"],
.contact_form .form_wrap select,
.contact_form .form_wrap textarea {
	max-width: 600px;
	width: 100%;
	background: #ccc;
	padding: 12px 16px;
	box-sizing: border-box;
}
.contact_form .form_wrap textarea {
	height: 150px;
	margin: 24px 0 0;
}
.wpcf7-checkbox {
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
	margin-top: -16px;
	margin-right: -40px;
}
.wpcf7-checkbox.is_small {
	max-width: 810px;
}
.wpcf7-checkbox .wpcf7-list-item {
	margin-top: 16px;
	margin-right: 40px;
}
.wpcf7-checkbox .wpcf7-list-item-label,
.wpcf7-acceptance .wpcf7-list-item-label {
	display: inline-block;
	padding-left: 20px;
	position: relative;
}
.wpcf7-checkbox .wpcf7-list-item-label::before,
.wpcf7-checkbox .wpcf7-list-item-label::after,
.wpcf7-acceptance .wpcf7-list-item-label::before,
.wpcf7-acceptance .wpcf7-list-item-label::after {
	content: "";
	width: 12px;
	height: 12px;
	position: absolute;
	top: 7px;
	left: 0;
	transition: .5s;
}
.wpcf7-checkbox .wpcf7-list-item-label::before,
.wpcf7-acceptance .wpcf7-list-item-label::before {
	border: solid 1px #fff;
}
.wpcf7-checkbox .wpcf7-list-item-label::after,
.wpcf7-acceptance .wpcf7-list-item-label::after {
	background: #fff;
	opacity: 0;
}
.wpcf7-checkbox input[type="checkbox"]:checked + .wpcf7-list-item-label::after,
.wpcf7-acceptance input[type="checkbox"]:checked + .wpcf7-list-item-label::after {
	opacity: 1;
}
@media screen and (max-width: 768px) {
.contact_form .form_wrap textarea {
	height: 120px;
	margin: 16px 0 0;
}
.wpcf7-checkbox {
	margin-top: min(-2.4vw, -8px);
	margin-right: 0;
}
.wpcf7-checkbox .wpcf7-list-item {
	margin-top: min(2.4vw, 8px);
	margin-right: min(6vw, 16px);
}
.wpcf7-checkbox .wpcf7-list-item-label,
.wpcf7-acceptance .wpcf7-list-item-label {
	padding-left: 16px;
}
.wpcf7-checkbox .wpcf7-list-item-label::before,
.wpcf7-checkbox .wpcf7-list-item-label::after,
.wpcf7-acceptance .wpcf7-list-item-label::before,
.wpcf7-acceptance .wpcf7-list-item-label::after {
	width: 8px;
	height: 8px;
}
}
@media screen and (max-width: 480px) {
.wpcf7-checkbox .wpcf7-list-item-label::before,
.wpcf7-checkbox .wpcf7-list-item-label::after,
.wpcf7-acceptance .wpcf7-list-item-label::before,
.wpcf7-acceptance .wpcf7-list-item-label::after {
	top: 1.8vw;
}
}

/* --------------------------------------------------------
	PRIVACY POLICY
-------------------------------------------------------- */
.privacy_list > div:not(:last-child) { margin: 0 0 6.8%; }
.privacy_list dt,
.privacy_list dd { padding: 20px 2.3%; }
.privacy_list dt {
	border-bottom: solid 1px #b3b3b3;
	padding-top: 0;
}
.privacy_list dd { padding-bottom: 0; }
@media screen and (max-width: 768px) {
.privacy_list > div:not(:last-child) { margin: 0 0 15%; }
.privacy_list dt,
.privacy_list dd { padding: 7% 3.7%; }
.privacy_list dt { padding-top: 0; }
.privacy_list dd { padding-bottom: 0; }
}

/* Cloudflare Turnstile */
.cf7-cf-turnstile{
	width: fit-content;
	margin: 20px 0 0 !important;
}
@media screen and (max-width: 768px) {
.cf7-cf-turnstile{
	margin: 4.6% auto 0 !important;
}
}
