@charset "UTF-8";

/*
Theme Name: First Steps 2025
Text Domain: firststeps-2025
Description: ファーストステップスつくば専用ワードプレステーマ
Author: ONZE
Author URI: https://on-ze.com
Theme URI: https://firststeps-montessori.com
Version: 0.9
*/

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

:root {
--color-background:#f4f0eb;
--color-white:#ffffff;
--color-black:#222222;
--color-gray:#808080;
--color-red:#91244c;
--color-gold:#987241;
--color-beige:#e6ddd2;
--color-border:rgba(152,114,65,0.2);
/*--color-border:#cbb8a0;*/
--font-light:200;
--font-regular:400;
--font-bold:600;
--border-radius:1vw;
--border-radius-large:11vw;
--letter-spacing:0.15em;
--line-height-large:2.1;
--line-height:1.5;
--line-height-mini:1.3;
--transition:0.7s;
--transition-fast:0.35s;
}


/******************/
/******************/
/* 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:break-word;
	overflow-wrap:anywhere;
	word-break:normal;
	font-feature-settings:"palt";
	-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-background);
	color:var(--color-black);
	font-family:'Shippori Mincho', 'Poppins' ,'Cormorant', 'YuMincho', 'Yu Mincho', '游明朝', 'Hiragino Mincho ProN', 'ヒラギノ明朝 ProN W3', serif;
	font-size:19px;
	font-size:1.9rem;
	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:#987241; color:var(--color-gold);}
i {font-style:normal;}
u {text-decoration:underline;}
em {font-weight:bold;}
strong {font-weight:bold; 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:2em 0; border:0; border-top:1px solid #cccccc; 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 #cccccc; border-color:var(--color-beige);
}
table th,
table td {
	padding:1.5em 1em; vertical-align:top; border-bottom:1px solid #cccccc; border-color:var(--color-beige);
}
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:#987241; background-color:var(--color-gold); color:#ffffff;}
::selection {background-color:#987241; background-color:var(--color-gold); 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 #cccccc; 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:#987241; background-color:var(--color-gold); color:#ffffff; cursor:text;
}

table.table-stripe tbody tr:nth-child(odd) {background-color:#cccccc; 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 5vw;
}
.inner[data-width="max"] {max-width:1900px;}
.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-header {
	width:100%; padding:20px 0; display:block; position:absolute;
	top:0;
	background: linear-gradient(to bottom, #f4f0eb 0%, #f4f0eb 50%, rgba(244, 240, 235, 0) 100%);
	z-index:9999;
}

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

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

.header-logo {
	margin:0 1vw 0 0;
}
.header-logo .site-title {
	display:block; margin:0; white-space:nowrap; overflow:hidden; position:relative;
	width:20vw; max-width:300px; min-width:180px; height:auto;
	aspect-ratio:100 / 24;
}
.header-logo .site-title a {
	display:block; background:url("images/logo-color.webp") 0 0 no-repeat;
	background-size:100% auto;
	padding:80px 0 0 0;
}
.header-logo .site-title a:hover {color:#987241; color:var(--color-gold);}
.header-logo .site-description {display:none;}

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

.site-header .contents {margin:0 ; position:relative;}

.header-navi {
	padding:1em 0 2.5em 0; display:block; line-height:1;
	background: linear-gradient(to bottom, #f4f0eb 0%, rgba(244, 240, 235, 0.5) 70%, rgba(244, 240, 235, 0) 100%);
	position:relative;
	bottom:0;
}
.header-navi.is-fixed {position:fixed; top:0; bottom:auto;}

.header-navi ul {display:table; table-layout:fixed; width:100%; list-style:none; margin:0; padding:0;
	font-size:21px; font-size:2.1rem;
}
.header-navi ul li {margin:0 0.5em; display:table-cell; position:relative;}
.header-navi ul li i {display:block;}
.header-navi ul li a {
	display:flex;
	align-items:center; justify-content:center;
	padding:0.7em 0.5em; position:relative;
	transition:var(--transition);
}
/*
.header-navi ul li a::before,
.header-navi ul li a::after {
	position:absolute; content:""; display:block;
	width:70%; height:1px;
	background: linear-gradient(to right, transparent, var(--color-beige) 30%, var(--color-beige) 70%, transparent);
	left:50%;
	transform:translateX(-50%);
	transition: width 0.4s ease, background 0.3s ease;
}*/
.header-navi ul li a::before,
.header-navi ul li a::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	pointer-events: none;
	background-repeat: no-repeat;
	background-position: top, bottom;
	background-size: 100% 1px;
}

.header-navi ul li a::before {
	background-image:
		linear-gradient(to right, transparent, var(--color-beige) 30%, var(--color-beige) 70%, transparent),
		linear-gradient(to right, transparent, var(--color-beige) 30%, var(--color-beige) 70%, transparent);
	z-index:1;
}
.header-navi ul li a::after {
	background-image:
		linear-gradient(to right, transparent, var(--color-red) 30%, var(--color-red) 70%, transparent),
		linear-gradient(to right, transparent, var(--color-red) 30%, var(--color-red) 70%, transparent);
	transform: scaleX(0);
	transform-origin: center;
	transition: var(--transition-fast) ease;
	z-index:2;
}

