@charset "UTF-8";

/* Layout
------------------------- */
.skin {
	width: 1400px;
	margin: auto;
	padding: 0 10px;
}

.flexbox {
	display: flex;
}

/* Header
------------------------- */
#top {
	transition: 0.4s;
	position: fixed;
	z-index: 999;
	display: flex;
	top: 0;
	left: 0;
	width: 100%;
	height: 120px;
	background-color: #fff;
	box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.15);
}

#siteID {
	flex: 0 0 240px;
	width: 240px;
	height: 120px;
	padding: 10px 20px;
}

#siteID__logo {
	transition: 0.4s;
	width: 200px;
	height: 100px;
}

#innerTop {
	flex: 1 1 600px;
}

#forehead {
	transition: 0.4s;
	overflow: hidden;
	width: 100%;
	height: 50px;
	padding: 0 15px 0;
	text-align: right;
}

#forehead__inner {
	padding: 5px 0 0;
}

#forehead .tel {
	display: inline-block;
	margin: 0 20px 0 0;
	letter-spacing: 2px;
	font-weight: 700;
	font-size: 18px;
}

#gnavi {
	display: flex;
	justify-content: flex-end;
	width: 100%;
	height: 70px;
}

/* short */
#top.short {
	height: 60px;
}

.short #siteID {
	height: 60px;
	padding: 10px 20px 0 15px;
}

.short #forehead {
	height: 0;
}

.short #siteID__logo {
	width: 100px;
	height: 40px;
}

/* Global Navigation
------------------------- */
#gnavi ul {
	display: flex;
	list-style-type: none;
}

#gnavi a {
	display: block;
	text-decoration: none;
	text-align: center;
}

#menu-gnavi {
	padding: 0 30px 0 0;
}

#menu-gnavi .menu-item {
	display: flex;
	align-items: center;
	height: 70px;
}

#menu-gnavi .menu-item a {
	display: inline-block;
	position: relative;
	color: #000;
}

#menu-gnavi .menu-item a:after {
	content: "";
	transform: rotate(15deg);
	display: inline-block;
	position: relative;
	top: 1px;
	width: 20px;
	height: 20px;
	margin: 0 20px 0 0;
	border-right: solid 1px var(--dull-gray);
}

#menu-gnavi .menu-item:last-child {
	margin: 0;
}

#menu-gnavi .menu-item:last-child a:after {
	display: none;
}

.button2 {
	transition: 0.4s;
	justify-content: space-between;
	width: 241px;
}

.button2__item {
	transition: 0.4s;
	flex: 0 0 120px;
	width: 120px;
}

#menuButton {
	cursor: pointer;
	display: none;
}

.button2__item .button2__item--anc {
	transition: 0.4s;
	display: block;
	width: 120px;
	height: 70px;
	padding: 10px 10px 0;
	background-color: var(--navy);
	text-align: center;
	font-size: 13px;
	color: #fff;
}

.button2__label {
	transition: 0.4s;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	height: 53px;
	margin: auto;
}

.button2__label:before {
	transition: 0.4s;
	content: "";
	display: block;
	width: 100%;
	height: 30px;
	background-image: url("../img/icon/icon_insta.svg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
}

.gotoContact .button2__label:before {
	background-image: url("../img/icon/icon_mail.svg");
	background-size: 83% 83%;
}

.hamButton .button2__label:before {
	display: none;
	background-image: url("../img/icon/icon_hamburger.svg");
	background-size: contain;
}

.button2__name {
	display: block;
	width: 100%;
	text-align: center;
}

/* short */
.short #menu-gnavi .menu-item {
	height: 60px;
}

.short .button2 {
	width: 201px;
}

.short .button2__item {
	flex: 0 0 100px;
	width: 100px;
}

.short .button2__item .button2__item--anc {
	width: 100px;
	height: 60px;
	padding: 10px 10px 0;
	font-size: 11px;
}

.short .button2__label {
	height: 43px;
}

.short .button2__label:before {
	height: 20px;
}

/* Chest
------------------------- */
#chest main {
	padding: 30px 20px 100px;
}

.wp-block-quote {
	margin: 30px;
	padding: 20px 20px 0;
	border: dotted 1px var(--gray);
	background-color: var(--pale-gray);
}

/* Footer
------------------------- */
#footer {
	padding: 100px 0;
	background-color: var(--pale-gray);
}

#footerContents__above {
	display: flex;
	justify-content: space-between;
	width: 1160px;
	padding: 0 0 50px;
	margin: auto;
}

.fnavi {
	flex: 0 0 calc(25% - 20px);
}

#footerContents__Below {
	display: flex;
	justify-content: center;
}

