@charset "UTF-8";

/* ADDITIONAL RESET
 * ----------------------------------------------- */
* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

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

body * {
	max-height: 99999em;
}

img {
	display: inline-block;
	height: auto;
	max-width: 100%;
	vertical-align: middle;
}

input,
label,
select,
button,
textarea {
	background: none;
	border: 0;
	display: inline-block;
	font: inherit;
	line-height: 1;
	margin: 0;
	padding: 0;
	vertical-align: middle;
	white-space: normal;
}

input:focus,
button:focus,
select:focus {
	outline: 0;
}

/* Make webkit render the search input like a normal text field */
input[type=search] {
	-webkit-appearance: textfield;
}

/* Turn off the recent search for webkit. It adds about 15px padding on the left */
::-webkit-search-decoration {
	display: none;
}

/* Turn off scroll bars in IE unless needed */
textarea {
	overflow: auto;
	white-space: pre-line;
}

/* BASE
 * ----------------------------------------------- */
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
	border: 0;
	font: inherit;
	font-size: 100%;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

html {
	line-height: 1;
}

ol,
ul {
	list-style: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

caption,
th,
td {
	font-weight: normal;
	text-align: left;
	vertical-align: middle;
}

q,
blockquote {
	quotes: none;
}

q:before,
q:after {
	content: "";
	content: none;
}

blockquote:before,
blockquote:after {
	content: "";
	content: none;
}

a img {
	border: none;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
	display: block;
}

/* HEADER
 * ----------------------------------------------- */
/* COMMON HEADER
 * ----------------------------------------------- */
header {
	z-index: 999;
}

.menu-mega {
	display: none;
}

.navigation-list a {
	display: block;
}

@media print,
(min-width: 768px) {
	header {
		height: 100vh;
		left: 0;
		position: fixed;
		top: 0;
		width: 60px;
	}

	header .logo-image {
		display: block;
		left: 15%;
		margin: 0 auto 30px;
		position: absolute;
		top: 56px;
		width: 114px;
		z-index: 3;
	}

	header.is-active .button-close-wrapper,
	header.is-active .overlay {
		opacity: 1;
		visibility: visible;
	}

	header .overlay {
		height: 100vh;
		left: 235px;
		opacity: 0;
		position: fixed;
		top: 0;
		transition: opacity 0.3s ease, visibility 0.3s ease;
		visibility: hidden;
		width: 100vw;
	}

	.header-navigation-content {
		align-items: flex-end;
		background: #fff;
		display: flex !important;
		height: 100vh;
		left: 0;
		min-height: 600px;
		padding: 200px 0 51px;
		position: fixed;
		top: 0;
		transition: transform 0.3s ease;
		width: 175px;
		z-index: 2200;
	}

	.header-navigation-content .header-navigation {
		display: block !important;
	}

	.is-container-home .header-navigation-content {
		min-height: 500px;
	}

	.is-ipad .header-navigation-content {
		height: 100%;
		transition: all 0.3s ease;
	}

	.header-navigation {
		width: 100%;
	}

	.menu-link-ipad {
		display: none;
		height: 100%;
		left: 0;
		position: absolute;
		top: 0;
		width: 100%;
		z-index: 2;
	}

	.is-ipad .menu-link-ipad {
		display: block;
	}

	.is-ipad .has-sub.is-active .menu-link-ipad {
		display: none;
	}

	.navigation-list {
		font-size: 12px;
		font-weight: bold;
		letter-spacing: 0.07em;
		line-height: 2.52;
		position: relative;
		z-index: 5;
	}

	.navigation-list>li:not(:last-child) {
		margin-bottom: 9px;
	}

	.navigation-list a {
		color: #221815;
		padding: 4px 15px 4px 30px;
		position: relative;
	}

	.navigation-list a::after {
		background: #e2e2e2;
		content: "";
		display: none;
		height: 100%;
		left: 0;
		position: absolute;
		top: 0;
		width: 100%;
		z-index: -1;
	}

	.navigation-list a:hover:after {
		display: block;
	}

	.navigation-list .has-sub {
		position: relative;
	}

	.navigation-sub-list {
		transition: display 0.26s ease;
	}

	.navigation-sub-list>li:not(:last-child) {
		margin-bottom: -3px;
	}

	.navigation-sub-list a {
		padding-left: 40px;
	}

	.button-menu-wrapper {
		opacity: 0;
		position: absolute;
		right: 0;
		top: 50%;
		transform: translateY(-50%);
		transition: 0.26s ease;
		visibility: hidden;
		width: 60px;
		z-index: 100;
	}

	.button-menu-wrapper .button-menu {
		cursor: pointer;
		width: 60px;
	}

	.button-menu-wrapper .button-menu img {
		display: block;
		margin: 0 auto;
		width: 26px;
	}

	.button-close-wrapper {
		align-items: center;
		background: #231815;
		display: flex;
		height: 100%;
		left: 175px;
		opacity: 0;
		position: absolute;
		top: 0;
		visibility: hidden;
		width: 60px;
	}

	.button-close-wrapper .button-close {
		cursor: pointer;
	}

	.is-header-small header:not(.is-active) .header-navigation-content {
		transform: translateX(-115px);
	}

	.is-header-small header:not(.is-active) .header-navigation-content .logo,
	.is-header-small header:not(.is-active) .header-navigation-content .header-navigation {
		opacity: 0;
		visibility: hidden;
	}

	.is-header-small header.is-active .button-close-wrapper {
		opacity: 1;
		visibility: visible;
	}

	.is-header-small .button-menu-wrapper {
		opacity: 1;
		visibility: visible;
	}

	.is-header-small .button-menu-wrapper.is-active {
		opacity: 0;
		visibility: hidden;
	}

	.is-header-small .header-navigation-content {
		background: #fff;
	}
}

@media (max-height: 750px) and (min-height: 100px) and (min-width: 768px) {
	header .logo-image {
		top: 30px;
	}

	header .navigation-list>li {
		margin-bottom: 4px;
	}

	.header-navigation-content {
		padding-bottom: 25px;
	}
}

@media (max-height: 700px) and (min-height: 100px) and (min-width: 768px) {
	.navigation-list a {
		padding: 0 10px 0 30px;
	}

	.navigation-inner {
		overflow: hidden;
	}

	.header-navigation-content {
		min-height: auto !important;
	}

	.header-navigation {
		max-height: 100%;
		overflow-y: auto;
	}
}

@media only screen and (max-width: 767px) {
	header {
		background: #fff;
		left: 0;
		padding: 0.1rem 0;
		position: fixed;
		top: 0;
		width: 100%;
		z-index: 2000;
	}

	header .logo {
		position: relative;
		z-index: 5;
	}

	header .logo-image {
		display: block;
		margin: 0 auto;
		width: 0.64rem;
	}

	header.is-active .overlay {
		display: block;
	}

	.button-menu-sm {
		background: no-repeat center center/0.16rem auto;
		background-image: url(../img/common/sp/button_menu.png);
		height: 0.3rem;
		position: absolute;
		right: 0.09rem;
		top: 0.08rem;
		transition: background-image 0.2s ease;
		width: 0.3rem;
		z-index: 10;
	}

	.button-menu-sm.is-active {
		background-image: url(../img/common/sp/button_menu_active.png);
	}

	.header-navigation-content.navigation-fixed {
		display: none !important;
	}

	.header-navigation {
		display: none;
		height: 100%;
		left: 0;
		position: fixed;
		top: 0;
		width: 100%;
		z-index: 900;
	}

	.header-navigation .navigation-inner {
		height: 100%;
		-webkit-overflow-scrolling: touch;
		overflow-y: auto;
		width: 100%;
	}

	.navigation-list-inner {
		background: #e83633;
		padding-top: 0.43rem;
		position: relative;
		z-index: 100;
	}

	.navigation-list {
		background: #e2e2e2;
		border-top: 1px solid #fa7372;
		font-weight: bold;
		letter-spacing: 0.15em;
		line-height: 1;
	}

	.navigation-list a {
		border-bottom: 1px solid #231815;
		color: #231815;
		padding: 0.17rem 0.2rem;
		position: relative;
	}

	.navigation-list a::after {
		background: url(../img/common/sp/arrow_icon.png) no-repeat center center/100% auto;
		content: "";
		height: 0.1rem;
		margin-top: -0.05rem;
		position: absolute;
		right: 0.23rem;
		top: 50%;
		width: 0.08rem;
	}

	.navigation-list>li.has-sub {
		position: relative;
	}

	.navigation-list>li.has-sub .menu-link::after {
		display: none;
	}

	.navigation-list>li.has-sub .is-arrow {
		background: url(../img/common/sp/plus_icon.png) no-repeat left 0.23rem center/0.1rem auto;
		display: block;
		height: 0.45rem;
		position: absolute;
		right: 0;
		top: 0;
		width: 0.56rem;
	}

	.navigation-list>li.has-sub.is-active .is-arrow {
		background-image: url(../img/common/sp/minus_icon_01.png);
	}

	.navigation-sub-list {
		background: #e2e2e2;
	}

	.navigation-sub-list a {
		padding: 0.18rem 0.3rem;
	}

	.overlay {
		background: rgba(0, 0, 0, 0.5);
		height: 100%;
		left: 0;
		position: fixed;
		top: 0.45rem;
		width: 100%;
		z-index: 2;
	}
}

@media only screen and (orientation: landscape) and (max-width: 767px) {
	.header-navigation .navigation-inner {
		padding-bottom: 0.5rem;
	}
}

/* FOOTER
 * ----------------------------------------------- */
/* COMMON FOOTER
 * ----------------------------------------------- */
.footer-content {
	display: flex;
}

.copyright {
	display: block;
	font-family: "Roboto", sans-serif;
	font-weight: bold;
	letter-spacing: 0.14em;
	margin-top: 5%;
}

.footer-list {
	font-weight: 400;
}

.footer-list a {
	display: block;
}

.footer-list li {
	position: relative;
}

.footer-list li::before {
	background: #231815;
	border-radius: 50%;
	content: "";
	left: 0;
	position: absolute;
}

@media print,
(min-width: 768px) {
	footer {
		padding: 50px 0 20px 60px;
	}

	footer .wrapper {
		width: 765px;
	}

	.footer-content {
		align-items: center;
		margin-bottom: 45px;
	}

	.footer-logo {
		margin-right: 83px;
		width: 156px;
	}

	.footer-list {
		letter-spacing: 0.08em;
		line-height: 1.615;
		margin-right: 70px;
		margin-top: -3px;
	}

	.footer-list li {
		padding-left: 12px;
	}

	.footer-list li:before {
		height: 6px;
		top: 8px;
		width: 6px;
	}

	.footer-list li+li {
		margin-top: 4px;
	}

	.copyright {
		font-size: 12px;
		line-height: 1.75;
		text-align: center;
	}
}

@media only screen and (max-width: 767px) {
	footer {
		padding: 0.23rem 0 0.1rem;
		position: relative;
	}

	.footer-images {
		margin-right: 0.26rem;
	}

	.footer-logo,
	.footer-certification {
		display: block;
		width: 0.68rem;
	}

	.footer-logo {
		margin-bottom: 0.03rem;
	}

	.footer-list {
		letter-spacing: 0.06em;
		line-height: 1.22;
		margin-top: -0.01rem;
		width: calc(100% - 0.68rem);
	}

	.footer-list li {
		padding-left: 0.09rem;
	}

	.footer-list li::before {
		height: 0.05rem;
		top: 0.04rem;
		width: 0.05rem;
	}

	.footer-list a {
		margin-right: -0.1rem;
	}

	.footer-list li+li {
		margin-top: 0.1rem;
	}

	.copyright {
		bottom: 0.1rem;
		left: 0.95rem;
		letter-spacing: 0;
		line-height: 1.5;
		position: relative;
	}
}

/* PRINTING
 * ----------------------------------------------- */
@media print {
	body {
		-webkit-print-color-adjust: exact;
	}

	html,
	body {
		margin: 0;
	}

	@page {
		margin: 0;
	}

	@page :left {
		margin: 0;
	}

	@page :right {
		margin: 0;
	}

	@page :first {
		margin-top: 0;
	}
}

/* GENERAL
 * ----------------------------------------------- */
body {
	color: #231815;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.4;
	-webkit-text-size-adjust: none;
	-moz-text-size-adjust: none;
	-ms-text-size-adjust: none;
}

.font-serif {
	font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "Hiragino Mincho Pro", "Times New Roman", "游明朝", YuMincho, "メイリオ", Meiryo, Georgia, serif;
}

/* HELPERS
 * ----------------------------------------------- */
a {
	color: #231815;
	text-decoration: none;
}

.hidden {
	display: none;
}

.invisible {
	visibility: hidden;
}

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

.text-center {
	text-align: center;
}

.text-right {
	text-align: right;
}

.text-justify {
	text-align: justify;
}

.text-nowrap {
	white-space: nowrap;
}

.text-lowercase {
	text-transform: lowercase;
}

.text-uppercase {
	text-transform: uppercase;
}

.text-capitalize {
	text-transform: capitalize;
}

.container {
	overflow: hidden;
}

.is-container-position {
	position: relative;
}

/* MEDIA QUERIES
 * ----------------------------------------------- */
/* RESPONSIVE
 * ----------------------------------------------- */
@media print,
(min-width: 768px) {
	body {
		overflow-y: scroll;
	}

	.is-body .button-menu-wrapper .button-menu {
		display: none !important;
	}

	.is-padding {
		padding-left: 60px;
	}

	.container {
		min-height: 100vh;
		min-width: 1260px;
	}

	.wrapper {
		margin-left: auto;
		margin-right: auto;
		width: 980px;
		position: relative;
		z-index: 2;
	}

	.sm {
		display: none !important;
	}

	.trans {
		filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
		opacity: 1;
		-webkit-transition: opacity 0.26s ease;
		-moz-transition: opacity 0.26s ease;
		-o-transition: opacity 0.26s ease;
		transition: opacity 0.26s ease;
	}

	.trans:hover {
		filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70);
		opacity: 0.7;
	}
}