.header-navi ul li a:hover {color:var(--color-red);}
.header-navi ul li a:hover::after {
	transform: scaleX(1);
	
}
/*
.header-navi ul li a:hover::before,
.header-navi ul li a:hover::after {
	width:100%;
	background: linear-gradient(to right, transparent, var(--color-red) 30%, var(--color-red) 70%, transparent);
	transition: width 0.4s ease, background 0.3s ease;
}
*/

.header-navi ul li[class*="has"] a span::after {
	content:"";
	width:0.7em; height:0.7em; display:inline-block;
	background:url("images/arrow-bottom-black.svg") center center no-repeat;
	background-size:cover;
	margin:0 0 0 0.5em;
}
.header-navi ul li[class*="has"] a:hover span::after {
	background-image:url("images/arrow-bottom-red.svg");
}
.header-navi ul li .sub-menu {
	display:none; position:absolute; text-align:left;
	padding:1em 0 0 1em;
	font-size:19px; font-size:1.9rem;
}
.header-navi ul li .sub-menu li {
	display:block; margin:0 0 1em 0; white-space:nowrap;
}
.header-navi ul li .sub-menu li a {padding:0; display:block;}
.header-navi ul li .sub-menu li a::before,
.header-navi ul li .sub-menu li a::after {display:none;}

.header-navi ul li[class*="has"]:hover .sub-menu {display:block;}





.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:#222222; background-color:var(--color-black); 
	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 {display:flex; align-items:center;}
.header-utility dl {display:flex; align-items:center; margin:0 1em 0 0;}
.header-utility dl dt,
.header-utility dl dd {margin:0 1em 0 0;}

.header-utility ul {
	display: flex;
	align-items: center;
	justify-content: center;
	cursor:pointer;
	width: fit-content;
	margin: 0 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 li .button {
	display: block;
	padding: 0.5em 1em; margin:0; background:none;
	border-radius: 999px;
	font-size:;
	cursor:pointer;
}
.header-utility .is-current .button {
	background-color: var(--color-white);
	color: var(--color-black);
}

@media (max-width:800px) {
	.site-header .contents {display:flex; justify-content:space-between; align-items:center;}
	.header-navi ul {display:none;}
	.header-utility {margin:0 1em 0 0;}
	.header-toggle {display:block;}
}

@media (max-width:660px) {
	.header-utility {display:none;}
}

/******************/
/******************/
/* widget *********/

.site-links {
	position:fixed; right:0; top:50%; transform:translateY(-50%);
	z-index:998;
}
/*
.site-links dl {margin:0 auto 1em;}
.site-links dl dt {margin:0 auto 1em;}
.site-links dl dt img {max-width:24px; width:100%; margin:0 auto;}
.site-links dl dd {margin:0 auto 1em;}
.site-links dl dd img {max-width:24px; width:100%; margin:0 auto;}
*/
.site-links .calendar {}
.site-links .calendar a {
	display:block; padding:3em 0.5em 3em;
	background:var(--color-black); color:#fff;
	border-top-left-radius:26px;
	border-bottom-left-radius:26px;
	position:relative;
	cursor:pointer;
}
.site-links .calendar a::before,
.site-links .calendar a::after {
	content:""; display:block; right:0; position:absolute;
	width:26px; height:26px;
	background:url("images/site-links-calendar-top.svg") 0 0 no-repeat;
}
.site-links .calendar a::before {top:-25px;}
.site-links .calendar a::after {bottom:-25px; background-image:url("images/site-links-calendar-bottom.svg");}

.site-links .calendar a:hover {background-color:var(--color-red);}
.site-links .calendar a:hover::before {background-image:url("images/site-links-calendar-top-red.svg");}
.site-links .calendar a:hover::after {background-image:url("images/site-links-calendar-bottom-red.svg");}

@media (max-width:700px) {
	.site-links {display:none;}
}



/******************/
/******************/
/* footer *********/

.footer-widget {
	position:relative; width:100%;
	margin:0 0 5vw 0; overflow:hidden;
	padding:0 0 5vw 0;
	pointer-events:none;
}

.footer-swiper {
	pointer-events:none;
}
.footer-swiper .swiper-wrapper {
	display:flex;
}

.footer-swiper .swiper-slide {
	width:240px; position:relative;
}

.swiper-free-mode>.swiper-wrapper {
-webkit-transition-timing-function:linear !important;
-o-transition-timing-function:linear !important;
transition-timing-function:linear !important;
}



.footer-swiper .swiper-slide img {transform:scale(1.1);}
.footer-swiper .swiper-slide.slide-odd {margin-top:100px;}


.site-footer {text-align:center; padding:0 0 7vw 0; line-height:1.5;}

.footer-navi {position:relative; padding:40px 0 60px 0;}
.footer-navi ul {clear:both; display:table; table-layout:fixed; width:auto; text-align:center; margin:0 auto; font-size:12px; font-size:1.2rem; border-collapse:collapse;}
.footer-navi ul li {display:table-cell; padding:0 12px; border-left:1px solid #cccccc; border-right:1px solid #cccccc; border-color:var(--color-border); white-space:nowrap;}
.footer-navi ul li a {display:block; padding:2px 6px;}
.footer-navi ul li a:hover {}
.footer-navi ul li i {display:block; font-size:14px; font-size:1.4rem;}


.footer-logo dl {margin:0 auto 5vw; line-height:var(--line-height-large);}
.footer-logo dl dt {margin:0 auto 1em; width:21vw; max-width:280px;}
.footer-logo dl dt img {width:100%; height:auto;}
.footer-logo dl dt a {}
.footer-logo dl dt a:hover {}
.footer-logo dl dd {font-size:17px; font-size:1.7rem; margin:0 auto 1em;}

small.site-info {clear:both; font-size:15px; font-size:1.5rem;}
small.site-info a {color:#987241; color:var(--color-gold);}
small.site-info a:hover {color:#987241; color:var(--color-gold);}

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

.site-main {
	padding: clamp(160px, 9vw, 9vw) 0 0 0;
	line-height:2.1; text-align:left;
	hyphens:auto;
}

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


.main-content {text-align:left;}



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

.main-content.has-sidebar {
float:left;
width:100%;
	width:calc(100% - 320px);
}

.main-sidebar {width:280px; float:right; padding:0; text-align:left;}
.main-sidebar .module {margin-bottom:20px; display:block; clear:both;}
.main-sidebar a {}
.main-sidebar a:hover {}
.main-sidebar h4 {font-size:18px; font-size:1.8rem; margin:0 0 4px 0; display:block;}

.main-sidebar p {margin:0 0 12px 0; clear:both;}
.main-sidebar ul {padding:0; margin:0; clear:both;}
.main-sidebar ul li {padding:0; margin:0;}

.main-sidebar label {display:block;}
.main-sidebar select {margin:0 0 1em 0; width:99%; border:1px solid #999999; border-color:var(--color-gray);}

.main-sidebar label.screen-reader-text {display:none;}
.main-sidebar .search-submit {display:none;}

.main-footer {}

/******************/
/******************/
/* post-type ******/


.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:35px; font-size:3.5rem;}
.article h3 {font-size:35px; font-size:3.5rem;}
.article h4 {font-size:29px; font-size:2.9rem;}
.article h5 {font-size:25px; font-size:2.5rem;}
.article h6 {font-size:21px; font-size:2.1rem;}

.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-red);}
.single-content ul li a:hover {color:var(--color-red); text-decoration:underline;}

.article ol li {padding:0 0 0 1.6em; text-indent:-1.4em; text-indent:calc(-12px - 0.4em);
	list-style:none;
	counter-increment:number;
}
.article 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;}
.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 #222222;
}

