@charset "UTF-8";
/* ==========================================
   ヘッダー・メニュー系クラス (mog-p-header-, mog-p-menu-, mog-p-logo)
   ========================================== */

/* ==========================================
   ヘッダーバー（p-header-search はJS依存のため残す）
   ========================================== */
.mog-p-header__bar {
	display: flex;
	align-items: center;
	height: 70px;
	padding-left: 70px;
	position: relative;
}

.mog-p-header__bar::after {
	content: '';
	border-bottom: 1px solid #ddd;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: -1;
}

.mog-p-header__bar.u-no-border::after {
	border-bottom: none;
}

@media (min-width: 992px) {
	body.l-header__fix .is-header-fixed .mog-p-header__bar.u-no-border::after {
		border-bottom: 1px solid #ddd;
	}
}

@media only screen and (max-width: 991px) {
	.mog-p-header__bar {
		height: 60px;
		padding-left: 60px;
	}

	body.l-header__fix--mobile .is-header-fixed .mog-p-header__bar.u-no-border::after {
		border-bottom: 1px solid #ddd;
	}
}

/* ==========================================
   ロゴ
   ========================================== */
.mog-p-logo {
}

.mog-p-header__logo {
	display: flex;
	align-items: center;
	flex: 0 0 auto;
	height: 70px;
	padding: 0;
}

.mog-p-header__logo img {
	display: block;
	max-width: 100%;
	height: auto;
}

.mog-p-header__logo--text {
	font-size: 30px;
	line-height: 1.2;
	overflow: hidden;
}

.mog-p-header__logo--mobile {
	display: none;
}

.mog-p-header__logo--retina {
}

@media only screen and (max-width: 991px) {
	.mog-p-header__logo {
		display: none;
	}

	.mog-p-header__logo--mobile {
		display: flex;
		align-items: center;
		flex: 1 1 auto;
		height: 60px;
		padding: 0 16px;
	}

	.mog-p-header__logo--text {
		font-size: 24px;
	}
}

/* ==========================================
   ヘッダー検索（.p-header-search はJS依存）
   ========================================== */
@media (min-width: 992px) {
	.p-header-search,
	.mog-p-header-search {
		position: relative;
	}

	.p-header-search.is-active .mog-p-header-search__form {
		width: 300px;
	}
}

@media (max-width: 991px) {
	.p-header-search,
	.mog-p-header-search {
		display: flex;
	}

	.p-header-search.is-active .mog-p-header-search__form {
		border-bottom: 1px solid #ddd;
		height: 62px;
	}
}

/* ==========================================
   会員メニュー（モバイル非表示）
   ========================================== */
.mog-p-header-member-menu--mobile-hidden {
}

/* ==========================================
   メニューボタン
   ========================================== */
.mog-p-menu-button {
	border-right: 1px solid #ddd;
	line-height: 70px;
	height: 70px;
	width: 70px;
}

@media only screen and (max-width: 991px) {
	.mog-p-menu-button {
		line-height: 60px;
		height: 60px;
		width: 60px;
	}
}

/* ==========================================
   子テーマカスタム: mog- プレフィックス版のヘッダースタイル
   ========================================== */
.mog-l-header__bar {
	display: flex !important;
	align-items: center !important;
	flex-wrap: nowrap !important;
	justify-content: space-between !important;
}

.mog-p-header__bar {
	padding-left: 16px !important;
	padding-right: 12px !important;
}

.mog-p-logo {
	order: 1 !important;
	position: relative !important;
	float: none !important;
	flex-shrink: 0;
}

.mog-p-header__logo {
	order: 1 !important;
	position: relative !important;
	float: none !important;
	flex-shrink: 0;
}

.mog-p-header__logo--mobile {
	order: 1 !important;
	position: relative !important;
	float: none !important;
	flex-shrink: 0;
	padding: 0;
	margin-right: 8px;
}

.mog-p-logo img {
	max-height: 40px;
	width: auto;
}

.mog-p-header__logo img {
	max-width: 185px;
}

.mog-p-logo.mog-p-header__logo--mobile img {
	max-width: clamp(104px, calc(104px + (100vw - 320px) * 0.745), 145px);
}

.mog-p-header-search {
	order: 2 !important;
	position: relative !important;
	float: none !important;
	flex: 0 1 auto !important;
	width: 50% !important;
	max-width: 300px !important;
	margin: 0 !important;
	height: 32px !important;
	min-height: 32px !important;
	max-height: 32px !important;
	display: block !important;
	padding: 0 8px !important;
}