@media only screen and (max-width: 767px) {
	.md {
		display: none !important;
	}

	html {
		font-size: 31.25vw;
	}

	body {
		font-size: 0.1rem;
	}

	.container {
		min-width: 320px;
		padding-top: 0.44rem;
	}

	.container.is-container-home {
		padding-top: 0;
	}

	.wrapper {
		padding-left: 0.16rem;
		padding-right: 0.16rem;
	}
}

/* PARTS
 * ----------------------------------------------- */
.section-common-contact {
	background: no-repeat center center/cover;
}

.section-common-contact .wrapper {
	position: relative;
	z-index: 1;
}

.contact-information {
	text-align: center;
}

.information-phone {
	display: inline-block;
	font-family: "Roboto", sans-serif;
	letter-spacing: 0.06em;
	line-height: 1.2;
}

.information-phone .is-small {
	display: inline;
	line-height: 1.5;
	vertical-align: middle;
}

.contact-time time {
	font-family: "Roboto", sans-serif;
}

.information-phone {
	font-weight: bold;
}

.contact-time {
	font-weight: bold;
	letter-spacing: 0.14em;
}

.contact-time time {
	letter-spacing: 0.04em;
	vertical-align: middle;
}

.contact-time .has-arrow {
	position: relative;
}

.contact-time .has-arrow::after {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: 100% auto;
	content: "";
	position: absolute;
	right: 0;
	top: 50%;
}