.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;}


/******************/
/* 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-title {padding:9vw 0;}
.page-title .title {
	line-height:var(--line-height-mini); text-align:left; margin:0 0 40px 0;
	
}
.page-title .title {font-size:25px; font-size:2.5rem;}
.page-title .title i {display:block; font-size:125px; font-size:12.5rem; display:block;
	line-height:1;
}
.page-title .title span {
	display:flex; align-items:center; margin:1em 0 0 0;
}
.page-title .title span::before {
	content:""; width:3em; height:1px; background:var(--color-gold);
	margin:0 0.5em 0 0;
}

.page-selector {margin:0 0 7vw 0;}
.page-selector ul {display:flex; align-items:center; justify-content:flex-start;}
.page-selector ul li {margin:0 1em 0.5em 0;}
.page-selector ul li a {
	background-color:var(--color-beige); color:var(--color-black); border-radius:100px;
	padding:0.5em 3em;
}
.page-selector ul li a:hover {background-color:var(--color-red); color:var(--color-white);}
.page-selector ul li.is-current a {
	pointer-events:none; background-color:var(--color-gold); color:var(--color-white);
}

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


.single-window {
	padding:7em 7em; border:1px solid var(--color-border);
	background:#fff;
	border-radius:var(--border-radius);
	border-top-right-radius:var(--border-radius-large);
	border-bottom-left-radius:var(--border-radius-large);
	box-shadow:var(--box-shadow);
}
@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 {
	color:var(--color-gold); padding:0 1em 0 0; margin:0 1em 0 0;
	border-right:1px solid var(--color-beige);
}



.single-title {
	padding:0 0 3em 0;
	margin:0 0 5em 0; border-bottom:1px solid var(--color-border);
	position:relative;
}
.single-title .title {
	font-size:51px; font-size:5.1rem;
	margin:0;
}

.page-content h2,
.single-content h2 {
	font-size:35px; font-size:3.5rem;
	background-color:var(--color-beige);
	padding:1.3em 1em; margin:3em 0 1em 0;
	border-radius:var(--border-radius); position:relative;
	display:flex; align-items:center;
}
.page-content h2 {background-color:var(--color-beige);}
.page-content h2::before,
.single-content h2::before {
	content:""; width:0.3em; height:0.3em; background-color:var(--color-gold);
	border-radius:50px;
	margin:0 0.5em 0 0;
}

.page-content h3,
.single-content h3 {
	font-size:27px; font-size:2.7rem; margin:2em 0 1em 0;
	border-bottom:1px solid var(--color-border);
	padding:0 0 0.5em 0;
	position:relative;
	display:flex; align-items:center;
}
.page-content h3::before,
.single-content h3::before {
	content:""; width:0.3em; height:0.3em; background-color:var(--color-gold);
	border-radius:50px;
	margin:0 0.5em 0 0.5em;
}

.single-content dl dd {margin:0 0 1em 1em;}

.single-links {text-align:center; margin:5em auto 7em;}
.single-links span a {font-weight:var(--font-bold);
	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 {display:none;}

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

/* #post-ID {} */

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



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

.section {
	position:relative; display:block; padding:7vw 0; margin:0;
}


.section-title .title {
	display:inline-block;
	font-size:65px; font-size:6.5rem; line-height:var(--line-height-mini);
}
.section-title .title span {
	font-size:21px; font-size:2.1rem;
	margin:1em auto 0 0;
	color:var(--color-gold);
}
.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-gold);
	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-gold);
	margin:0 0.5em 0 0;
}