#footerContents__siteID {
	margin: 0 30px 0 0;
}

#organizationInfo {
	margin: -7px 0 0 30px;
	line-height: 1.8;
	font-weight: 400;
	font-size: 17px;
}

#organizationInfo address {
	margin: 0 0 30px;
}

#links {
	list-style-type: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0 auto 80px;
}

#links li {
	margin: 0 0 10px;
}

.fnavi__header2 {
	position: relative;
	margin: 0 0 20px;
	letter-spacing: 1px;
	font-weight: 600;
	font-size: 18px;
	color: var(--navy);
}

.fnavi__header2:before {
	content: "";
	transform: rotate(23deg);
	display: inline-block;
	position: relative;
	top: 9px;
	width: 20px;
	height: 24px;
	border-left: solid 1px var(--navy);
}

.fnavi__header2:after {
	content: "";
	transform: rotate(23deg);
	display: inline-block;
	position: relative;
	top: -1px;
	width: 23px;
	height: 24px;
	border-right: solid 1px var(--navy);
}

.fnavi ul {
	list-style-type: none;
	margin: 0 0 50px;
}

.fnavi li {
	line-height: 2;
}

.fnavi a {
	text-decoration: none;
	color: #000;
}

.annotation {
	background-color: var(--pale-gray);
	text-align: center;
	margin-bottom: 0.5em;
}

#copyright {
	padding: 20px 0;
	background-color: var(--navy);
	text-align: center;
	font-weight: 400;
	font-size: 13px;
	color: #fff;
}

/* Floating Menu
------------------------- */
#floatingMenu {
	z-index: 998;
	position: fixed;
	display: none;
	width: 100%;
	height: calc(100vh - 50px);
	top: 50px;
	left: 0;
	background-color: #fff;
}

#floatingMenu.showed {
	display: flex;
	justify-content: center;
	align-items: center;
}

#menu-gnavi2 {
	list-style-type: none;
	width: 285px;
	margin: auto;
}

#menu-gnavi2 a {
	display: block;
	padding: 10px;
	margin: 0 0 10px;
	border: solid 1px var(--navy);
	text-decoration: none;
	text-align: center;
	font-family:
		"Noto Serif JP",
		"游明朝", "Yu Mincho",
		"游明朝体", "YuMincho",
		"ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN",
		"MS 明朝", "MS Mincho",
		"ＭＳ Ｐ明朝", "MS PMincho",
		serif;
	color: var(--navy);
}

/* hamburger Button
------------------------- */
#menuButton__inner {
	position: relative;
	top: calc(50% - 11px);
	width: 30px;
	height: 23px;
	margin: auto;
}

.menuBar {
	position: absolute;
	width: 30px;
	height: 3px;
	background-color: var(--navy);
}

#menuBar__1 {
	transition: 0.4s;
	position: absolute;
	left: 0;
	top: 0;
}

#menuBar__2 {
	transition: 0.4s;
	position: absolute;
	left: 0;
	top: 10px;
}

#menuBar__3 {
	transition: 0.4s;
	position: absolute;
	left: 0;
	top: 20px;
}

#menuButton.close #menuButton__inner {
	top: 11px;
	width: 30px;
}

#menuButton.close .menuBar {
	width: 34px;
}

#menuButton.close #menuBar__1 {
	transform: rotate(-45deg);
	top: 14px;
}

#menuButton.close #menuBar__3 {
	transform: rotate(45deg);
	top: 14px;
}

#menuButton.close #menuBar__2 {
	display: none;
}

/* Smartphone Menu
------------------------- */
#smartMenu {
	z-index: 5;
	display: flex;
	display: none;
	list-style-type: none;
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 50px;
	background-color: var(--navy);
}

.smartMenu__item {
	flex: 0 0 50%;
}

.smartMenu__item a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 50px;
	background-color: var(--navy);
	text-decoration: none;
	color: #fff;
}

.smartMenu__item--name {
	font-weight: 600;
	font-size: 13px;
}

.smartMenu__item.tel a {
	border-right: solid 1px #fff;
}

.smartMenu__item.tel .smartMenu__item--name:before {
	display: inline-block;
	content: "";
	width: 14px;
	height: 14px;
	margin: 0 2px 0 0;
	background-image: url("../img/icon/icon-phone.svg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	vertical-align: -2px;
}

.smartMenu__item.mail .smartMenu__item--name:before {
	display: inline-block;
	content: "";
	width: 20px;
	height: 14px;
	margin: 0 2px 0 0;
	background-image: url("../img/icon/icon_mail.svg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	vertical-align: -2px;
}

/* End of base.css */