@charset "UTF-8";

/*
Theme Name: ARCH 2026
Text Domain: arch-2026
Description: 株式会社アーチ専用ワードプレステーマ
Author: ONZE
Author URI: https://on-ze.com
Theme URI: https://archfoods.co.jp
Version: 0.9
*/

/******************/

:root {
--color-black:#231f20;
--color-dark:#3f3d3e;
--color-gray:#979792;
--color-border:#d9d8d8;/*--color-border:rgba(63,61,62,0.2);*/
--color-background:#f6f5f3;
--color-white:#ffffff;
--color-blue:#254896;
--color-gradient:linear-gradient(90deg,rgba(41, 46, 135, 1) 0%, rgba(30, 110, 173, 1) 100%);
--color-red:#ff4e38;
--font-normal:'Shippori Mincho' ,'Cormorant', 'YuMincho', 'Yu Mincho', '游明朝', 'Hiragino Mincho ProN', 'ヒラギノ明朝 ProN W3', serif;
--font-light:200;
--font-regular:400;
--font-bold:600;
--border-radius:20px;
--border-radius-mini:4px;
--border-radius-large:8vw;
--letter-spacing:0.06em;
--line-height-large:2.0;
--line-height:1.4;
--line-height-mini:1.2;
--transition:0.2s;
--transition-fast:0.15s;
--transition-late:0.7s;
}

/******************/
/******************/
/* ONZE RESET CSS */

*,
*::before,
*::after {
	box-sizing:border-box;
}

* {
border:0;
margin:0;
outline:0;
padding:0;
font:inherit;
font-family:inherit;
font-size:100%;
font-style:inherit;
font-weight:inherit;
text-decoration:none;
vertical-align:baseline;
/*	all:unset;
	display:revert;*/
}


article, aside, footer, header, main, nav, article, section {display:block;}
img, picture, audio, canvas, video, svg {display:block; max-width:100%; height:auto;}

br,
hr {display:block;}

ol,
ul {list-style:none;}

blockquote, q {quotes:none;}
blockquote:before, blockquote:after, q:before, q:after {content:none;}

input,
select {vertical-align:middle;}

body {
	line-height:1;
	line-break:strict;
	overflow-wrap:anywhere;
	word-break:normal;
	font-feature-settings:"palt";
	font-kerning:normal;
	-webkit-text-size-adjust:100%;
	-webkit-font-smoothing:antialiased;
}

a {-webkit-tap-highlight-color:transparent;}

/******************/
/******************/
/* html format ****/

html {
	font-size:62.5%;
	font-size:calc(100vw / 144);
}
html {font-size:clamp(7px, calc(100vw / 1600 * 4 + 5px), 11px);}
html.is-fixrem {font-size:62.5%;}

body {
background-color:var(--color-white);
color:var(--color-dark);
font-family:'Shippori Mincho' ,'Bellefair', 'YuMincho', 'Yu Mincho', '游明朝', 'Hiragino Mincho ProN', 'ヒラギノ明朝 ProN W3', serif;
font-size:17px;
font-size:1.7rem;
font-style:normal;
font-weight:var(--font-regular);
position:relative;
text-align:center;
width:100%;
}

a,
a:link,
a:visited,
a:hover,
a:active {
	color:inherit;
	-webkit-tap-highlight-color:transparent rgba(0,0,0,0);
	text-decoration:none;
	-webkit-text-decoration-skip:objects;
}


h1,
h2,
h3,
h4,
h5,
h6 {display:block; line-height:1.3;}

b {color:var(--color-blue);}
i {font-style:normal;}
u {text-decoration:underline;}
em {font-weight:bold;}
strong {font-size:1.4em;}
mark {background:transparent;}

q {}
q:before,
q:after {content:'"';}
s {text-decoration:underline;}
del {text-decoration:line-through;}

ins {}
iframe {}

ruby {}
rt {font-size:0.5em;}

sup {vertical-align:super; font-size:smaller;}
sub {vertical-align:sub; font-size:smaller;}

details {margin:0 0 40px 0;}