.mog-p-header-search.is-active .mog-p-header-search__form {
	width: 100% !important;
	height: 32px !important;
}

.mog-p-header-search__form {
	display: block !important;
	opacity: 1 !important;
	visibility: visible !important;
	position: relative !important;
	height: 32px !important;
	width: 100% !important;
	overflow: visible !important;
	background: transparent !important;
	border: none !important;
	margin: 0 !important;
	padding: 0 !important;
	top: auto !important;
	left: auto !important;
	right: auto !important;
	bottom: auto !important;
	transition: none !important;
}

.mog-p-header-search__form form {
	display: flex !important;
	align-items: center !important;
	border: 1px solid var(--tcd-secondary-color) !important;
	border-radius: 2px !important;
	overflow: hidden !important;
	box-sizing: border-box !important;
	height: 32px !important;
	min-height: 32px !important;
	max-height: 32px !important;
	width: 100% !important;
	padding: 0 !important;
	margin: 0 !important;
	background: #FFFFFF !important;
	position: relative !important;
}

.mog-p-header-search__input {
	flex: 1 !important;
	border: none !important;
	padding: 0px 6px !important;
	font-size: 15px !important;
	background-color: #FFFFFF !important;
	color: #3E3A39 !important;
	outline: none !important;
	box-sizing: border-box !important;
	min-width: 0 !important;
	height: 32px !important;
	min-height: 32px !important;
	max-height: 32px !important;
	line-height: normal !important;
	vertical-align: middle !important;
	margin: 0 !important;
	border-radius: 0 !important;
	position: relative !important;
	top: auto !important;
	left: auto !important;
	right: auto !important;
	bottom: auto !important;
}

.mog-p-header-search__input:focus {
	outline: none !important;
	box-shadow: none !important;
}

.mog-p-header-search__input::placeholder {
	color: #999999 !important;
}

.mog-p-header-search__submit {
	width: 32px !important;
	height: 32px !important;
	min-width: 32px !important;
	max-width: 32px !important;
	min-height: 32px !important;
	max-height: 32px !important;
	background-color: var(--tcd-secondary-color) !important;
	border: none !important;
	padding: 0 !important;
	margin: 0 !important;
	cursor: pointer !important;
	flex-shrink: 0 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	position: relative !important;
	color: #FFFFFF !important;
	font-size: 0 !important;
	line-height: 0 !important;
	border-radius: 0 !important;
	top: auto !important;
	left: auto !important;
	right: auto !important;
	bottom: auto !important;
	background: var(--tcd-secondary-color) !important;
	font-family: "design_plus", sans-serif !important;
}

.mog-p-header-search__submit::before {
	content: "" !important;
	display: block !important;
	width: 20px !important;
	height: 20px !important;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E") !important;
	background-size: contain !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
}

.mog-p-header-search__button {
	display: none !important;
}

.mog-p-header-member-menu--mobile-hidden {
	order: 3 !important;
}

.mog-p-menu-button {
	order: 999 !important;
	position: relative !important;
	float: none !important;
	flex-shrink: 0 !important;
	margin-left: 0 !important;
}

.mog-c-menu-button {
	position: relative !important;
	width: 36px !important;
	height: 36px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}

.mog-c-menu-button::before,
.mog-c-menu-button::after {
	content: "" !important;
	display: block !important;
	position: absolute !important;
	width: 30px !important;
	height: 3px !important;
	background-color: #E60012;
	transition: transform 0.3s ease !important;
	border-radius: 9999px;
}

.mog-c-menu-button::before {
	top: 8px !important;
	left: clamp(0px, calc(10vw - 40px), 8px) !important;
	box-shadow: 0 8px 0 #E60012 !important;
}

.mog-c-menu-button::after {
	bottom: 9px !important;
	left: clamp(0px, calc(10vw - 40px), 8px) !important;
	width: 26px !important;
}

.mog-l-header__bar .mog-p-menu-button {
	order: 999 !important;
	position: relative !important;
	float: none !important;
	flex-shrink: 0 !important;
	margin-left: 0 !important;
	border: none;
}

@media only screen and (max-width: 991px) {
	.mog-p-header-member-menu--mobile-hidden {
		display: none !important;
	}
}