@media (max-width:600px) {
	.section-title .title {font-size:51px; font-size:5.1rem;}
}






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

.section-top-slider {
	position:relative; width:100%; overflow:hidden; margin:0; padding:0;
	
}
.section-top-slider .flex-item:nth-child(1) {
	flex-basis:60%; padding:9vw 0 5vw 3vw; position:relative;
	z-index:1;
}
.section-top-slider .flex-item:nth-child(2) {
	flex-basis:40%; padding:0; position:relative;
}

.section-top-slider .top-slider-title .text {
	margin:0 0 1em 0;
	line-height:var(--line-height);
	font-size:17px; font-size:1.7vw;
}
.section-top-slider .top-slider-title .title {
	line-height:1.1;
	font-size:75px; font-size:5.5vw;
	margin:0 0 0.5em 0;
	display:block;
}
.section-top-slider .top-slider-title .title span {
	color:var(--color-gold);
	display:block;
	height:1em;
	background: linear-gradient(to top, currentColor 2px, transparent 99%) no-repeat;
	transition: background-size 1.0s ease;
	background-position: 0% 100%;
	background-size: 0% 1px;
}

.section-top-slider .copy {display:inline-block; position:relative;}
.section-top-slider .copy .change {
	position:absolute;
	display:inline-block;
	line-height:var(--line-height-mini);
	opacity: 1;
	white-space:nowrap;
	left:0;
	background: linear-gradient(to top, currentColor 1px, transparent 99%) no-repeat;
	background-position: 0% 100%;
	background-size: 0% 1px;
	transition:background-size 1s ease, opacity 0.6s ease;
}
.section-top-slider .copy .change.fade-out {
	opacity:0;
}
.section-top-slider .copy .change.underline {
	animation: underlineGrow 1s ease forwards;
}
@keyframes underlineGrow {
	from {
		background-size: 0% 1px;
	}
	to {
		background-size: 100% 1px;
	}
}