@media print,
(min-width: 768px) {
	.section-common-contact {
		background-image: url(../img/common/contact_bg.jpg);
		overflow: hidden;
		padding: 114px 0 115px 60px;
		position: relative;
	}

	.section-common-contact::before {
		background: url(../img/common/triangle_img_06.png) no-repeat right top;
		content: "";
		height: 100%;
		left: 0;
		margin-right: -11px;
		pointer-events: none;
		position: absolute;
		right: calc(50% + 360px);
		top: 0;
	}

	.section-common-contact .introduction-text {
		margin-bottom: 112px;
	}

	.section-common-contact .common-title {
		margin-bottom: 22px;
	}

	.contact-list {
		align-items: center;
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		margin: 0 -28px 92px;
	}

	.contact-list li {
		margin: 0 38px;
	}

	.information-phone {
		font-size: 31px;
		letter-spacing: 0.1em;
		margin-bottom: 4px;
	}

	.information-phone .is-small {
		font-size: 24px;
		margin-right: 10px;
		position: relative;
	}
}

@media all and (min-width: 768px) and (-ms-high-contrast: none),
print and (-ms-high-contrast: active),
(min-width: 768px) and (-ms-high-contrast: active) {
	.information-phone .is-small {
		top: -1px;
	}
}

@media print,
(min-width: 768px) {
	.phone {
		display: inline-block;
		pointer-events: none;
	}

	.contact-time {
		font-size: 12px;
	}

	.contact-time time {
		font-size: 15px;
	}

	.contact-time span {
		margin-left: 8px;
	}

	.contact-time .has-arrow {
		margin-left: 0;
		margin-right: 10px;
		padding-right: 10px;
		top: 1px;
	}

	.contact-time .has-arrow::after {
		background-image: url(../img/common/arrow_solid_icon.png);
		height: 8px;
		margin-top: -3px;
		width: 6px;
	}

	.contact-custom .section-common-contact::before {
		background-image: url(../img/top/triangle_img_03.png);
		background-position: 0 0;
		height: 100%;
		left: 50%;
		margin-left: -268px;
		right: 0;
		top: 0;
	}
}