hr {margin:4em 0; border:0; border-top:1px solid #cbcacb; border-color:var(--color-border); height:0;}

table {
	border-collapse:collapse; border-spacing:0; empty-cells:show; border:0; width:100%; margin:0 0 3em 0; border-top:1px solid #cbcacb; border-color:var(--color-border);
}
table th,
table td {
	padding:2.2em 1em; vertical-align:top; border-bottom:1px solid #cbcacb; border-color:var(--color-border);
}
table th {vertical-align:middle; text-align:center;}
table td span {display:block; font-size:15px; font-size:1.5rem;}
table caption {
	text-align:left; padding:8px;
}


	
	

::-moz-selection {background-color:#cbcacb; background-color:var(--color-gray); color:#ffffff;}
::selection {background-color:#cbcacb; background-color:var(--color-gray); color:#ffffff;}

/******************/
/******************/
/* shortcodes *****/

.alignright,
.align-right,
.textright,
.text-right {text-align:right;}
.alignleft, .align-left, .textleft, .text-left {text-align:left;}
.center, .aligncenter, .align-center, .textcenter, .text-center {text-align:center; margin-left:auto; margin-right:auto;}
.clear {clear:both;}
.clearfix:after {content:""; clear:both; display:block; height:0; visibility:hidden;}
.empty {visibility:hidden;}
.hide,
.none {display:none;}
.hidden {overflow:hidden;}
.left, .floatleft, .float-left {float:left;}
.right, .float-right, .float-right {float:right;}
.relative {position:relative;}
.absolute {position:absolute;}
.nowrap {white-space:nowrap;}
.small,
.text-small {font-size:0.8em;}

img.left,
img.alignleft,
img.align-left {margin:0 20px 20px 0; float:left;}
img.right,
img.alignright,
img.align-right {margin:0 0 20px 20px; float:right;}

img.full {max-width:100%; width:100%; height:auto;}

table.table-border,
table.table-border th,
table.table-border td {border:1px solid #cbcacb; border-color:var(--color-border);}

table.table-hover tbody tr:hover,
table.table-hover tbody tr:nth-child(odd):hover,
table.table-hover tbody tr:nth-child(even):hover {background-color:#cbcacb; background-color:var(--color-gray); color:#ffffff; cursor:text;
}

table.table-stripe tbody tr:nth-child(odd) {background-color:#cbcacb; background-color:var(--color-border);}
table thead th {vertical-align:bottom;}


.inner {
	clear:both; display:block; margin:0 auto; position:relative; max-width:1700px; width:100%;
	padding:0 2vw;
	padding-left:calc(20px + 4xw);
	padding-right:calc(20px + 4xw);
}
.inner[data-width="max"] {max-width:2400px;}
.inner[data-width="mid"] {max-width:1600px;}
.inner[data-width="min"] {max-width:1300px;}

@media (max-width:600px) {
	.inner {padding:0 3vw;}
}

/******************/
/******************/
/* WordPress Tags */

img.size-full,
img.size-large,
.wp-post-image,
.post-thumbnail img {
max-width:100%;
width:100%;
height:auto;
}

.wp-caption {}
.wp-caption-text {}
.sticky {}
.gallery-caption {}
.bypostauthor {}
#wpstats {display:none;}

.wp-embedded-content {max-width:100%; width:100%;}
.wp-video {margin:0 0 1em 0; max-width:100%; width:100%;}
.wp-video-shortcode {margin:0 0 1em 0; max-width:100%; width:100%;}

/******************/
/******************/

.site {}
.site-header {}
.site-navi {}
.site-main {}
.site-footer {}
.site-background {}

/******************/
/******************/
/* header *********/

.site-background {}


.site-header {
	width: 220px;
	width: calc(220px + 2%);
	min-height: 100vh;
	display: block;
	position: absolute;
	backface-visibility: hidden;
	top: 0;
	left: 0;
	padding: 0 1.5% 0;
	margin: 0;
	-ms-overflow-style: none;
	scrollbar-width: none;
	background:transparent;
	/* box-shadow: 0 0 50px #f8f8f6;
	box-shadow: 0 0 15px rgba(0,0,0,0.1); */
	z-index: 99;
}
.site-header::before {
	content:"";
	position:fixed;
	top:0; left:0; bottom:0; min-height:100vh;
	width:19px;
	background:var(--color-gradient);
	z-index:8000;
}


.site-header.is-fixed {position:fixed; bottom:0; top:auto;}
.site-header.fixed-bottom {position:fixed; bottom:0; top:auto;}
.site-header.is-ie,
.site-header.is-ie.is-fixed,
.site-header.is-ie.fixed-bottom {position:absolute; top:0; bottom:auto;}


.site-header .inner {display:flex; justify-content:space-between; align-items:center;}

.header-logo {
	margin:0 0 1vw 0;
	padding: 60px 10px 30px 20px;
	position:relative;
}
.header-logo .site-title {
	display:block; margin:0; white-space:nowrap; overflow:hidden; position:relative;
	height:auto;
}
.header-logo .site-title a {
	display:block;
}
.header-logo .site-title a:hover {color:#cbcacb; color:var(--color-gray);}
.header-logo .site-description {display:block; margin:0.6em auto 0;}


.site-utility {
	position:fixed; top:35px; right:35px;
	display:flex; align-items:center;
	background:var(--color-gradient);
	color:#fff;
	border-radius:50px;
	width:fit-content; line-height:1;
	padding:0.6em 0.6em 0.6em 1.2em;
	z-index:8888;
}
.site-utility ul {
	padding:0.14em 0.14em; font-size:22px; font-size:2.2rem; letter-spacing:0; display:flex; justify-content:space-between;
	align-content: center;
	text-align:left;
}
.site-utility ul li {display:flex; align-items: stretch;}
.site-utility ul li.phone {
	font-size:26px; font-size:2.6rem;
	padding:0.36em 0 0 1.6em;
	margin:0 1em 0 0.2em;
	letter-spacing:var(--letter-spacing);
	background:url("images/icon-phone-white.svg") left center no-repeat;
	background-size:1em auto;
}
.site-utility ul li.phone a {
	display: inline;
	background:linear-gradient(to top, currentColor 1px, transparent 99%) no-repeat;
	background:linear-gradient(to top, var(--color-white), var(--color-white)) no-repeat left bottom 1px;
	transition: var(--transition);
	background-position: 0% 100%;
	background-size: 0% 1px;
}
.site-utility ul li.phone a:hover {
	background-size: 200% 1px;
}




.site-utility ul li.contact {text-align:left;}
.site-utility ul li.contact a {
	background:#fff url("images/icon-mail.svg") right 1em center no-repeat;
	background-size:1em auto;
	border:1px solid var(--color-white);
	border-radius:30px;
	color:var(--color-blue);
	padding:0.4em 2.6em 0.4em 1em;
	display:block;
}
.site-utility ul li.contact a:hover {
	background-color: var(--color-blue);
	background-image:url("images/icon-mail-white.svg");
	color:#fff;
}


/******************/
/******************/
/* navi ***********/



.header-navi {
	position:absolute;
	padding:5em 0 1.5em 2.5em; display:block;
	color:black;
	z-index:777;
}
.header-navi ul {
	display:block; list-style:none; margin:0; padding:0;
	text-align:left;
}
.header-navi ul li {
	margin:0 0 2.0em 0;
	display:flex; align-items:center;
}
.header-navi ul li::before {
	content:""; width:0.6em; height:0.3em;
	margin:0 0.5em 0 0;
	background:url("images/arrow-right-gray.svg") left center no-repeat;
	background:100% auto;
	opacity:0.8;
}
.header-navi ul li[class*="current"] a {
	color:var(--color-blue);
}
.header-navi ul li[class*="current"]::before {
	background-image:url("images/arrow-right-blue.svg");
	opacity:1;
}
.header-navi ul li i {
	display:block; font-size:24px; font-size:2.4rem;
	transition:var(--transition);
}
.header-navi ul li span {
	position:absolute; display:block;
	opacity:0;
	top:50%; left:0; white-space:nowrap;
	transform:translateY(-50%);
	transition:var(--transition);
}
.header-navi ul li a {
	position:relative;
	display:inline-block; padding:0;
	color:var(--color-black);
	mix-blend-mode: difference;
}
.header-navi ul li a span::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: -3px;
	width: 100%;
	height: 1px;
	background: var(--color-gradient);
	transition: var(--transition);
	transform: scaleX(0);
	transform-origin: left;
}
.header-navi ul li a:hover span::after {
	transform: scaleX(1);
}
.header-navi ul li a:hover {color:var(--color-blue);}
.header-navi ul li a:hover i {opacity:0;}
.header-navi ul li a:hover span {opacity:1;}

.header-navi ul li.is-dark::before {
	background-image:url("images/arrow-right-white.svg");
	opacity:1;
}
.header-navi ul li.is-dark[class*="current"]::before {
	opacity:1;
}
.header-navi ul li.is-dark a {
	color:#fff;
}
.header-navi ul li.is-dark a::after {background-color: var(--color-white);}
.header-navi ul li.is-dark a span::after {background: var(--color-white);}


.header-toggle {
	display:none; background:transparent; cursor:pointer; position: relative;
}
.header-toggle span {display:block; width:36px; height:36px; position:relative;}
.header-toggle span:before,
.header-toggle span:after {
	position:absolute; content:"";
	display:inline-block;
	left:0;
	width:100%;
	height:2px;
	transition:all 0.4s;
	background-color:var(--color-white); 
	border-radius:2px;
}

.header-toggle span:before {top:12px;}
.header-toggle span:after {bottom:12px;}
.header-toggle i {
	position:absolute; width:36px; height:36px; top:0; left:0; color:transparent;
	transition:all 0.4s;
}
/******************/
/* utility ********/

.header-utility {}

.header-utility {
	width: fit-content;
	margin: 1em 0 0 auto;
	background-color: var(--color-border);
	background-color:#e6ddd2;
	border-radius: 999px;
	border: 1px solid var(--color-border);
	padding:0.3em;
	cursor: pointer;
}
.header-utility ul {
	display: flex;
	align-items: center;
	justify-content: center;
	cursor:pointer;
}
.header-utility ul li .button {
	display: block;
	padding: 0.5em 1em; margin:0; background:none;
	border-radius: 999px;
	font-size: 0.8em;
	cursor:pointer;
}
.header-utility .is-current .button {
	background-color: var(--color-white);
	color: var(--color-black);
}

@media (max-width:900px) {
	.site-header {display: contents;}
	.header-logo {width:fit-content; max-width:150px; margin:0; padding:20px 0 0 32px;}
	.site-utility {padding: 0.6em 1em;}
	.site-utility ul {display:none;}
	.header-toggle {display:block;}
	.header-toggle.is-active {}
	.header-navi {display:none; padding-left:3em; padding-right:3em; width:100%; right:100%; transition:var(--transition);}
	.header-navi.is-active {
		position:fixed;
		display:block; background:var(--color-gradient);
		top:0; left:0; bottom:0;
		right:0;
	}
	.header-navi ul {display:inline-block; margin:0 auto; padding:2em 0; font-size:24px; font-size:2.4rem;}
	.header-navi ul li[class*="current"] a {color:var(--color-white);}
	.header-navi ul li[class*="current"]::before {background-image:url("images/arrow-right-white.svg");}
	.header-navi ul li a {color:var(--color-white); mix-blend-mode:normal;}
	.header-navi ul li i {font-size:30px; font-size:3.0rem;}
	.header-navi ul li i {font-size:30px; font-size:3.0rem;}
	
	body.is-navi {overflow:hidden;}
}

@media (max-width:600px) {
	.site-utility {top:20px; right:20px;}
	.header-logo {width:130px; padding-top:12px;}
	.header-toggle {display:block;}
}
/******************/
/******************/
/* footer *********/


.site-pagetop {
	position:fixed; display:block;
	bottom:20px; right:20px;
	width:4em; height:4em;
	opacity:0;
	transition:var(--transition);
	z-index:88;
}
.site-pagetop.is-active {
	opacity:1;
}
.site-pagetop button {
	background-color:var(--color-white);
	padding: 0;
	width:100%; height:100%; position:relative;
	color: transparent;
	display: block;
	border-radius:50%;
	border:1px solid var(--color-blue);
	transition:var(--transition);
	cursor:pointer;
	overflow: hidden;
	will-change: opacity;
}


.site-pagetop button i {color:transparent; position:absolute;}
.site-pagetop button span {
	position:absolute;
	display:block;
	width:2em; height:2em;
	background:center center no-repeat;
	background-image:url("images/site-pagetop.svg");
	background-size:100% auto;
	top:50%; left:calc(50% - 1em);
	transform:translateY(-50%);
	will-change: transform;
}
.site-pagetop button:hover {
	background:var(--color-gradient);
	color:var(--color-white);
	transform:translateY(-0.7rem);
}
.site-pagetop button:hover span {background-image:url("images/site-pagetop-white.svg");}
.site-pagetop button:hover span {
	animation:
		arrow-up-out 0.4s ease-out forwards,
		arrow-up-in 0.4s ease-out 0.4s forwards;
}
.site-pagetop button:not(:hover) span {
	animation:
		arrow-up-out-reset 0.4s ease-out forwards,
		arrow-up-in-reset 0.4s ease-out 0.4s forwards;
}


.site-footer {
	clear:both;
	text-align:center; padding:100px 0 0 0;
	padding-top:calc(50px + 5vw);
	line-height:var(--line-height);
	background:var(--color-gradient);
	color:var(--color-white);
	position:relative;
	overflow:hidden;
}
.site-footer::before {
	content:"";
	position:absolute;
	display:block;
	top:0; left:0; right:0; bottom:0;
	background:var(--color-gradient); pointer-events:none;
	opacity:0.75;
	z-index: 3;
}
.site-footer .background {
	position:absolute;
	display:block;
	top:0; left:0; right:0; bottom:0;
	width:100%; height:auto;
	z-index:2;
}
.site-footer .background video {
	min-width:100%; min-height:100%; width:100%;
	display:block;
	object-fit: cover;
	object-position: center center;
}

.footer-logo {position:relative; z-index:5;}
.footer-logo dl {margin:0 auto 1em; max-width:560px; line-height:var(--line-height-large);}
.footer-logo dl dt {margin:0 auto 1em; min-width:140px; width:15vw; max-width:200px;}
.footer-logo dl dt img {width:100%; height:auto;}
.footer-logo dl dt a {}
.footer-logo dl dt a:hover {}
.footer-logo dl dd {margin:0 auto 1em;}
.footer-logo dl dd.title {font-size:20px; font-size:2.0rem; margin:0 auto 1em;}
.footer-logo dl dd.text {font-size:18px; font-size:1.8rem; margin:0 auto 0.1em;}
.footer-logo dl dd.tel {
	font-size:40px; font-size:4.0rem; letter-spacing:var(--letter-spacing); line-height:1;
	background:url("images/icon-phone-white.svg") 0 center no-repeat;
	background-size:0.8em auto;
	padding:0 0 0 1.2em;
	width:fit-content;
	display:block;
}
.footer-logo dl dd.tel a {position:relative;}
.footer-logo dl dd.tel a::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: 1px;
	width: 100%;
	height: 1px;
	background: var(--color-white);
	transition: var(--transition);
	transform: scaleX(0);
	transform-origin: left;
}
.footer-logo dl dd.tel a:hover::after {transform: scaleX(1);}

.footer-navi {position:relative; z-index:5;}
.footer-navi ul {display:flex; justify-content:center; gap:2%; font-size:14px; font-size:1.4rem; margin:0 auto 4vw;}
.footer-navi ul li a {color:#fff; position:relative; display:flex; align-items:center;}
.footer-navi ul li a::before {
	content:"";
	display:block;
	width:2px; height:2px; margin:0 0.2em 0 0;
	background:#fff; border-radius:10px;
}
.footer-navi ul li a::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: -3px;
	width: 100%;
	height: 1px;
	background: var(--color-white);
	transition: var(--transition);
	transform: scaleX(0);
	transform-origin: left;
}
.footer-navi ul li a:hover::after {
	transform: scaleX(1);
}

small.site-info {position:relative; display:block; clear:both; font-size:16px; font-size:1.6rem; margin:2em auto 8em; z-index:9;}
small.site-info a {color:#cbcacb; color:var(--color-gray);}
small.site-info a:hover {color:#cbcacb; color:var(--color-gray);}

/******************/
/******************/
/* main ***********/

.site-main {
	display:flow-root;
	padding: 0;
	padding-left: calc(220px + 2%);
	position: relative; text-align:left;
	line-height: 2.1;
	letter-spacing:var(--letter-spacing);
	-webkit-hyphens: auto;
	-moz-hyphens: auto;
	-ms-hyphens: auto;
	hyphens: auto;
}


.main-header {}
.main-thumbnail {}
.main-content {}
.main-sidebar {}
.main-footer {}


.main-header {
	padding: 134px 0 8vw 2vw;
	position: relative;
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	justify-content: center;
	overflow: hidden;
}


@media (max-width:900px) {
	.site-main {padding:0 0 0 19px;}
	.main-header {padding: 20px 0 8vw 2vw;}
}

/******************/
/******************/
/* sidebar.php ****/



.main-content.has-sidebar {
	float:right;
	width:100%;
	width:calc(100% - 320px);
	margin:0 0 0 auto;
}

.main-sidebar {
	position:sticky;
	top:52px;
	width: 240px;
	padding:0 0 0 2vw;
	float:left;
	z-index:8;
}

.main-footer {
	position:relative;
	min-width:100%;
	clear:both;
}


@media (max-width:800px) {
	.main-sidebar {display:block; position:relative; width:100%; float:none; padding:0 2vw; top:inherit;
		margin:0 0 6em 0;
	}
	.main-content.has-sidebar {width:100%; float:none;}

}

/******************/
/******************/
/* main-content ***/


.article h1,
.article h2,
.article h3,
.article h4,
.article h5,
.article h6 {margin:0 auto 1em auto; line-height:1.3;}

.article h1 {font-size:51px; font-size:5.1rem;}
.article h2 {font-size:45px; font-size:4.5rem;}
.article h3 {font-size:32px; font-size:3.2rem;}
.article h4 {font-size:28px; font-size:2.8rem;}
.article h5 {font-size:24px; font-size:2.4rem;}
.article h6 {font-size:22px; font-size:2.2rem;}

.article p {margin:0 0 2em 0;}

.single-content ul,
.single-content ol {margin:0 0 2em 0; padding:0; list-style:outside;}

.article ul ul,
.article ul ol,
.article ol ul,
.article ol ol {margin-bottom:0;}

.article ul {list-style:none;}
.article ul ul {list-style:circle;}
.article ol {list-style:none;}
.article ol ol {list-style:upper-roman;}

.single-content ul li {padding:0 0 0 1.4em; padding-right:1.4em; text-indent:-1.4em;}
.single-content ul li:before {content:""; display:inline-block;
background:url("images/arrow-r-dark.svg") center center no-repeat; width:1em; height:1em; background-size:12px 12px;
vertical-align:middle;
margin:0 0.4em 0 0;
}
.single-content ul li a {color:var(--color-gray);}
.single-content ul li a:hover {color:var(--color-blue); text-decoration:underline;}

.single-content ol li {padding:0 0 0 1.6em; text-indent:-1.4em; text-indent:calc(-12px - 0.4em);
	list-style:none;
	counter-increment:number;
}
.single-content ol li:before {content:counter(number) "."; margin:0 0.4em 0 0;}

.article dl {margin:0 0 2em 0; padding:0;}
.article dl dt {margin:0; position:relative; font-size:1.1em;}
.article dl dd {margin:0 0 1em 0; padding:0;}


.article img {max-width:100%; height:auto;}

.article blockquote {
padding:1em;
margin:0 0 2em 1em;
border-left:2px solid #231f20;
}

.article blockquote > *:last-child,
.article blockquote > *:last-child > *:last-child,
.article blockquote > *:last-child > *:last-child > *:last-child {margin:0;}

.article blockquote cite {font-size:0.8em;}
.article blockquote cite:before {content:"— "; margin:0 0 0 1em;}



/******************/
/* section ********/

.section {
	position:relative; display:block;
	padding:9vw 0; margin:0;
	padding-top:calc(70px + 5vw);
	padding-bottom:calc(70px + 5vw);
}


.section-title .title {
	display:inline-block;
	line-height:var(--line-height-mini);
}
.section-title .title i {font-size:70px; font-size:7.0rem; color:var(--color-blue);}
.section-title .title span {
	font-size:21px; font-size:2.1rem;
	margin:0 auto 0 1em;
	white-space:nowrap;
	color:var(--color-black);
}
.section-title .title span b {
	display:flex;
	justify-content:flex-start; align-items:center;
	color:var(--color-black);
}
.section-title .title span b::before {
	content:"";
	display:block;
	width:3em; height:1px; background:var(--color-gray);
	margin:0 0.5em 0 0;
}
.section-title .title::after {}
.section-title .subtitle {font-weight:bold;}
.section-title .description {font-size:15px; font-size:1.5rem;}

h4.title span {
	font-size:21px; font-size:2.1rem;
	margin:0.5em auto 0 0;
}
h4.title span b {
	display:flex;
	justify-content:flex-start; align-items:center;
	color:var(--color-black);
}
h4.title span b::before {
	content:"";
	display:block;
	width:2em; height:1px; background:var(--color-gray);
	margin:0 0.5em 0 0;
}


@media (max-width:700px) {
	.section-title .title {line-height:1; display:block;}
	.section-title .title i {display:block;}
	.section-title .title span {margin:0 0 0 0;}
}





/******************/
/******************/
/* front-page.php */


.load {
	cursor: pointer;
	background-color: var(--color-blue);
	background-position: center center;
	background-repeat: no-repeat;
	display:flex; justify-content:center; align-items:center;
	flex-direction: column;
	position: fixed;
	width: 100%;
	height: 100%;
	min-height: 100%;
	overflow: hidden;
	margin: 0;
	padding: 0;
	z-index: 0;
	top: 0;
	left: 0;
	z-index: 9999;
}

.load video{
	min-width: 100%;
	min-height: 100%;
	width: 100%;
	height: 100%;
	left: 0;
	position: absolute;
	object-fit: cover;
	pointer-events:none;
}

.load .load-logo {
	color:#fff; text-align:center; padding:0; margin-top:-4vw;
	width:100%; max-width:calc(200px + 2vw);
	z-index:99;
}

.load .load-logo.open {
	animation:openanimation 1.2s ease;
}


.load .load-logo.close {
	animation:animation2 2s ease;
}

@keyframes openanimation {
	from {transform:scale(100,100);}
	to {transform:scale(1,1);}
}

@keyframes animation2 {
	from {transform:scale(1,1);}
	to {transform:scale(100,100);}
}

.load .button {z-index:88; position:relative;}




/******************/


.home .site-main {overflow:hidden;}
.section-top-slider {
	position:relative; margin:0;
	padding:0 0 0 4vw;
	display:flex; align-items: center;
	height:80vh;
	min-height:700px;
	overflow:visible;
}
.section-top-slider .top-slider-title {
	height:100%;
	display:flex; align-items:center; justify-content:center;
	flex-direction:column;
	flex-wrap:wrap;
	line-height:var(--line-height-mini);
	color:#fff;
	position:relative;
	line-height:var(--line-height);
	mix-blend-mode: difference;
	z-index:2;
}
.section-top-slider .top-slider-title .copy {
	display:block;
	margin:18% 0 3em 0;
	position:relative;
}
.section-top-slider .top-slider-title .copy i {
	display:block;
	font-size:70px; font-size:5.0vw;
	line-height:var(--line-height-mini);
	letter-spacing: -0.04em;
	position:relative;
}
.section-top-slider .top-slider-title .copy span {
	display:block;
	font-size:22px; font-size:2.2vw;
	margin:0.5em auto 0 0;
}

.section-top-slider .top-slider-title .title {
	line-height:var(--line-height-mini);
	margin:0 auto 0 0;
	font-size:17px; font-size:1.0vw;
	visibility:hidden;
}



.section-top-slider .top-slider-box {
	position:absolute;
	top:110px; right:0; bottom:0;
	width:70%;
	pointer-events:none;
	z-index:1;
}
.section-top-slider .top-slider-box::after {
	content:"";
	display:block;
	position:absolute;
	left:-32px; bottom:-32px;
	width:80%; height:30%;
	background:var(--color-gradient);
	z-index:0;
}
.section-top-slider .top-slider-swiper {
	transition:var(--transition);
	will-change:filter, opacity;
	position:relative;
	z-index:1;
}
.section-top-slider .top-slider-swiper.is-blur {
	filter: blur(7px);
}
.section-top-slider .top-slider-swiper.is-blur-2 {
	filter: blur(11px);
	opacity:0.5;
}
.section-top-slider .top-slider-swiper.is-blur-3 {
	opacity:0;
}

.section-top-slider .swiper-container {
	width:100%; height:100%;
	line-height:0;
	overflow:hidden;
}
.section-top-slider .swiper-wrapper {
	transition-timing-function:linear;
	will-change:transform;
}
.section-top-slider .swiper-slide {
	width:100%;
	height:100%;
	margin:0 0 0;
	overflow: hidden;
}
.section-top-slider .swiper-slide .thumbnail {
	overflow:hidden;
	width:100%; height:100%;
	aspect-ratio:4 / 3;
}
.section-top-slider .swiper-slide img {
	width:100%; height:100%; object-fit:cover;
}


@media (max-width:1100px) {
	.section-top-slider .top-slider-box {
		bottom:auto;
		aspect-ratio:1 / 1;
	}
}




@media (max-width:900px) {
	.section-top-slider {
		padding:0;
		margin:0 0 8vw 0; display:block;
		height:auto;
		min-height:auto;
	}
	.section-top-slider .top-slider-title {
		padding:0 20px;
	}
	.section-top-slider .top-slider-box {aspect-ratio:2 / 1;}
	.section-top-slider .top-slider-title .copy i {
		font-size: 70px;
		font-size: 7.0vw;
	}
	.section-top-slider .top-slider-title .copy span {font-size:3.1vw;}
	.section-top-slider .top-slider-title .title {font-size:21px; font-size:2.1rem;}
	.section-top-slider .top-slider-title .subtitle {font-size:19px; font-size:1.9rem; margin:0 auto 0 0;}
	.section-top-slider .top-slider-box {
		position:relative;
		top:auto; right:auto; bottom:auto;
		width:100%;
		height:auto;
	}
	.section-top-slider .swiper-slide {width:50%; height:auto;}
}
@media (max-width:700px) {
	.section-top-slider .flex-container {flex-direction: column-reverse;}
}


.section-top-about {
	position:relative; z-index:3;
}
.section-top-about .flex-item:nth-child(1) {flex-basis:45%;}
.section-top-about .flex-item:nth-child(2) {flex-basis:45%; padding: 0 0 0;}

.section-top-about .video {
	position:relative;
	aspect-ratio:2 / 1;
	overflow:hidden;
}
.section-top-about .video video {object-fit: cover; width:100%; height:100%;}



@media (max-width:1000px) {
	.section-top-about .flex-container {display:block;}
}




.list-company ul {display:flex; justify-content:space-between;
	flex-wrap:wrap;
}
.list-company ul li {border-bottom:1px solid var(--color-border); flex-basis:48%;}
.list-company ul li:nth-child(-n+2) { /* 2以下 */
	border-top:1px solid var(--color-border);
}
.list-company ul li a {
	display:flex;
	justify-content:flex-start;
	align-items: center;
	padding:1em 0 1em 1em;
	position:relative;
}

.list-company ul li a::before {
	content:"";
	display:block; width:4px; height:4px; background:var(--color-gradient);
	margin:0 0.6em 0 0;
	border-radius:10px;
}
.list-company ul li .thumbnail {
	max-width:120px; margin:0 1em 0 0;
	border:1px solid var(--color-gray);
	aspect-ratio:3 / 2;
	overflow:hidden;
	border-radius: var(--border-radius-mini);
}
.list-company ul li .thumbnail img {object-fit:cover; width:100%; height:100%; transition:var(--transition);}
.list-company ul li .icon {
	position:relative;
	border-radius:50%;
	width:1.5em; height:1.5em;
	background:var(--color-gradient);
	margin:auto 1em auto auto;
	overflow:hidden;
	transition:var(--transition);
	z-index:3;
}
.list-company ul li .icon::after {
	content:"";
	position: absolute;
	top:calc(50% - 0.15em); left:55%;
	transform: translateX(-50%);
	width:0.6em; height:0.3em;
	background:url("images/arrow-right-white.svg") center center no-repeat;
	background-size:100% auto;
	margin:0;
}

.list-company ul li a:hover {color:var(--color-blue);}
.list-company ul li a:hover .thumbnail {border-color:var(--color-blue);}
.list-company ul li a:hover .thumbnail img {transform:scale(1.2);}
.list-company ul li a:hover::after {
	animation: slide-in var(--transition) ease-out forwards;
}
.list-company ul li a:not(:hover)::after {
	animation: slide-out var(--transition) ease-in forwards;
}

.list-company ul li a:hover .icon::after {
	background-image:url("images/arrow-right-white.svg");
	animation:
		slide-out-arrow 0.2s ease-in forwards,
		slide-in-arrow 0.2s ease-out 0.2s forwards;
}

.list-company ul li a:not(:hover) .icon::after {
	animation:
		slide-out-reset 0.2s ease-in forwards,
		slide-in-reset 0.2s ease-out 0.2s forwards;
}

@media (max-width:1200px) {
	.list-company ul {display:block;border-top:1px solid var(--color-border);}
	.list-company ul li,
	.list-company ul li:nth-child(-n+2) {border-top:0;}
}



.section-top-loopslider {padding:0; overflow:hidden;}
.home .section-top-loopslider {overflow:visible;}

.section-top-loopslider .scroll {}
.section-top-loopslider .swiper-slide {
	display:block; width:180px;
}

.section-top-loopslider .swiper-wrapper {
	transition-timing-function:linear;
	will-change:transform;
}

@media (max-width:1000px) {
	.section-top-loopslider .swiper-slide {width:160px;}
}
@media (max-width:800px) {
	.section-top-loopslider .swiper-slide {width:120px;}
}
@media (max-width:600px) {
	.section-top-loopslider .swiper-slide {width:90px;}
}
@media (max-width:400px) {
	.section-top-loopslider .swiper-slide {width:80px;}
}


.section-top-service {}

@media (max-width:1200px) {
	.section-top-service .swiper-container .module {top:20px;}
}



.section-top-news {position:relative; background-color:var(--color-background);}
.section-top-news::before {
	content:"";
	position:absolute;
	display:block;
	top:0; left:-100%; right:0; bottom:0;
	background-color:var(--color-background);
	z-index:-1;
}


.swiper-container {position:relative;}
.swiper-container .module {
	position:absolute; top:-6em; right:0;
	display:flex;
	justify-content:flex-start; align-items:center;
	z-index:3;
}
.swiper-container .module .button {margin:0;}

.swiper-container .swiper-button-prev,
.swiper-container .swiper-button-next {
	position:relative; display:block;
	width:2.3em; height:2.3em;
	background-color:transparent;
	margin:0 1em 0 0;
	border:1px solid var(--color-blue);
	border-radius:50%;
	top:auto; left:auto; right:auto;
	overflow:hidden;
	transition:var(--transition);
}

.swiper-container .swiper-button-prev:before,
.swiper-container .swiper-button-next:before,
.swiper-container .swiper-button-prev:after,
.swiper-container .swiper-button-next:after {
	content:"";
	font-size:1em;
	width:0.8em; height:0.8em;
	position:absolute;
	top:calc(50% - 0.4em);
	left:calc(52% - 0.4em);
	background:center center no-repeat;
	background-image:url("images/arrow-right-blue.svg");
	background-size:auto;
	transition:none;
	animation:none;
	will-change:transform;
} 
.swiper-container .module .swiper-button-prev:before {
	background-image:url("images/arrow-left-blue.svg");
} 

.swiper-container .module .swiper-button-prev:after,
.swiper-container .module .swiper-button-next:after {
	transform:translateX(-200%);
	display:none;
}


.swiper-container .swiper-button-prev:hover,
.swiper-container .swiper-button-next:hover {
	background-color:var(--color-blue);
}
.swiper-container .swiper-button-prev:hover::before {
	background-image:url("images/arrow-left-white.svg");
	animation:
		arrow-out-reverse 0.4s ease-out 0.1s forwards,
		arrow-in-reverse 0.4s ease-out 0.4s forwards;
}
.swiper-container .swiper-button-next:hover::before {
	background-image:url("images/arrow-right-white.svg");
	animation:
		arrow-out 0.4s ease-out 0.1s forwards,
		arrow-in 0.4s ease-out 0.4s forwards;
}
.swiper-container .swiper-button-prev:not(:hover)::before {
	animation:
		arrow-out-reverse-reset 0.4s ease-out 0.1s forwards,
		arrow-in-reverse-reset 0.4s ease-out 0.4s forwards;
}
.swiper-container .swiper-button-next:not(:hover)::before {
	animation:
		arrow-out-reset 0.4s ease-out 0.1s forwards,
		arrow-in-reset 0.4s ease-out 0.4s forwards;
}

.swiper-container .swiper-button-disabled {background-color:transparent; border-color:var(--color-border);}
.swiper-container .swiper-button-next.swiper-button-disabled::before {
	opacity:1;
	/*background-image:url("images/arrow-right-gray.svg");*/
	background-image:url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIGlkPSJf44Os44Kk44Ok44O8XzIiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgdmlld0JveD0iMCAwIDMyIDMyIj48ZGVmcz48c3R5bGU+LmNscy0xe2ZpbGw6I2U5ZThlODt9PC9zdHlsZT48L2RlZnM+PGcgaWQ9Il/jg6zjgqTjg6Tjg7xfMS0yIj48cGF0aCBjbGFzcz0iY2xzLTEiIGQ9Ik0xOSwzMWMwLTUuMjMsMS41Ni0xNCwxMi0xNCwuNTUsMCwxLS40NSwxLTFzLS40NS0xLTEtMWMtMTAuNDQsMC0xMi04Ljc3LTEyLTE0LDAtLjU1LS40NS0xLTEtMXMtMSwuNDUtMSwxYzAsNi42MiwyLjMsMTEuNDcsNi4zOCwxNEgxYy0uNTUsMC0xLC40NS0xLDFzLjQ1LDEsMSwxaDIyLjM4Yy00LjA4LDIuNTMtNi4zOCw3LjM4LTYuMzgsMTQsMCwuNTUuNDUsMSwxLDFzMS0uNDUsMS0xWiIvPjwvZz48L3N2Zz4=");
}
.swiper-container .swiper-button-prev.swiper-button-disabled::before {
	opacity:1;
	/*background-image:url("images/arrow-left-gray.svg");*/
	background-image:url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIGlkPSJf44Os44Kk44Ok44O8XzIiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgdmlld0JveD0iMCAwIDMyIDMyIj48ZGVmcz48c3R5bGU+LmNscy0xe2ZpbGw6I2U5ZThlODt9PC9zdHlsZT48L2RlZnM+PGcgaWQ9Il/jg6zjgqTjg6Tjg7xfMS0yIj48cGF0aCBjbGFzcz0iY2xzLTEiIGQ9Ik0xMywxYzAsNS4yMy0xLjU2LDE0LTEyLDE0LS41NSwwLTEsLjQ1LTEsMXMuNDUsMSwxLDFjMTAuNDQsMCwxMiw4Ljc3LDEyLDE0LDAsLjU1LjQ1LDEsMSwxczEtLjQ1LDEtMWMwLTYuNjItMi4zLTExLjQ3LTYuMzgtMTRoMjIuMzhjLjU1LDAsMS0uNDUsMS0xcy0uNDUtMS0xLTFIOC42MmM0LjA4LTIuNTMsNi4zOC03LjM4LDYuMzgtMTQsMC0uNTUtLjQ1LTEtMS0xcy0xLC40NS0xLDFaIi8+PC9nPjwvc3ZnPg==");
}

@media (max-width:1200px) {
	.swiper-container .module {position:relative; top: auto;}
}


.section-top-links {}
.section-top-links .flex-container {gap:4%;}
.section-top-links .flex-container .flex-item {flex-basis:48%;}

.section-top-links a {
	display:block; position:relative; color:#fff;
	border-radius:var(--border-radius-mini);
	overflow:hidden;
}
.section-top-links a::before {
	content:"";
	position:absolute;
	top:0; left:0; right:0; bottom:0;
	background:var(--color-gradient);
	transition:var(--transition);
	opacity:0.8;
	z-index:3;
}
.section-top-links a::after {
	content:""; pointer-events:none;
	position:absolute;
	top:4px; left:4px; right:4px; bottom:4px;
	border:1px solid var(--color-white);
	border-radius:var(--border-radius-mini);
	opacity:0.4;
	z-index:4;
}
.section-top-links .background img {transition:var(--transition);}
.section-top-links .title {
	position:absolute;
	top:50%; left:2em; transform:translateY(-50%);
	line-height:var(--line-height-mini);
	z-index:5;
}
.section-top-links .title i {
	display:block;
	font-size:30px; font-size:3.0rem;
}
.section-top-links .text {
	position:absolute;
	right:1em; top:50%; max-width:65%;
	transform:translateY(-50%);
	font-size:14px; font-size:1.4rem;
	z-index:5;
}

.section-top-links a:hover::before {opacity:0.5;}
.section-top-links a:hover .background img {
	transform:scale(1.1);
}

@media (max-width:1300px) {
	.section-top-links .flex-container {display:block;}
	.section-top-links .flex-container .flex-item {margin:0 0 4% 0;}
}

/******************/
/* page.php *******/

.article-about .section {padding:0;}

.article-about .archives-about ul {
	position:relative;
	display:flex; justify-content:flex-start; gap:5%; flex-wrap:wrap;
	z-index:2;
}
.article-about .archives-about ul li {flex-basis:47.5%; margin:0 0 8% 0; line-height:0;}
.article-about .archives-about ul li a {
	display:block; position:relative;
}
.article-about .archives-about ul li span {display:block;}
.article-about .archives-about ul li .thumbnail {
	border:1px solid var(--color-blue);
	margin:0 0 1em 0;
	overflow:hidden;
}
.article-about .archives-about ul li .thumbnail img {
	width:100%; height:auto;
	transition:var(--transition);
}
.article-about .archives-about ul li .thumbnail a:hover img {
	transform:scale(1.2);
}
.article-about .archives-about ul li .title {
	line-height:var(--line-height);
	margin:0 auto 2em 0;
	z-index:2;
}
.article-about .archives-about ul li .title i {
	display:block;font-size:36px; font-size:3.6rem;
	color:var(--color-blue);
	line-height:var(--line-height-mini);
}
.article-about .archives-about ul li .title b {
	font-size:20px; font-size:2.0rem;
	color:var(--color-black);
}


.article-about .archives-about ul li a:hover .title {}


.list-item {display:flex; justify-content:flex-start; gap:3%;}
.list-item .item {flex-basis:31.3333%;}
.list-item .item .thumbnail {
	border:2px solid var(--color-border); aspect-ratio:1 / 1; overflow:hidden;
	margin:0 0 12px 0;
}
.list-item .item .title {font-size:18px; font-size:1.8rem; border-bottom:1px solid var(--color-border); width:fit-content; text-align:left;}


.article-message .thumbnail {width:25%}
.article-message h2::before {display:none;}
.article-message .sign {text-align: right; width:fit-content; margin:2em 0 2em auto;}
.article-message .sign img {max-width:200px;}

.article-programs table {
	width:fit-content; min-width:100%;
	table-layout:fixed;
}



.article-members ul {display:flex; flex-wrap:wrap; gap:9.5%; justify-content:flex-start;}
.article-members .item {flex-basis:27%; margin:0 0 7% 0;}
.article-members .item span {display:block;}
.article-members .item .thumbnail {
	margin:0 0 0.5em 0; overflow:hidden;
	aspect-ratio:2 / 3;
}
.article-members .item .thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .3s;
	transform: scale(1.05); 
	will-change: transform;
	pointer-events: none;
}
.article-members .item .thumbnail .layer {transition: transform 0.1s;}

.article-members .item .poste {color:var(--color-gray);}
.article-members .item .name {
	font-size:25px; font-size:2.5rem; line-height:var(--line-height-mini);
	letter-spacing:0.3em;
}
.article-members .item .name i {display:block; font-size:21px; font-size:2.1rem; letter-spacing:var(--letter-spacing);}



.page-id-73 .site-main {overflow:visible;}
.article-results .contents {display:flex; justify-content:space-between;}
.article-results .content-selector {flex-basis:25%; max-width:300px;}
.article-results .content {flex-basis:70%; min-width:calc(100% - 320px);}

.article-results .content-selector ol {position:sticky; top:9em;}
.article-results .content-selector ol li {margin:0 0 0.5em 0;}
.article-results .content-selector ol li a {}
.article-results .content ol {margin:0 0 3em 0;}


.article-results .content ol {
	list-style:none; padding:0 0 0 2.4em; text-align:left;
	list-style:outside;
	list-style-type:decimal;
	font-size:21px; font-size:2.1rem;
}
.article-results .content ol li {display:list-item; margin:0; padding:40px 0; position:relative;}
.article-results .content ol li:after {content:""; position:absolute; display:block; border-bottom:1px solid var(--color-border); top:0; left:-2.4em; width:calc(100% + 2.4em);}
.article-results .content ol li span {display:block;}
.article-results .content ol li .title {line-height:var(--line-height-mini); margin:0 0 0.5em 0;}
.article-results .content ol li .author {font-size:14px; font-size:1.4rem; font-weight:normal;}
.article-results .content ol li .quote {font-size:14px; font-size:1.4rem; font-weight:normal;}


.article-company .section {padding-top:0;}

.article-company .section-company-customer .flex-container {justify-content:space-between; flex-wrap:wrap;}
.article-company .section-company-customer dl {flex-basis:48%;}
.article-company .box {padding:4em 0 0.1em; background:var(--color-background); position:relative;}
.article-company .box::before {
	content:"";
	position:absolute; top:0; left:-100%; right:-100%; bottom:0;
	background: var(--color-background);
	z-index:-1;
}
.article-company .box dl {position:relative;}
.article-company .box dl dd {font-size:12px; font-size:1.2rem;}


.article-company .section-company-info table td {padding:30px 0;}
.article-company .section-company-info table th {font-weight:bold; min-width:200px;}
.article-company .section-company-history ol {columns:2;}



.box.clients {padding:2em 2em 0.1em; background:var(--color-background); position:relative;
	border-radius:var(--border-radius);
}
.box.clients::before {}
.box.clients dl {position:relative;}
.box.clients dl dd {font-size:12px; font-size:1.2rem;}


.maps {
	clear:both;
	width:100%; height:30vw; min-height:450px; overflow:hidden; position:relative;
	padding-top:0; margin:3vw 0 2em 0;
	border-radius:var(--border-radius);
}

.googlemaps {width:100%; height:100%; position:absolute; top:0;}
.maps iframe {position:absolute; top:0; left:0; right:0; bottom:0; width:100%; height:100%;}



.article-hygiene .flex-container {margin-bottom:2em; gap:1px;}
.article-hygiene .flex-container .flex-item {flex-basis:calc(33.3333% - 1px);}

.article-fulltime .box,
.article-parttime .box {
	background:var(--color-background);
	padding:2em 2em 0.1em;
	border-radius:var(--border-radius-mini);
	margin:0 0 4em 0;
}

.article-contact .box {
	background:var(--color-background);
	border-radius: var(--border-radius);
	padding:6em 4em 4em;
	margin:0 auto 4em;
}
.article-contact h3 {position:relative; border:0;}
.article-contact h3::before {
	content:"";
	position:absolute;
	left:0; top:0;
	height:100%; width:auto;
	aspect-ratio:1 / 1;
	line-height:1;
	border-radius:50px;
	background:var(--color-blue) center center no-repeat;
	background-image:url("images/icon-phone-white.svg");
	background-size:1.6em auto;
}
.article-contact #contact-mail h3::before {background-image:url("images/icon-mail-white.svg");}

.article-contact h3:has(i) {
	font-size:24px; font-size:2.4rem; margin:0 auto 2em 0;
	padding:0 0 0 3.6em;
	display:block;
	border:0;
}
.article-contact h3 i {display:block; color:var(--color-blue);font-size:30px; font-size:3.0rem;}

.article-contact dl dd {
	font-size: 40px;
	font-size: 4.0rem;
	letter-spacing: var(--letter-spacing);
	line-height: 1;
	background: url("images/icon-phone-black.svg") 0 center no-repeat;
	background-size: 0.8em auto;
	padding: 0 0 0 1.2em;
	width: fit-content;
	display: block;
}
.article-contact dl dd a {position:relative;}
.article-contact dl dd a:hover {
	color:var(--color-blue);
}

.article-contact dl dd a::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: 1px;
	width: 100%;
	height: 1px;
	background: var(--color-blue);
	transition: var(--transition);
	transform: scaleX(0);
	transform-origin: left;
}
.article-contact dl dd a:hover::after {
	transform: scaleX(1);
}

@media (max-width:600px) {
	.article-contact .box {padding:4em 2em 2em;}
	.article-contact h2:has(i) {font-size:20px; font-size:2.0rem;}
	.article-contact h2 i {font-size:24px; font-size:2.4rem;}
}
@media (max-width:600px) {
	.article-contact .box {padding:2em 1em 1em;}
}

.article-privacy .columns {margin:4em auto 4em; font-size:14px; font-size:1.4rem;}
.article-privacy dl dd {margin:0 0 1em 2em;}

.article-privacy .box {
	font-size:14px; font-size:1.4rem;
	background:var(--color-background);
	padding:2em 4em 0.1em;
	border-radius:var(--border-radius);
}
.article-privacy .box dl dt {border-bottom:1px solid var(--color-border); padding:0 0 0.4em 0; margin:0 0 0.4em 0;}
.article-privacy .box dl dd {}

.article-legal dl {font-size:14px; font-size:1.4rem;}
.article-legal dl dd {margin:0 0 1em 2em;}



/******************/
/******************/
/* archive.php ****/


.archives ul {
	display:flex; flex-direction:row; justify-content:flex-start;
	flex-wrap:nowrap;
	align-items:stretch;
	list-style:none; padding:0; margin:0 0 2em 0;
}
.archives ul li {
	width:30%; height:auto;
	display:flex;
	align-items:stretch;
	margin:0; padding:0;
	background-color:var(--color-white);
	border:6px solid var(--color-white);
	border-radius:var(--border-radius);
	position:relative;
}
.top-archives-swiper ul li.swiper-slide {
	width:30%; max-width:400px;
}

.archives ul li::before {
	content:""; position:absolute; top:-4px; left:-4px; right:-4px; bottom:-4px;
	border:1px solid var(--color-border);
	border-radius:var(--border-radius);
	pointer-events:none;
}
.archives ul li a {
	display:flex;
	flex-direction:column;
	flex-grow:1;
	align-items:stretch;
	padding:0; height:100%;
}

.archives .thumbnail {
	aspect-ratio:75 / 50; overflow:hidden; line-height:1;
	position:relative;
	margin:0;
	border-radius:var(--border-radius);
	border-bottom-left-radius:var(--border-radius-mini);
	border-bottom-right-radius:var(--border-radius-mini);
	overflow:hidden;
}
.archives .thumbnail img {
	object-fit:cover; width:100%; height:100%;
	transition:var(--transition);
}
.archives .thumbnail img.overlay {
	position:absolute;
	object-fit:cover; width:100%; height:100%;
	top:0; left:0;
	transition:var(--transition); z-index:3;
}
.archives .content {
	padding:2em 2em 3em 2em;
	flex-grow:1;
	line-height:var(--line-height);
}
.archives .meta {
	font-size:15px; font-size:1.5rem;
	margin:0 0 1em 0;
	display:flex;
}
.archives .meta .date {
	color:var(--color-black); padding:0 1em 0 0; margin:0 1em 0 0;
	border-right:1px solid var(--color-border);
}
.archives .title {
	padding:0; font-size:18px; font-size:1.8rem;
	line-height:var(--line-height);
	display:-webkit-box;
	overflow:hidden;
	text-overflow: ellipsis;
	-webkit-box-orient:vertical;
	-webkit-line-clamp:2;
}
.archives .title b {
	color:var(--color-black);
	display:inline;
	background: linear-gradient(0deg, var(--color-blue), var(--color-blue)) no-repeat left bottom;
	background-size: 0 1px;
	transition:var(--transition);
}
.archives .summary {display:none;}

.archives ul li a:hover .thumbnail img {scale:1.1;}
.archives ul li a:hover {}
.archives ul li a:hover .title b {
	background-size: 100% 1px;
	color:var(--color-blue);
}
 
 
.archives ul li.links a {
	 background-color:var(--color-white); text-align:center;
	 justify-content:center;
	 border-radius:var(--border-radius);
}
.archives ul li.links i {
	 font-weight:var(--font-bold);
	 font-size:19px; font-size:1.9rem;
	 transition:var(--transition);
}
.archives ul li.links a:hover i {scale:1.1;}

#article-news .archives ul {
	flex-wrap:wrap;
	gap:4%;
}
#article-news .archives ul li {margin:0 0 5% 0;}

@media (max-width:1200px) {
	.archives ul li {width:50%;}
	.top-archives-swiper ul li.swiper-slide {width:40%;}
}
@media (max-width:800px) {
	.archives ul li {width:48%;}
	.top-archives-swiper ul li.swiper-slide {width:45%;}
	.archives .content {padding:2em 2em 2em 2em;}
}
@media (max-width:700px) {
	.top-archives-swiper ul li.swiper-slide {width:55%;}
}
@media (max-width:460px) {
	.archives ul {padding:0 2em;}
	.top-archives-swiper ul li.swiper-slide {width:75%;}
	#article-news .archives ul li {width:100%; margin:0 0 7vw 0;}
}
@media (max-width:380px) {
	.archives ul {padding:0;}
}
/******************/
/******************/
/* archive-custom-post.php */


.archives-service ul {
	display:flex; flex-direction:row; justify-content:flex-start;
	flex-wrap:nowrap;
	gap:0;
	align-items:stretch;
	list-style:none; padding:0; margin:0;
}
.archives-service ul li {
	width:30%;
	/*width:calc(100% / 3);*/
	position:relative;
}
.archives-service ul li .thumbnail {
	display:block; margin:0 auto 2em; line-height:1;
	max-width:172px;
	aspect-ratio:1 / 1;
}
.archives-service ul li img {
	width:100%; height:auto;
}
.archives-service ul li .title {
	line-height:var(--line-height);
	text-align:center;
	margin:0.4em auto 1.4em;
}
.archives-service ul li .title i {
	display:block;
	font-size:30px; font-size:3.0rem;
	color:var(--color-blue);
	line-height:1;
	margin:0 auto 0.4em;
}
.archives-service ul li .more {text-align:center; margin:0 auto;}
.archives-service ul li .more a {margin:0 auto;}
/*
.archives-custompost .mix,
.archives-custompost .gap {display:inline-block; width:20%; vertical-align:top;}
.archives-custompost #mix .mix {display:none;}
*/

@media (max-width:1200px) {
	.archives-service ul {flex-wrap:wrap;}
	.archives-service ul li {flex-basis:50%; margin:0 0 10% 0;}
	.archives-service ul li .thumbnail {max-width:150px;}
}
@media (max-width:700px) {
	.archives-service ul li .thumbnail {max-width:120px;}
}

/******************/
/* page.php single.php single-custompost.php *****/

.page-title {}
.single-title {}
.single-custompost-title {}

.page-meta {}
.single-meta {}
.single-custompost-meta {}

.page-thumbnail {}
.single-thumbnail {}
.single-custompost-thumbnail {}

.page-content {}
.single-content {}
.single-custompost-content {}


.page-thumbnail {
	margin:0 0 4em auto;
	margin-right:-5vw;
	width:90%;
	position:relative;
}
.page-thumbnail::after {
	content:"";
	display:block;
	position:absolute;
	left:-24px; bottom:-24px;
	width:80%; height:30%;
	background:var(--color-gradient);
	z-index:0;
}
.page-thumbnail .wrapper {
	aspect-ratio:3 / 1;
	overflow:hidden;
}
.page-thumbnail img {
	width:100%; height:100%; max-height:100%;
	position:relative; object-fit:cover; z-index:1;
	transform:scale(1.05);
	will-change: transform;
	transition: transform 0.05s linear;
}


@media (max-width:900px) {
	.page-thumbnail .wrapper {aspect-ratio:5 / 2;}
	.page-thumbnail::after {left: -20px; bottom: -20px;}
}
@media (max-width:600px) {
	.page-thumbnail .wrapper {aspect-ratio:2 / 1;}
	.page-thumbnail::after {left: -12px; bottom: -12px;}
}

.page-title {}
.page-title .title {
	line-height:var(--line-height-mini); text-align:left; margin:0 0 40px 0;
	
}
.page-title .title {font-size:30px; font-size:3.0rem;}
.page-title .title i {
	display:block; font-size:110px; font-size:11.0rem; display:block;
	color:var(--color-blue);
	line-height:1;
}
.page-title .title span {
	display:flex; align-items:center; margin:1em 0 0 0;
}
.page-title .title span::before {
	content:""; width:2em; height:1px; background:var(--color-gray);
	margin:0 0.5em 0 0;
}

@media (max-width:900px) {
	.page-title .title i {font-size: clamp(60px, 11vw, 40rem);}
}


.page-selector {
	margin:0 0 4vw 0;
}
.page-selector ul {
	display:block; align-items:center; justify-content:flex-start;
	flex-wrap:wrap;
	font-size:14px; font-size:1.4rem;
	border-top:1px solid var(--color-border);
}
.page-selector ul li {margin:0 0 0;
	border-bottom:1px solid var(--color-border);
	white-space:nowrap;
}
.page-selector ul li a {
	display:flex;
	justify-content:flex-start; align-items:center;
	background-color:transparent;
	padding:0.6em 1em; white-space:nowrap;
	transition:var(--transition);
}
.page-selector ul li a::before {
	content:""; display:block; width:4px; height:4px; background:var(--color-gray);
	border-radius:10px;
	margin:0 0.6em 0 0;
}
.page-selector ul li a:hover {
	background:var(--color-gradient);
	color:var(--color-white);
}
.page-selector ul li.is-current a {
	pointer-events:none;
	background:var(--color-gradient); color:var(--color-white);
}
.page-selector ul li.is-current a::before {
	background:#fff;
}

@media (max-width:800px) {
	.page-selector ul {border:0;}
	.page-selector ul li {display:inline-block; border:0; margin:0 2px 4px 0;}
	.page-selector ul li a {background:var(--color-background);}
}


.page-content {margin:0 0 5vw 0;}

.page-content h2 {position:relative; display:flex; align-items:center;}
.page-content h2::before {
	content:"";
	width:6px; height:6px; margin:-0 0.4em 0 0;
	background:var(--color-gradient);
	border-radius:5px;
}

.page-content h3 {
	border-bottom:1px solid var(--color-blue); width:fit-content;
	padding:0 0.5em 0.2em;
	margin:0 auto 1em 0;
}

.page-content ol {
	list-style:none; padding:0 0 0 1.5em; text-align:left;
	list-style:outside;
	list-style-type:decimal;
	margin:1em auto 2em 0;
}
.page-content ol li {display:list-item;}



.single-window {
	padding:7em 7em;
	background:#fff;
	border:1px solid var(--color-border);
	border-radius:var(--border-radius);
}


@media (max-width:900px) {
	.single-window {padding:5vw 7vw;}
}
@media (max-width:600px) {
	.single-window {padding:5vw 5vw;}
}
@media (max-width:460px) {
	.single-window {padding:5vw 3vw;}
}

.single-meta {margin:0 0 1em 0;}
.single-meta .date {line-height:1.3;}


.single-title {
	padding:0 0 1em 0;
	margin:0 0 2em 0; border-bottom:1px solid var(--color-border);
}
.single-title .title {font-size:31px; font-size:3.1rem;}

.single-links {text-align:center; margin:5em auto 7em;}
.single-links span a {
	display: inline;
	background:linear-gradient(to top, currentColor 1px, transparent 99%) no-repeat;
	background:linear-gradient(to top, var(--color-black), var(--color-black)) no-repeat left bottom 1px;
	transition: var(--transition);
	background-position: 0% 100%;
	background-size: 0% 1px;
}
.single-links .navi-prev,
.single-links .navi-next {margin:0 1em;}

.single-links a:hover {
	color:var(--color-black);
	background-size: 200% 1px;
}



/* #post-ID {} */

/******************/
/* single-custom-post.php */


/******************/
/* 404.php */

body.error404 {overflow:hidden;}
body.error404 #swup {display: contents;}
body.error404 .site-header,
body.error404 .site-footer {display:none;}
.main-404 {
	display: flex;
	justify-content:center;
	align-items:center;
	text-align:center;
	position:fixed;
	top:0; left:0; right:0; bottom:0; padding:5em 3em;
	background-color:var(--color-background);
	color:var(--color-black);
	overflow:auto;
	z-index:99999;
}
.article-404 {
	margin: auto;
	padding:3em 0;
	line-height:var(--line-height-big);
}
.article-404 .logo {text-align:center; margin:0 auto 2em; font-size:20x; font-size:2.0rem;}
.article-404 .logo img {margin:0 auto 12px; width:100%; max-width:310px;}
.article-404 .logo {}
.article-404 .title {margin:0 auto; font-size:32x; font-size:3.2rem;}
.article-404 .subtitle {margin:0 auto 1.5em; font-size:20px; font-size:2.0rem;}
.article-404 .subtitle::before,
.article-404 .subtitle::after {display:none;}

/******************/
/******************/
/* breadcrumbs ****/

.breadcrumbs {clear:both; display:block;
	margin:0 0 1em 0; padding:0; text-align:left; font-size:13px; font-size:1.3rem;
}
.breadcrumbs ul {
	padding:0; margin:0 auto 0 0; list-style:none; white-space:nowrap;
	overflow-x:auto;
	-webkit-overflow-scrolling:touch;
}
.breadcrumbs ul li {display:inline-block;}
.breadcrumbs ul li:after {content:"\25B8"; margin:0 0.5em 0 1em;}
.breadcrumbs ul li:first-child:before {}
.breadcrumbs ul li:last-child:after {content:"";}
.breadcrumbs ul li a {
	display: inline-block;
	color: var(--color-black);
	padding:0 0 0;
	background: linear-gradient(0deg,var(--color-black),var(--color-black)) no-repeat left bottom;
	background-size: 0 1px;
	transition: var(--transition)
}
.breadcrumbs ul li a:hover {
	background-size: 100% 1px;
}


/******************/
/* pagination *****/

.pagination {margin:0 auto 5em; clear:both;}
.pagination ul {
	text-align:center; font-size:19px; font-size:1.9rem;
	display:flex; justify-content:center; align-items:center;
	flex-wrap:wrap;
}
.pagination ul li {display:inline-block; margin:0 0.7em; white-space:nowrap;}
.pagination ul li .current {text-decoration:underline;}
.pagination span,
.pagination ul li a {
	padding:0;
	color:var(--color-black);
	transition:background-color var(--transition) , color var(--transition);
}
.pagination ul li a.prev,
.pagination ul li a.next {
	display: block;
	width:2.5em; height:2.5em; border-radius:50%;
	background:transparent center center no-repeat;
	border:1px solid var(--color-blue);
	color:transparent;
	position:relative;
	overflow:hidden;
}
.pagination ul li a.prev::before,
.pagination ul li a.next::before {
	content:""; display:block; position:absolute;
	width:0.7em; height:0.7em;
	top:calc(50% - 0.35em);
	left:calc(50% - 0.35em);
	background:center center no-repeat;
	background-size:100% auto;
}
.pagination ul li a.prev::before {background-image:url("images/arrow-left-blue.svg");}
.pagination ul li a.next::before {background-image:url("images/arrow-right-blue.svg");}

.pagination ul li a.prev:hover,
.pagination ul li a.next:hover {
	background-color:var(--color-blue);
	color:transparent;
}
.pagination ul li a.prev:hover::before {
	background-image:url("images/arrow-left-white.svg");
}
.pagination ul li a.next:hover::before {
	background-image:url("images/arrow-right-white.svg");
}

.pagination ul li a.prev:hover::before {
	background-image:url("images/arrow-left-white.svg");
	animation:
		arrow-out-reverse 0.4s ease-out 0.1s forwards,
		arrow-in-reverse 0.4s ease-out 0.4s forwards;
}
.pagination ul li a.next:hover::before {
	background-image:url("images/arrow-right-white.svg");
	animation:
		arrow-out 0.4s ease-out 0.1s forwards,
		arrow-in 0.4s ease-out 0.4s forwards;
}

.pagination ul li a:hover {
	color:var(--color-blue);
	text-decoration:underline;
}
.pagination span.dots {border:0; background:transparent;}

.pagination ul li a:not(:hover)::before {
	animation:
		arrow-out-reset 0.4s ease-in forwards,
		arrow-in-reset 0.4s ease-out 0.4s forwards;
}
.pagination ul li a.prev:not(:hover)::before {
	animation:
		arrow-out-reverse-reset 0.4s ease-in forwards,
		arrow-in-reverse-reset 0.4s ease-out 0.4s forwards;
}

/******************/
/******************/
/* comments.php ***/


/******************/
/* button *********/
/* .article button */

.button {margin:2em 0; font-size:16px; font-size:1.6rem; width:fit-content;}

.buttons {display:flex; justify-content:flex-start;}
.buttons .button {margin:2em 1em 2em 0;}

.button a {
	display:flex; justify-content:space-between; align-items:center;
	min-width:190px; padding:0.12em 0.8em 0.12em 1.8em;
	border-radius:50px;
	text-align:left;
	background:transparent;
	border:1px solid; border-color:var(--color-blue);
	color:var(--color-blue); position:relative;
	overflow:hidden;
	transition:var(--transition);
}
.button i {
	position:relative; z-index:2;
}
.button .icon {
	position:relative;
	border-radius:50%;
	width:1.5em; height:1.5em;
	background:var(--color-gradient);
	margin:0 0 0 3em;
	overflow:hidden;
	transition:var(--transition);
	z-index:3;
}
.button .icon::after {
	content:"";
	position: absolute;
	top:calc(50% - 0.35em); left:50%;
	transform: translateX(-50%);
	width:0.7em; height:0.7em;
	background:url("images/arrow-right-white.svg") center center no-repeat;
	background-size:100% auto;
	margin:0;
}

.button a:after {
	content:""; display:block;
	position:absolute; width:100%; height:100%;
	top:0; bottom:0; left:0;
	background:var(--color-gradient);
	border-radius:50px;
	transform:translateX(-100%);
	transition:var(--transition);
	z-index:1;
}

.button a:hover {
	background-color:transparent; color:var(--color-white); cursor:pointer;
}
.button a:hover .icon {
	background:#fff;
}

.button a:hover::after {
	animation: slide-in var(--transition) ease-out forwards;
}
.button a:not(:hover)::after {
	animation: slide-out var(--transition) ease-in forwards;
}

.button a:hover .icon::after {
	background-image:url("images/arrow-right-blue.svg");
	animation:
		slide-out-arrow 0.2s ease-in forwards,
		slide-in-arrow 0.2s ease-out 0.2s forwards;
}

.button a:not(:hover) .icon::after {
	animation:
		slide-out-reset 0.2s ease-in forwards,
		slide-in-reset 0.2s ease-out 0.2s forwards;
}

@keyframes slide-in {
	from {transform: translateX(-120%);}
	to {transform: translateX(0);}
}

@keyframes slide-out {
	from {transform: translateX(0);}
	to {transform: translateX(120%);}
}
@keyframes slide-in-arrow {
	from {transform: translateX(-200%);}
	to {transform: translateX(-50%);}
}
@keyframes slide-out-arrow {
	from {transform: translateX(-50%);}
	to {transform: translateX(150%);}
}
@keyframes slide-in-reset {
	from {transform: translateX(-200%);}
	to {transform: translateX(-50%);}
}
@keyframes slide-out-reset {
	from {transform: translateX(-50%);}
	to {transform: translateX(150%);}
}

.button.-white a {
	border-color:var(--color-white);
	color:var(--color-white);
}
.button.-white a .icon {
	background:transparent;
	border:1px solid var(--color-white);
}
.button.-white .icon::after {background-image:url("images/arrow-right-white.svg");}
.button.-white a:after {background:var(--color-white);}
.button.-white a:hover {
	background-color:transparent;
	color:var(--color-blue);
}
.button.-white a:hover .icon {background-color:var(--color-blue);}
.button.-white a:hover .icon::after {background-image:url("images/arrow-right-white.svg");}




@media (max-width:600px) {
	.button a {min-width:150px;}
}

.button.-center {margin:0 auto;}
.button.-right {margin:1em 0 1em auto; text-align:right;}

.button.button-small a {padding:4px 12px; min-width:30px; font-size:0.8em;}
.button.button-large a {padding:8px 36px; min-width:180px; font-size:1.2em;}

.button.button-success a {border-color:#cbcacb; border-color:var(--color-gray); color:blue;}
.button.button-success a:hover {background-color:#cbcacb; background-color:var(--color-gray); color:#ffffff;}

.button.button-error a {border-color:red; color:red;}
.button.button-error a:hover {background-color:red; color:#ffffff;}

.button.button-warning a {border-color:yellow; color:yellow;}
.button.button-warning a:hover {background-color:yellow; color:#ffffff;}

.more {line-height:var(--line-height);}
.more a {
	font-size:14px; font-size:1.4rem;
	padding:0 2em 0 1em;
	border-bottom:1px solid var(--color-border);
	display:block;
	width:fit-content;
	background:url("images/arrow-right-black.svg") right 0.5em center no-repeat;
	background-size:0.8em auto;
}
.more a:hover {
	border-color:var(--color-blue);
	color:var(--color-blue);
}



/******************/
/******************/
/* Flexbox System & Table System */


.table-container {
	display:table; table-layout:fixed; border-collapse:collapse; width:100%; position:relative; margin:0; padding:0;
}
.table-cell {
	display:table-cell; vertical-align:top; position:relative; margin:0; padding:0; empty-cells:show;
}

.flex-container {
	margin:0; padding:0; list-style:none;
	display:flex;
	flex-wrap:wrap;
	flex-direction:row;
	align-items:stretch;
	align-content:stretch;
	justify-content:space-between;
}

.flex-item {
margin:0; padding:0;
flex:0 1 auto;
flex-grow:0;
flex-shrink:1;
}

.flex-container-2 .flex-item {
	flex-basis:50%;
}
.flex-container-3 .flex-item {
	flex-basis:33.3333%;
}
.flex-container-4 .flex-item {
	flex-basis:25%;
}

.columns {
	column-gap:4em;
	column-rule:1px dotted;
	margin:0 auto 4em;
}
.columns-2 {columns:2;}


/******************/
/* responsive-table */


.responsive-table {
	width:100%;
	position: relative;
	overflow-y: hidden;
	overflow:scroll;
	-ms-overflow-style:-ms-autohiding-scrollbar;
	width: 100%;
	cursor: grab;
}

.responsive-table:not(.is-overflow)::-webkit-scrollbar {display:none;}
.responsive-table .icon {
	content:""; position:absolute; top:min(30vh,50%); left:50%; width:112px; height:112px; background:url("images/icon-scrollable-jp.svg") center/contain no-repeat; transform:translate(-50%,-50%); z-index:2; backdrop-filter:blur(2px);}
.responsive-table .icon {
	opacity:0; transition:.2s; pointer-events:none; transition-delay:.4s;
}
.responsive-table.is-overflow>.icon {opacity:1;}
.responsive-table.is-overflow>.icon.is-hide {opacity:0;}
[data-current-lang="en"] .responsive-table .icon {background-image:url("images/icon-scrollable-en.svg");}
.responsive-table.is-overflow>.scrollable-icon.is-hide {
	opacity: 0;
}
.responsive-table.is-overflow>.scrollable-icon {
	opacity: 1;
}

/******************/
/* jquery-tabs ****/


.tab-selector ol {
	display:table; table-layout:fixed; text-align:center;
	padding:0 20px; margin:0 auto; width:100%;
	position:relative; bottom:-1px;
	z-index:3;
}
.tab-selector ol li {
	display:table-cell;
	padding:12px 0; cursor:pointer; background-color:#cbcacb; background-color:var(--color-border);
	border:1px solid #999999; border-color:var(--color-gray);
	white-space:nowrap;
	overflow:hidden;
}

.tab-selector ol li:not(:last-child) {border-right:0;}
.tab-selector ol li:hover {background-color:#cbcacb; background-color:var(--color-gray); color:#ffffff;}
.tab-selector ol li:first-child {border-top-left-radius:4px;}
.tab-selector ol li:last-child {border-top-right-radius:4px;}
.tab-selector ol li.is-current {background-color:#ffffff; background-color:var(--color-background); color:#cbcacb; color:var(--color-gray); border-bottom:1px solid #ffffff;}
.tab-selector ol li.is-current:hover {background-color:#ffffff; background-color:var(--color-background); color:#cbcacb; color:var(--color-gray);}

.tab-content {position:relative; z-index:2;}
.tab-content > div {display:none;}
.tab-content > div:first-child {display:block;}



/******************/
/******************/
/* materials ******/

.adr span {margin:0; display:inline-block;}




/******************/
/******************/
/* plugins ********/

/*
[data-sr] {
	opacity:0; filter:blur(15px);
	transition:var(--transition-late);
}
*/
[data-sr].is-visible {
	opacity:1; filter:blur(0);
}







/******************/
/* ContactForm7 ***/



.form {clear:both; display:block; margin:0;}
.form table {
	line-height:var(--line-height-mini);
	border-top:1px solid; border-color:var(--color-border);}
.form table th,
.form table td {
	border-bottom:1px solid; border-color:var(--color-border); padding:1em 1em; vertical-align:middle;
}
.form table th {
	text-align:center;
	position:relative;
	padding: 1em 2em 1em 0;
}
.form table td {}
.form table th i {
	display:block; font-size:21px; font-size:2.1rem;
	color:#cbcacb; color:var(--color-blue);
}
.form table th b {
	position:absolute; right:0; top:50%; background-color:#ff4e38; color:#fff; font-size:12px; font-size:1.2rem;
	border-radius:4px;
	padding:0.5em;
	display:inline-block;
	transform: translateY(-50%);
}


@media (max-width:700px) {
	.form table,
	.form table tbody,
	.form table tr,
	.form table th,
	.form table td {display:block;}
	.form table th,
	.form table td {display:block; text-align:left; padding:0;}
	.form table th {border:0; padding:20px 0 0 0; margin:0 0 12px 0; display:flex; align-items:center;}
	.form table th i {display:inline-block; margin:0 1em 0 0;}
	.form table td {padding:0 0 16px 0;}
	.form table th b {position:relative; margin:0 0 0 auto; transform:none;}
}


form {}
fieldset {}
label {}

::-webkit-input-placeholder,
::-moz-placeholder,
:-moz-placeholder,
:-ms-input-placeholder {color:#999999; color:var(--color-gray);}

[type="search"] {
/*-webkit-appearance:textfield;
-moz-appearance:textfield;
-ms-appearance:textfield;
-o-appearance:textfield;
appearance:textfield;*/
}

input[type="text"],
input[type="password"],
input[type="date"],
input[type="datetime"],
input[type="email"],
input[type="number"],
input[type="search"],
input[type="tel"],
input[type="time"],
input[type="url"],
input[type="file"],
select,
textarea {
	width:auto;
	max-width:100%;
	border-radius:4px;
	display:block;
	position:relative;
/*-webkit-appearance:none;
appearance:none;*/
padding:1.5em 1em; margin:0; line-height:var(--line-height);
border:1px solid #f5f5f5;
border-radius:var(--border-radius-mini);
background-color:var(--color-white);
}


input[type="checkbox"],
input[type="radio"] {}
input[type="file"] {cursor:pointer; width:auto;}
input[name="your-address"] {width:100%;}
select {width:auto; padding:12px; border:1px solid #cbcacb;}
textarea {width:100%;}

input[type="submit"] {
	margin:0 auto 5em;
	text-align:center;
	appearance:none;
	display:block;
	text-align:center;
	background-size:1.5em auto;
	background-color:var(--color-blue);
	background: url("images/icon-mail.svg") right 1.6em center no-repeat;
	background-size: 1.5em auto;
	border:2px solid var(--color-blue); border-radius:100px;
	color:var(--color-blue);
	padding:1em 5em 1em 3em;
	appearance:none;
	display:block;
}
input[type="submit"]:hover {
	background-color:var(--color-blue); border-color:var(--color-blue);
	background-image:url("images/icon-mail-white.svg");
	color:#fff;
	cursor:pointer;
}

input[type="submit"][disabled],
input[type="submit"][disabled]:hover {
	color:var(--color-gray); background-color:transparent;
	background-image: url("images/icon-mail-gray.svg");
	border-color:var(--color-gray); cursor:not-allowed;
}

input[type="text"]:focus,
input[type="password"]:focus,
input[type="date"]:focus,
input[type="datetime"]:focus,
input[type="email"]:focus,
input[type="number"]:focus,
input[type="search"]:focus,
input[type="tel"]:focus,
input[type="time"]:focus,
input[type="url"]:focus,
select:focus,
textarea:focus {
border:1px solid #cbcacb; border-color:var(--color-gray);
}

textarea {height:auto; min-height:100px;}
select {}


@media (max-width:960px) {
	input[type="text"],
	input[type="password"],
	input[type="date"],
	input[type="datetime"],
	input[type="email"],
	input[type="number"],
	input[type="search"],
	input[type="tel"],
	input[type="time"],
	input[type="url"] {width:100%;}
	select {width:auto;}
	textarea {width:100%;}
}
	

.wpcf7{}

.screen-reader-response {display:none;}

.wpcf7-response-output:empty {display:none;}
.wpcf7-response-output {
margin:0 auto 3em; padding:1.5em; line-height:var(--line-height-mini);
border:0;
	border-radius:var(--border-radius);
	text-align:center; display:block;
	clear:both;
	background:var(--color-red);
	color:var(--color-white);
	width:fit-content;
}

[data-status="sent"] .wpcf7-response-output {background:var(--color-gradient);}

.wpcf7-mail-sent-ok {
border:1px solid #cbcacb; border-color:var(--color-gray);
color:var(--color-white);
padding:12px;
margin:0 0 20px 0;
}

.wpcf7-validation-errors {
border:1px solid var(--color-dark);
color:var(--color-dark);
padding:12px;
margin:0 0 20px 0;
}

.wpcf7 span {}
.wpcf7-form-control-wrap {display:block; position:relative;}
.wpcf7 span.wpcf7-list-item-label {margin:0 1em 0 0; display:inline-block;}
.wpcf7 span.use_label_element {margin-bottom:20px; display:block;}
.wpcf7 span.wpcf7-not-valid-tip {
	color:var(--color-white); background-color:var(--color-red);
	font-size:15px; font-size:1.5rem; display:block;
	position:absolute;
	left:1em; bottom:-1em; padding:0.3em 3em;
	border-radius:var(--border-radius);
}
.wpcf7 span.wpcf7-not-valid-tip-no-ajax {display:none;}

.wpcf7 .wpcf7-form-control {}
.wpcf7 .wpcf7-list-item {margin:0 0 16px 0;}

.wpcf7 input[type="radio"],
.wpcf7 input[type="checkbox"] {display:none;}
.wpcf7 label {cursor:pointer;}
.wpcf7-list-item {position:relative; display:inline-block;}
.wpcf7-list-item-label {min-height:20px; line-height:24px; vertical-align:middle; padding:0 0 0 32px; display:inline-block; position:relative;}
.wpcf7-list-item-label:before {width:20px; height:20px; content: ''; position: absolute; left:0; top:0; background-color:#ffffff; background-color:var(--color-background); border:2px solid #cbcacb; display:inline-block;}
.wpcf7-list-item-label:after{
width:10px; height:6px; left:6px; top:6px;
border:2px solid #cbcacb; border-color:var(--color-gray);
content:''; position:absolute; transform:rotate(-45deg);
border-top:none; border-right:none; transition:all 0.3s; opacity:0;
}
input[type="radio"]:checked + .wpcf7-list-item-label:after,
input[type="checkbox"]:checked + .wpcf7-list-item-label:after {opacity:1;}


img.ajax-loader {display:block; margin:12px auto 0;}

.wpcf7 .sent .form {display:none;}



/******************/
/* facebook *******/

/******************/
/* twitter ********/


/******************/
/******************/
/* Media Query ****/

/* ▲ iPad Air4 横（820px） ▼ */

/* ▲ iPhone 6+ 横（736px） ▼ */

/* ▲ Mac OS Safari - Minimum(504px) ▼ */

/* ▲ iPhone 6+ - iPhone 6 414px▼ */

/* ▲ iPod touch 320px ▼ */


/******************/
/******************/
/* fonts **********/


.font-gothic {font-family:'YuGothic', 'Yu Gothic', '游ゴシック', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', 'Meiryo', 'メイリオ', 'Helvetica', sans-serif;}
.font-mincho {font-family:'YuMincho', 'Yu Mincho', '游明朝', 'Hiragino Mincho ProN', 'ヒラギノ明朝 ProN W3', 'Meiryo', 'メイリオ', 'Times New Roman', serif;}
.font-mono {font-family:"Osaka-mono", "MS Gothic", monospace;}
.bold {font-weight:bold;}

i {font-family:"Bellefair", serif;}




/******************/

.noscript {
	display:flex; justify-content:center; align-items:center;
	position:fixed;
	top:0; left:0; right:0; bottom:0;
	background-color:var(--color-green);
	color:#fff;
	line-height:var(--line-height);
	z-index:99999;
}


/******************/
/******************/
/* Keyframes ******/


@keyframes arrow-out {
	from {opacity:1; transform: translateX(0);}
	to {opacity:0; transform: translateX(200%);}
}
@keyframes arrow-in {
	from {opacity:0; transform: translateX(-200%);}
	to {opacity:1; transform: translateX(0);}
}
@keyframes arrow-out-reverse {
	from {opacity:1; transform: translateX(0);}
	to {opacity:0; transform: translateX(-200%);}
}
@keyframes arrow-in-reverse {
	from {opacity:0; transform: translateX(200%);}
	to {opacity:1; transform: translateX(0);}
}
@keyframes arrow-out-reset {
	from {opacity:1; transform: translateX(0);}
	to {opacity:0; transform: translateX(200%);}
}
@keyframes arrow-in-reset {
	from {opacity:0; transform: translateX(-200%);}
	to {opacity:1; transform: translateX(0);}
}
@keyframes arrow-out-reverse-reset {
	from {opacity:1; transform: translateX(0);}
	to {opacity:0; transform: translateX(-200%);}
}
@keyframes arrow-in-reverse-reset {
	from {opacity:0; transform: translateX(200%);}
	to {opacity:1; transform: translateX(0);}
}
@keyframes arrow-up-out {
	from {transform:translateY(-50%)}
	to {transform: translateY(-250%);}
}
@keyframes arrow-up-in {
	from {transform:translateY(250%);}
	to {transform: translateY(-50%);}
}
@keyframes arrow-up-out-reset {
	from {transform:translateY(-50%)}
	to {transform: translateY(-250%);}
}
@keyframes arrow-up-in-reset {
	from {transform:translateY(250%);}
	to {transform: translateY(-50%);}
}
/* end ************/
/******************/
/******************/