.section-top-slider .swiper-container {
	position:absolute; overflow:hidden;
	top:0; right:0; bottom:0; left:-15vw;
	-webkit-mask-image: -webkit-gradient(linear, left top, right top, from(transparent), color-stop(25%, #000), color-stop(75%, #000), to(transparent));
	-webkit-mask-image: -webkit-linear-gradient(left, transparent 0%, #000 25%, #000 75%, transparent 100%);
	mask-image: -webkit-gradient(linear, left top, right top, from(transparent), color-stop(25%, #000), color-stop(75%, #000), to(transparent));
	mask-image: linear-gradient(to right, transparent 0%, #000 25%, #000 75%, transparent 100%);
	line-height:0;
	z-index:0;
}
.section-top-slider .swiper-slide {
	width:50%;
}
.section-top-slider .swiper-slide .thumbnail {
	aspect-ratio:2 / 3; overflow:hidden;
	border-radius:var(--border-radius);
	border-top-right-radius:var(--border-radius-large);
	border-bottom-left-radius:var(--border-radius-large);
	transition:var(--transition);
	transform:scale(0.9);
	transform-origin:center center;
}
.section-top-slider .swiper-slide img {
	width:100%; height:100%; object-fit:cover;
}

.section-top-slider .swiper-slide-active .thumbnail {
	transform:scale(1);
}
.section-top-slider .swiper-slide-prev .thumbnail,
.section-top-slider .swiper-slide-next .thumbnail {
	transform:scale(0.9);
}
.section-top-slider .button.-black a::after {
	background-image: url("images/icon-calendar-white.svg");
}
.section-top-slider .button.-black a:hover::after {
	background-image: url("images/icon-calendar-black.svg");
}
/*
.section-top-slider .swiper-slide-prev .thumbnail {transform-origin:center right;}
.section-top-slider .swiper-slide-next .thumbnail {transform-origin:center left;}
*/

.top-slider-news {
	position:relative; margin:0 0 3vw
	 auto; padding:0 0 0 4vw;
 }
.top-slider-news dl {
	display:flex; justify-content:flex-start; align-items:center;
	margin:0 0 0 auto; width:fit-content;
	padding:0.7em 3em; background-color:var(--color-beige);
	border-top:1px solid var(--color-border);
	border-bottom:1px solid var(--color-border);
	line-height:var(--line-height-mini);
}
.top-slider-news dl dt {
	color:var(--color-gold); margin:0 3em 0 0; font-size:25px; font-size:2.5rem;
	white-space:nowrap;
}
.top-slider-news dl dd {margin:0;}
.top-slider-news .date {
	color:var(--color-gray); font-size:17px; font-size:1.7rem; letter-spacing:var(--letter-spacing);
	display:block;
	margin:0 0 0.5em 0;
}
.top-slider-news .title {font-size:19px; font-size:1.9rem;
	background: linear-gradient(0deg, #000, #000) no-repeat left bottom 1px;
	background-size: 0 1px;
	transition:var(--transition);
}
.top-slider-news a:hover .title {background-size: 100% 1px;}



@media (max-width:900px) {
	.section-top-slider .flex-item:nth-child(1) {flex-basis:70%;}
	.section-top-slider .flex-item:nth-child(2) {flex-basis:30%;}
	.section-top-slider .top-slider-title .title {font-size:5.5vw;}
}
@media (max-width:700px) {
	.section-top-slider .flex-container {flex-direction: column-reverse;}
	.section-top-slider .flex-item:nth-child(1) {width:100%;}
	.section-top-slider .flex-item:nth-child(2) {width:100%;}
	.section-top-slider .swiper-container {position:relative; left:auto;}
	.section-top-slider .swiper-container .swiper-slide {width:36%;}
	.section-top-slider .top-slider-title .title {font-size:6.5vw;}
}
@media (max-width:600px) {
	.section-top-slider .top-slider-title .title {font-size:7.5vw;}
	.top-slider-news {margin:0 auto 11vw auto;}
	.top-slider-news dl {width:100%;}
}


.section-top-reasons .flex-item {
	flex-basis:25%;
	padding:1em 2em 0; position:relative;
}
.section-top-reasons .flex-item::after {
	content:"";
	position:absolute; top:20%; bottom:20%; right:0;
	width:1px; height:60%;
	background:var(--color-border);
}
.section-top-reasons .flex-item dl {margin:0;}
.section-top-reasons .flex-item dl dd {margin:0;}

.section-top-reasons .flex-item .thumbnail {
	width:35%; min-width:50px; margin:0 auto 3em;
}
.section-top-reasons .flex-item .thumbnail img {width:100%; height:auto;}
.section-top-reasons .flex-item .title {
	text-align:center;
	font-size:25px; font-size:2.5rem;
	margin:0 auto 0.5em;
	line-height:var(--line-height-mini);
}
.section-top-reasons .text {
	font-size:15px; font-size:1.5rem;
}


@media (max-width:640px) {
	.section-top-reasons .flex-container {flex-wrap:wrap;}
	.section-top-reasons .flex-container-4 .flex-item {flex-basis:50%; margin:0 0 5% 0;}
}

.section-top-programs {}
.list-programs.flex-container-3 .item {
	flex-basis:30%;
	background-color:var(--color-white);
	border-radius:1vw;
	border-top-right-radius:5vw;
	border-bottom-left-radius:5vw;
	overflow:hidden;
	padding:1em;
}
.list-programs .thumbnail {
	border-radius:1vw;
	border-top-right-radius:calc(5vw - 1em);
	margin:0 auto 1em;
	overflow:hidden;
}
.list-programs .title {
	font-size:19px; font-size:1.9rem;
	line-height:var(--line-height-mini); margin:0 0 0.5em 0;
	padding:0 1vw;
}
.list-programs .title i {display:block; font-size:35px; font-size:3.5rem;}

.list-programs .age {margin:0 0 1em 0; color:var(--color-gray); font-size:13px; font-size:1.3rem;
	padding:0 1vw;
}
.list-programs .text {
	padding:0 1vw; margin:0; color:var(--color-gold);
	line-height:var(--line-height);
	display:none;
}
.list-programs .text {font-family:"Poppins", sans-serif;}

@media (max-width:800px) {
	.list-programs.flex-container-3 .item {flex-basis:100%; margin:0 0 5% 0;}
	.list-programs .thumbnail {float:left; width:40%; margin:0 5% 0 0;}
	.list-programs dd {margin:0 0 0 50%; overflow:hidden;}
	.list-programs .title {padding:1em 0 0 1vw;}
}
@media (max-width:460px) {
	.list-programs .thumbnail {float:none; width:100%; margin:0 0 0.5em 0;}
	.list-programs dd {margin:0 0 0.5em 0;}
}


.section-top-message {
	padding:5vw 0;
	background-color:var(--color-beige);
}
.section-top-message::after {
	content:""; display:block; position:absolute;
	top:-3vw; right:0; bottom:-3vw;
	width:40%;
	background:url("images-page/top-message-background.webp") 0 0 no-repeat;
	background-size:contain;
	z-index:1;
}
.section-top-message .flex-container {justify-content:space-between; position:relative;
	z-index: 2;
}
.section-top-message .flex-item:nth-child(1) {flex-basis:65%; z-index:2;}
.section-top-message .flex-item:nth-child(2) {flex-basis:30%; max-width:360px; position:relative; z-index:2;}
.section-top-message .thumbnail {
	position:relative;
	margin-top:3vw;
	margin-bottom:-9vw;
	background-color:#fff;
	padding:1em;
	border-radius:var(--border-radius);
	border-top-right-radius:9vw;
}
.section-top-message .thumbnail .photo {
	overflow:hidden;
	border-radius:var(--border-radius);
	border-top-right-radius:calc(9vw - 1em);
	border:1px solid var(--color-border);
}
.section-top-message .thumbnail .name {
	position:absolute; left:1em; bottom:1em;
	background-color:var(--color-white);
	line-height:var(--line-height);
	padding:1em 3em 0.5em 1em;
	border-top-right-radius:9vw;
}
.section-top-message .thumbnail .name dl {margin:0; line-height:var(--line-height-mini);}
.section-top-message .thumbnail .name dl dt {color:var(--color-gold);}
.section-top-message .thumbnail .name dl dd {margin:0;}

@media (max-width:800px) {
	.section-top-message .flex-item {display:contents;}
	.section-top-message .section-content {float:left; width:60%;}
	.section-top-message .thumbnail {float:right; width:35%; margin:0; position:relative;}
	.section-top-message .thumbnail .photo {object-fit:cover; width:100%; height:100%;}
	.section-top-message .thumbnail .photo img {object-fit:cover; width:100%; height:100%;}
}
@media (max-width:640px) {
	.section-top-message .section-content,
	.section-top-message .thumbnail {float:none; width:100%;}
	.section-top-message .thumbnail {float:none; max-width:300px; margin:3vw auto 0;}
}


.section-top-info {padding-bottom:0;}
.section-top-info .flex-container .flex-item {
	flex-basis:47%;
	background-color:#ffffff; padding:3em 2em 1em;
	border-radius:var(--border-radius);
	border:1px solid var(--color-border);
	border-top-right-radius:9vw;
	border-bottom-left-radius:9vw;
}
.section-top-info .title {
	font-size:45px; font-size:4.5rem;
}
.section-top-info .text {
	font-family:"Poppins", sans-serif; color:var(--color-gold);
}

@media (max-width:600px) {
	.section-top-info .flex-container {display:block;}
	.section-top-info .flex-container .flex-item {margin:0 0 5% 0;}
}

.section-top-access {}
.section-top-access .box {
	background:var(--color-white);
	border:1px solid var(--color-border);
	padding:3em;
	border-radius:3vw;
	border-top-right-radius:9vw;
}
.section-top-access dl {float:left; width:70%; max-width:calc(100% - 220px);}
.section-top-access dl dt {
	line-height:var(--line-height-mini); margin:0 0 0.5em 0;
	font-size:1.1em;
}
.section-top-access .button {float:right;}

@media (max-width:800px) {
	.section-top-access dl {float:none; width:100%; max-width:100%;}
	.section-top-access .button {float:none;}
}
@media (max-width:600px) {
	.section-top-access .box {padding:2em;}
}

/*
.section-top-contact .flex-item a {align-items:center; min-height:400px; display:flex; flex-wrap:nowrap; padding:40px;}
.section-top-contact .flex-item a p {margin:0; text-align:center;}
.section-top-contact .flex-item p i {display:block;}
*/
/******************/
/* page.php *******/

.article-message .thumbnail {width:25%}

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

.article-company .section-company-info {}
.article-company .section-company-info table th,
.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;}

.article-message .thumbnail {
	float:right; width:25%; margin:0 0 3em 3em;
	max-width:400px; min-width:240px;
}

/* .article-profile {} */
/* .article-service {} */
/* .article-contact {} */
.article-faq dl dt,
.article-faq dl dd {position:relative;}
.article-faq dl dt::before,
.article-faq dl dd::before {
	content:"Q."; display:block; position:absolute;
	font-size:25px; font-size:4.1vw; color:var(--color-gold);
	top:0.5vw; left:0.3em;
	line-height:1;
	opacity:0.35;
}
.article-faq dl dd::before {color:var(--color-gold);}
.article-faq dl dd::before {color:var(--color-black); content:"A."; top:-0.5em;}

.article-faq dl dt {
	font-size:25px; font-size:2.5rem; background:var(--color-beige);
	color:var(--color-gold);
	padding:1.5em 3vw 1.5em 6vw;
	margin:0 0 1.5em 0;
	border-radius:var(--border-radius);
}
.article-faq dl dd {margin:0 0 5em 0; padding:0 3vw 0 6vw;}

.article-privacy .columns {margin:2em 0; font-size:13px; font-size:1.3rem;}


.maps {
	clear:both;
	width:100%; height:30vw; min-height:400px; max-height:60vw; overflow:hidden; position:relative;
	padding-top:0; margin:3vw 0 0 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%;}




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

.archives {width:100%; margin:0 auto; text-align:left;}
.archives ul {
	display:block; 
	list-style:none; padding:0; margin:0 auto 5em;
}
.archives ul li {
	width:100%;
	margin:0 0 1em 0; padding:0;
	background-color:var(--color-white);
	border:3px solid var(--color-white);
	border-radius:var(--border-radius);
	border-top-right-radius:var(--border-radius-large);
	border-bottom-left-radius:5vw;
	position:relative;
	box-shadow:var(--box-shadow);
}
.archives-slider 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-beige);
	border-radius:var(--border-radius);
	border-top-right-radius:var(--border-radius-large);
	border-bottom-left-radius:5vw;
	pointer-events:none;
}
.archives ul li a {
	display:flex;
	flex-direction:column;
	flex-grow:1;
	align-items:stretch;
	padding:0; height:100%;
}

.archives .content {
	padding:1em 3em 1em 3em;
	flex-grow:1;
	line-height:var(--line-height-mini);
	display:flex; align-items:center; justify-content:flex-start;
}
.archives .meta {
	font-size:15px; font-size:1.5rem; font-weight:var(--font-bold);
	margin:0 3em 0 0;
	min-width:11em;
}
.archives .meta .date {
	color:var(--color-gold); padding:0 1em 0 0; margin:0 1em 0 0;
	border-right:1px solid var(--color-beige);
}
.archives .title {
	padding:0; font-size:19px; font-size:1.9rem;
	line-height:var(--line-height-mini);
	display:inline;
	-webkit-box-orient:vertical;
	-webkit-line-clamp:2;
	text-overflow: ellipsis;
	background: linear-gradient(0deg, #000, #000) no-repeat left bottom/0 1px;
	background-size: 0 1px;
	transition:var(--transition);
}

.archives ul li a:hover .thumbnail img {scale:1.1;}
.archives ul li a:hover .thumbnail img.eyecatche.grayscale {filter:grayscale(0);}
.archives ul li a:hover .title {
	background-size: 100% 1px;
}
 
 
.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:900px) {}

/******************/
/******************/
/* archive-custom-post.php */

.archives-teachers ul {
	list-style:none; padding:0 0 0; margin:0;
	display:-webkit-flex;
	display:flex;
	flex-wrap:wrap;
	flex-direction:row;
	align-items:stretch;
	align-content:stretch;
	-webkit-justify-content:space-between;
	justify-content:space-between;
}
.archives-teachers ul li {
	position:relative; display:block; margin:0 0 4% 0; padding:4px;
	background:#ffffff; line-height:1;
	flex:0 1 auto;
	flex-grow:0;
	flex-shrink:1;
	flex-basis:17%;
	max-width:17%;
	border-radius:var(--border-radius);
}
.archives-teachers ul li .thumbnail {
	display:block; margin:0; aspect-ratio:3 / 4;
	overflow:hidden; line-height:1;
	border-radius:var(--border-radius);
}
.archives-teachers ul li img {width:100%; height:100%; object-fit:cover;}
.archives-teachers ul li .title {font-size:17px; font-size:1.7rem;
	display:block; padding:0.5em; text-align:center;
}




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

.breadcrumbs {clear:both; display:block; margin:0 0 1em 0; padding:0; text-align:left; font-size:15px; font-size:1.5rem;}
.breadcrumbs p {}
.breadcrumbs ul {padding:0; margin:0 auto; list-style:none; white-space:nowrap;
overflow-x:scroll;
-webkit-overflow-scrolling:touch;
overflow-scrolling:touch;
}
.breadcrumbs ul li {display:inline-block;}
.breadcrumbs ul li:after {content:"\00BB"; margin:0 12px;}
.breadcrumbs ul li:first-child:before {}
.breadcrumbs ul li:last-child:after {content:"";}
.breadcrumbs ul li a {}
.breadcrumbs ul li a:hover {color:var(--color-red);}

/******************/
/******************/
/* navigation *****/
/*
.navigation {margin:0 auto 40px; clear:both;}
.navigation:after {content:""; clear:both; display:block; height:0; visibility:hidden;}
.navigation span {}
.navigation .navi-prev {text-align:left; float:left;}
.navigation .navi-next {text-align:right; float:right;}
.navigation .navi-prev a:before {content:"＜"; margin-right:4px;}
.navigation .navi-next a:after {content:"＞"; margin-left:4px;}
*/
/******************/
/* pagination *****/


.pagination {margin:0 auto 5em; clear:both;}
.pagination ul {
	text-align:center; font-size:19px; font-size:1.9rem;
	font-weight:var(--font-bold);
	display:flex; justify-content:center; align-items:center;
}
.pagination ul li {display:inline-block; margin:0 1em;}
.pagination ul li .current {color:var(--color-gold);}
.pagination span,
.pagination ul li a {
	padding:0;
	color:var(--color-black);
}
.pagination ul li a.prev,
.pagination ul li a.next {
	display: block;
	width:3em; height:3em; border-radius:5em;
	background:var(--color-white) center center no-repeat;
	background-size:1em;
	border:1px solid var(--color-beige);
	color:transparent;
}
.pagination ul li a.prev {background-image:url("images/arrow-left-gold.svg");}
.pagination ul li a.next {background-image:url("images/arrow-right-gold.svg");}

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

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


/******************/
/* post-links *****/

.post-links {clear:both; text-align:center; margin:0 auto 80px; max-width:320px; width:100%; display:table; table-layout:fixed;}
.post-links span {display:table-cell; padding:8px 2px;}
.post-links .navi-prev {text-align:center;}
.post-links .navi-next {text-align:center;}
.post-links a {border:1px solid #987241; border-color:var(--color-gold); background-color:#987241; background-color:var(--color-gold); color:#ffffff; display:block;}
.post-links a:hover {background:transparent; color:#987241; color:var(--color-gold);}


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


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



.button {margin:1em 0; font-size:17px; font-size:1.7rem; 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.5em 1.5em 0.5em 1.5em;
	border-radius:50px;
	text-align:left;
	background:var(--color-black);
	border:1px solid; border-color:var(--color-black); color:var(--color-white); position:relative;
	transition:var(--transition);
}
.button a::after {
	content:""; width:1.3em; height:1.3em;
	background:url("images/arrow-right-white.svg") center center no-repeat;
	background-size:100% auto;
	margin:0 0 0 2em;
}
.button a:hover {
	background-color:transparent; color:var(--color-black); cursor:pointer;
}
.button a:hover:after {
	background-image:url("images/arrow-right-black.svg");
}

.button.-red a {
	background-color:var(--color-red);
	border-color:var(--color-red);
	color:var(--color-white);
}
.button.-red a:hover {
	background-color:transparent;
	color:var(--color-red);
}
.button.-red a:hover:after {
	background-image:url("images/arrow-right-red.svg");
}
.button.-gold a {
	background-color:var(--color-gold);
	border-color:var(--color-gold);
	color:var(--color-white);
}
.button.-gold a:hover {
	background-color:transparent;
	color:var(--color-gold);
}

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


.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:#987241; border-color:var(--color-gold); color:blue;}
.button.button-success a:hover {background-color:#987241; background-color:var(--color-gold); 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;}


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

.alert {
clear:both; display:block;color: inherit;
border:1px solid transparent;
display:block;
padding:1rem;
	border-radius:4px;
color:red;
border-color:red;
background-color:transparent;
margin:0 0 1em 0;
}

.alert-success {border-color:blue; color:blue;}
.alert-error {border-color:red; color:red;}
.alert-warning {border-color:yellow; color:yellow;}

.alert > p {margin:0;}
.alert em, .alert strong {font-weight:bold;}

span.close {float:right; color:inherit; cursor:pointer;}

/******************/
/* 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:-webkit-flex;
	display:flex;
	flex-wrap:wrap;
	flex-direction:row;
	align-items:stretch;
	align-content:stretch;
	-webkit-justify-content:space-between;
	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;
}
.columns-2 {columns:2;}


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

.r-table,
.responsive-table {
	width:100%;
	position: relative;
	overflow-y: hidden;
	overflow-x: scroll;
	width: 100%;
	cursor: grab;
}


/******************/
/* 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:#cccccc; 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:#987241; background-color:var(--color-gold); 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:#987241; color:var(--color-gold); border-bottom:1px solid #ffffff;}
.tab-selector ol li.is-current:hover {background-color:#ffffff; background-color:var(--color-background); color:#987241; color:var(--color-gold);}

.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 ********/


body.is-modal {overflow:hidden;}
.modal {display:none;
position:fixed; top:0; left:0; right:0; bottom:0; background:rgba(255,255,255,0.8);
overflow-y:scroll;
-webkit-overflow-scrolling:touch;
overflow-scrolling:touch;
z-index:99999;
}

.modal-close {cursor:pointer; position:absolute; top:12px; right:12px; width:40px; height:40px;
background:#ffffff center center no-repeat;
	background-size:20px 20px;
	background-color:var(--color-background);
border:1px solid #f578b9;
background-image:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyMCAyMCI+PGRlZnM+PHN0eWxlPi5jbHN7ZmlsbDojZjU3OGI5O308L3N0eWxlPjwvZGVmcz48cG9seWdvbiBjbGFzcz0iY2xzIiBwb2ludHM9IjIwIDEuMjUgMTguNzUgMCAxMCA4Ljc1IDEuMjUgMCAwIDEuMjUgOC43NSAxMCAwIDE4Ljc1IDEuMjUgMjAgMTAgMTEuMjUgMTguNzUgMjAgMjAgMTguNzUgMTEuMjUgMTAgMjAgMS4yNSIvPjwvc3ZnPg==");
	border-radius:50%;
color:transparent;
}
.modal-close:hover {
background-color:#987241; background-color:var(--color-gold);
background-image:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyMCAyMCI+PGRlZnM+PHN0eWxlPi5jbHN7ZmlsbDojZmZmO308L3N0eWxlPjwvZGVmcz48cG9seWdvbiBjbGFzcz0iY2xzIiBwb2ludHM9IjIwIDEuMjUgMTguNzUgMCAxMCA4Ljc1IDEuMjUgMCAwIDEuMjUgOC43NSAxMCAwIDE4Ljc1IDEuMjUgMjAgMTAgMTEuMjUgMTguNzUgMjAgMjAgMTguNzUgMTEuMjUgMTAgMjAgMS4yNSIvPjwvc3ZnPg==");
}




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



.form {clear:both; display:block; margin:0;}
.form table {
	line-height:var(--line-height-mini);
	border-top:1px solid; border-color:var(--color-beige);}
.form table th,
.form table td {
	border-bottom:1px solid; border-color:var(--color-beige);
	padding:1.5em 1em; vertical-align:middle;
}
.form table th {
	text-align:center;
}
.form table td {}
.form table th i {
	display:block; font-size:25px; font-size:2.5rem;
	color:#987241; color:var(--color-gold);
}


@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:32px 0 0 0; margin:0 0 12px 0;}
	.form table th i {display:inline-block; margin:0 1em 0 0;}
	.form table td {padding:0 0 16px 0;}	
}


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);
	background-color:var(--color-white);
	font-size:19px; font-size:1.9rem;
}


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 #cccccc;}
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-red);
	border:2px solid var(--color-red); border-radius:100px;
	color:#fff;
	padding:1em 5em 1em 3em;
	appearance:none;
	display:block;
	cursor:pointer;
	transition:var(--transition);
}
input[type="submit"]:hover {
	background-color:var(--color-white);
	color:var(--color-red);
}

input[type="submit"][disabled],
input[type="submit"][disabled]:hover {
	color:var(--color-gray); background:transparent;
	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 #987241; border-color:var(--color-gold);
}

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;
}

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

.wpcf7-validation-errors {
border:1px solid var(--color-red);
color:var(--color-red);
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 #cccccc; display:inline-block;}
.wpcf7-list-item-label:after{
width:10px; height:6px; left:6px; top:6px;
border:2px solid #987241; border-color:var(--color-gold);
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 ****/


@media (max-width:1600px) {
}

@media (max-width:1200px) {
}



/* ▲ iPad Air4 横（820px） ▼ */
@media (max-width:800px) {

}

/* ▲ iPhone 6+ 横（736px） ▼ */
@media (max-width:720px) {

}



/* ▲ Mac OS Safari - Minimum(504px) ▼ */
@media (max-width:520px) {

}

/* ▲ iPhone 6+ - iPhone 6 414px▼ */
@media (max-width:400px) {

}


/* ▲ iPod touch 320px ▼ */
@media (max-width:300px) {

}

/******************/
/******************/
/* 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:"Cormorant", sans-serif;}

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


/* end ************/
/******************/
/******************/