@media only screen and (max-width: 767px) {
	.section-common-contact {
		background-image: url(../img/common/sp/contact_bg.jpg);
		padding: 0.45rem 0;
	}

	.section-common-contact .introduction-text {
		line-height: 2.6;
		margin-bottom: 0.42rem;
	}

	.contact-list {
		margin-bottom: 45px;
	}

	.contact-list li {
		margin-bottom: 0.18rem;
	}

	.information-phone {
		font-size: 0.18rem;
	}

	.information-phone .is-small {
		font-size: 0.14rem;
		margin-right: 0.1rem;
	}

	.contact-time time {
		font-size: 0.11rem;
	}

	.contact-time .has-arrow {
		margin-right: 0.05rem;
		padding-right: 0.08rem;
	}

	.contact-time .has-arrow::after {
		background-image: url(../img/common/sp/arrow_solid_icon.png);
		height: 0.06rem;
		margin-top: -0.02rem;
		width: 0.05rem;
	}
}

/* COMMON TITLE
 * ----------------------------------------------- */
.common-title {
	font-family: "Roboto", sans-serif;
	font-weight: bold;
	letter-spacing: 0.16em;
	line-height: 1;
	text-align: center;
}

.introduction-text {
	letter-spacing: 0.18em;
	line-height: 2.14;
	text-align: center;
}

