@charset "UTF-8";
body {
	padding-bottom: 0;
}

.sidebar .card-header {
	padding: 0 !important;

	border-bottom: none !important;
	background-color: transparent !important;
}

.close-button {
	padding: 0;

	text-decoration: none !important;

	border: none;
	outline: none;
	background: none;
	-webkit-box-shadow: none;
	        box-shadow: none;
}

.main-content {
	-webkit-box-flex: 1;
	-webkit-flex: 1;
	    -ms-flex: 1;
	        flex: 1;

	-webkit-transition: -webkit-transform 0.3s ease;
	        transition: -webkit-transform 0.3s ease;
	        transition:         transform 0.3s ease;
	        transition:         transform 0.3s ease, -webkit-transform 0.3s ease;
}

.layout {
	min-height: 100vh;

	-webkit-transition: margin-left 0.3s ease;
	        transition: margin-left 0.3s ease;
}
.layout.menu-open {
	margin-left: 332px;
}
.layout.menu-open .side-menu-open {
	left: 0;
}

/* 初期ロード時にtransitionを無効化 */
.layout.no-transition {
	-webkit-transition: none !important;
	        transition: none !important;
}

.side-menu-open {
	position: fixed;
	z-index: 1;
	top: 0;
	left: -322px;

	overflow-y: auto;

	width: 322px;
	height: 100%;

	-webkit-transition: left 0.3s ease;
	        transition: left 0.3s ease;

	background-color: #1a1a1a;
}

.open-button {
	margin: 20px 20px 0;

	border: none;
	background: none;
}

.sidebar {
	position: relative;

	-webkit-flex-shrink: 0;
	-ms-flex-negative: 0;
	        flex-shrink: 0;

	width: 100%;
	height: 100vh;
	padding: 10px 0;

	background-color: #1a1a1a;
}
.sidebar > button {
	position: absolute;
	top: 20px;
	right: 20px;
}
.sidebar .sidebar-container {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display:         flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	-webkit-justify-content: space-between;
	        justify-content: space-between;

	height: 100%;
}
.sidebar .sidebar-container .logo {
	display: block;

	margin: 0 auto;
}
.sidebar .sidebar-container .sidebar-wrapper {
	margin: 0;
	padding: 0;

	list-style: none;
}
.sidebar .sidebar-container .sidebar-wrapper.navbar-collapse {
	-webkit-box-align: start !important;
	-webkit-align-items: flex-start !important;
	        align-items: flex-start !important;
	-ms-flex-align: start !important;
}
.sidebar .sidebar-container .sidebar-wrapper .menu-home a {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display:         flex;
	-webkit-box-align: center;
	-webkit-align-items: center;
	        align-items: center;
	-ms-flex-align: center;

	margin-top: 30px;

	color: #fff;

	gap: 20px;
}
.sidebar .sidebar-container .sidebar-wrapper .menu-home a img {
	width: 25px;
}
.sidebar .sidebar-container .sidebar-wrapper .menu-home a p {
	font-size: 18px;
}
.sidebar .nav-link {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display:         flex;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	-webkit-justify-content: flex-start;
	        justify-content: flex-start;

	padding-left: 15px;

	text-align: left;
}
.sidebar .card {
	padding: 15px 0;

	border: none;
	background: none;
}
.sidebar .menu-title {
	font-size: 22px;
	font-weight: bold;

	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display:         flex;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	-webkit-justify-content: flex-start;
	        justify-content: flex-start;

	width: 100%;
	margin: 0;
	padding-left: 30px;

	text-align: left;

	color: #fff;
	border: none !important;
	outline: none !important;
	background-color: #1a1a1a;
	-webkit-box-shadow: none !important;
	        box-shadow: none !important;
}
.sidebar .menu-title img {
	margin-left: 20px;
}

.sidebar .shop-name {
	font-size: 20px;

	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display:         flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	-webkit-justify-content: center;
	        justify-content: center;

	padding: 0 20px;

	text-align: center;

	color: #fff;
}

.menu-title:focus,
.menu-title:active {
	border: none !important;
	outline: none !important;
	-webkit-box-shadow: none !important;
	        box-shadow: none !important;
}

.dropdown-item {
	position: relative;
	z-index: 0;

	display: -webkit-box !important;
	display: -webkit-flex !important;
	display: -ms-flexbox !important;
	display:         flex !important;
	-webkit-box-align: center;
	-webkit-align-items: center;
	        align-items: center;
	-ms-flex-align: center;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	-webkit-justify-content: flex-start;
	        justify-content: flex-start;

	width: 100%;
	padding: 12px 12px 12px 30px;

	color: #ddd;

	gap: 15px;
}
.dropdown-item .menu-icon-wrapper {
	position: relative;

	-webkit-flex-shrink: 0;
	-ms-flex-negative: 0;
	        flex-shrink: 0;

	width: 25px;
	height: 25px;
}
.dropdown-item .menu-icon-wrapper .menu-icon {
	position: absolute;

	width: 100%;
	height: 100%;

	-webkit-transition: opacity 0.3s ease;
	        transition: opacity 0.3s ease;

	inset: 0;
}
.dropdown-item .menu-icon-wrapper .hover {
	opacity: 0;
}
.dropdown-item .menu-icon-wrapper .default {
	opacity: 1;
}
.dropdown-item .menu-text {
	font-size: 16px;

	-webkit-box-flex: 1;
	-webkit-flex: 1;
	    -ms-flex: 1;
	        flex: 1;

	color: #fff48f;
}
.dropdown-item .menu-arrow {
	width: 8px;
	margin-left: auto;
}
.dropdown-item::before {
	position: absolute;
	z-index: -1;

	content: "";
	-webkit-transition: background 0.2s ease;
	        transition: background 0.2s ease;

	background: transparent;

	inset: 0;
}
.dropdown-item:hover,
.dropdown-item:focus {
	color: #fff;
}
.dropdown-item:hover .menu-icon-wrapper .hover,
.dropdown-item:focus .menu-icon-wrapper .hover {
	opacity: 1;
}
.dropdown-item:hover .menu-icon-wrapper .default,
.dropdown-item:focus .menu-icon-wrapper .default {
	opacity: 0;
}
.dropdown-item:hover::before,
.dropdown-item:focus::before {
	background: #e1c667;
}

.dropdown-item:hover .menu-text,
.dropdown-item:focus .menu-text {
	color: #272a29;
}

.user-actions {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display:         flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	    -ms-flex-direction: column;
	        flex-direction: column;

	width: 100%;
	margin-top: 80px;
	padding-bottom: 57px;
}

.logout a {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display:         flex;
	-webkit-box-align: center;
	-webkit-align-items: center;
	        align-items: center;
	-ms-flex-align: center;

	color: #fff;

	gap: 20px;
}
.logout a img {
	margin-left: 15px;
}

.language {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display:         flex;
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	-webkit-justify-content: flex-end;
	        justify-content: flex-end;

	width: 100%;
	padding: 1rem 1rem 0 1rem;
}
.language .language-container {
	position: relative;

	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display:         flex;
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	-webkit-justify-content: flex-end;
	        justify-content: flex-end;
}
.language .language-container .language-button {
	position: relative;
	z-index: 2;

	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display:         flex;
	-webkit-box-align: center;
	-webkit-align-items: center;
	        align-items: center;
	-ms-flex-align: center;
	-ms-flex-pack: distribute;
	-webkit-justify-content: space-around;
	        justify-content: space-around;

	min-width: 138px;
	height: 36px;
	padding: 8px 0 !important;

	white-space: nowrap;

	border: 1px solid #cac3aa;
	border-radius: 27.35px;
	background-color: #79643a;
}
.language .language-container .language-button img:first-of-type {
	padding-right: 15px;
	padding-left: 5px;
}
.language .language-container .language-button img:last-of-type {
	padding-right: 5px;
	padding-left: 15px;
}
.language .language-container .dropdown-menu {
	position: absolute;
	z-index: 1;
	right: 48px !important;
	left: auto !important;

	margin-right: -50px;
	margin-bottom: -36px;
	padding: 13px 0 50px !important;

	-webkit-transform-origin: bottom right;
	        transform-origin: bottom right;

	border-radius: 16px;
	background-color: #c8c1a6;
}
.language .language-container .dropdown-menu .dropdown-item {
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	-webkit-justify-content: center;
	        justify-content: center;

	padding: 12px 30px !important;

	text-align: center;

	color: #1a1a1a;
}
.language .language-container .dropdown-menu .dropdown-item:active {
	font-weight: bold;

	background-color: #fff176;
}

.language .dropdown-menu .dropdown-item {
	color: #1a1a1a;
	background-color: transparent !important;
}
.language .dropdown-menu .dropdown-item::before {
	background: none !important;
}
.language .dropdown-menu .dropdown-item:hover {
	color: #1a1a1a !important;
	background-color: #fff48f !important;
}
.language .dropdown-menu .dropdown-item:active {
	font-weight: bold;

	background-color: #e1c667 !important;
}

.stop-icon {
	width: 40px;
}

.sidebar .sidebar-wrapper {
	width: 100%;
}
.sidebar .sidebar-wrapper ul,
.sidebar .sidebar-wrapper li,
.sidebar .sidebar-wrapper a,
.sidebar .sidebar-wrapper .card,
.sidebar .sidebar-wrapper .card-header,
.sidebar .sidebar-wrapper .btn-link,
.sidebar .sidebar-wrapper .card-title,
.sidebar .sidebar-wrapper .dropdown-item {
	width: 100%;
}