.section-title {
	font-weight: bold;
	text-align: center;
}

.section-title span {
	display: block;
}

.section-title .english {
	color: #e83633;
	font-family: "Roboto", sans-serif;
	letter-spacing: 0.16em;
	line-height: 1;
}

.section-title.is-show {
	opacity: 1;
}

@media print,
(min-width: 768px) {
	.common-title {
		font-size: 40px;
		margin-bottom: 36px;
	}

	.section-title {
		margin-bottom: 80px;
	}

	.section-title .english {
		font-size: 56px;
		margin-bottom: 17px;
	}

	.section-title .japan {
		color: #000;
		font-size: 18px;
		letter-spacing: 0.24em;
	}

	.section-title.is-left {
		text-align: left;
	}
}

@media only screen and (max-width: 767px) {
	.common-title {
		font-size: 0.23rem;
		margin-bottom: 0.12rem;
	}

	.section-title {
		margin-bottom: 0.3rem;
	}

	.section-title .english {
		font-size: 0.3rem;
		margin-bottom: 0.11rem;
		opacity: 0;
		transition: opacity 0.26s ease;
		transition-delay: 0.2s;
	}

	.section-title .japan {
		color: #271d1a;
		font-size: 0.1rem;
		letter-spacing: 0.26em;
	}

	.section-title.is-show .english {
		opacity: 1;
	}
}

/* MODULES
 * ----------------------------------------------- */
.button-common {
	border: 1px solid #231815;
	display: block;
	letter-spacing: 0.1em;
	position: relative;
	text-align: center;
}

.button-common::after {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: 100% auto;
	content: "";
	position: absolute;
	top: 50%;
}

.button-common.is-white {
	background-color: #fff;
}

.button-common.is-black {
	background-color: #231815;
	color: #fff;
}

.button-common.is-revise {
	background-color: none;
	color: #222;
}

@media print,
(min-width: 768px) {
	.button-common {
		font-size: 16px;
		padding: 27px 31px 29px 10px;
		width: 295px;
	}

	.is-samll {
		border: 1px solid #878280;
		padding: 0;
		width: 160px;
	}
}

@media all and (min-width: 768px) and (-ms-high-contrast: none),
print and (-ms-high-contrast: active),
(min-width: 768px) and (-ms-high-contrast: active) {
	.button-common {
		padding-top: 27px;
	}
}

@media print,
(min-width: 768px) {
	.button-common::after {
		height: 13px;
		margin-top: -6px;
		right: 30px;
		width: 11px;
	}

	.button-common.is-white:after {
		background-image: url(../img/common/arrow_icon.png);
	}

	.button-common.is-black:after {
		background-image: url(../img/common/arrow_icon_01.png);
	}
}

@media only screen and (max-width: 767px) {
	.button-common {
		font-size: 0.13rem;
		margin: 0 auto;
		padding: 0.2rem 0.2rem 0.2rem 0.1rem;
		width: 2.2rem;
	}

	.is-samll {
		border: 1px solid #878280;
		padding: 0.08rem;
		width: 1.1rem;
	}

	.button-common::after {
		height: 0.1rem;
		margin-top: -0.05rem;
		right: 0.24rem;
		width: 0.08rem;
	}

	.button-common.is-white:after {
		background-image: url(../img/common/sp/arrow_icon.png);
	}

	.button-common.is-black:after {
		background-image: url(../img/common/sp/arrow_icon_01.png);
	}
}
