@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@400;700&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Shippori+Mincho:wght@800&family=Zen+Maru+Gothic:wght@300;400;700&display=swap');

/************************************************
BASE HTML
*************************************************/
html {
	font-size: 62.5%;
	position: relative;
	min-height: 100%;
/*	scroll-behavior: smooth;*/
}
body {
	color: #333333;
	font-family:"Noto Sans JP","Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif !important;
	font-style: normal;
	font-weight: 400;
	line-height: 1.8;
	font-size: 14px;
	font-size: 1.4rem;
}
body > div { /* chrome fix */
	font-size: 14px;
	font-size: 1.4rem;
}
a:link,
a:visited {
	color: #333333;
}
a:hover,
a:active {
	color: #FF6600 !important;
	filter: alpha(opacity=70);
	opacity:0.7;
	transition: 1s;
}
a.line {
	padding-bottom: 5px;
	position: relative;

}
a.line:hover {
	text-decoration: none;
}
a.line::before {
	background: #FF6600;
	content: '';
	width: 100%;
	height: 2px;
	position: absolute;
	left: 0;
	bottom: 0;
	transform-origin: right top;
	transform: scale(0, 1);
	transition: transform .3s;
}
a.line:hover::before {
	transform-origin: left top;
	transform: scale(1, 1);
}
ul {
	padding-left: 0;
	list-style-type: none;
}
h1 {}
h2 {
	font-weight: normal !important;
}
h3 {
	font-weight: normal !important;
}
nav {
	margin-bottom: 15px;
}
::placeholder {
	color: #B0B0B0;
}
/* Override Bootstrap */
ul {
	margin-bottom: 0 !important;
}
.btn-lg {
	height: 40px;
}
a.btn-lg {
	padding-top:10px;
}
/* Noto Serif JP *//* weight M500(200-900) */
.notom_font {
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	font-style: normal;
}
/* Shippori Mincho *//* weight M500 */
.shippori_font {
	font-family: "Shippori Mincho", serif;
	font-weight: 800;
	font-style: normal;
}
/* Zen Maru Gothic *//* weight L300 R400 B700 */
.zenmaru_font_L {
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight: 300;
	font-style: normal;
}
.zenmaru_font_R {
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight: 400;
	font-style: normal;
}
.zenmaru_font_B {
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight: 700;
	font-style: normal;
}
/* Rounded Mplus 1c *//* weight R400 B700 */
.roundm_font {
	font-family: "M PLUS Rounded 1c", sans-serif;
	font-weight: 400;
	font-style: normal;
}
.roundm_font_B {
	font-family: "M PLUS Rounded 1c", sans-serif;
	font-weight: 700;
	font-style: normal;
}
[id] {
	scroll-margin-top: 100px;
}

/************************************************
BUTTON COLOR
*************************************************/
/* PRIMARY（Bootstrapデフォルトを変更して黒背景を指定） */
.btn-primary,
.btn-primary.disabled,
.btn-primary:disabled {
	color: #FFFFFF !important;
	background-color: #F7771C !important;
	border-color: #F7771C !important;
}
.btn-primary:focus,
.btn-primary.focus,
.btn-primary:not(:disabled):not(.disabled):active:focus,
.btn-primary:not(:disabled):not(.disabled).active:focus,
.show > .btn-primary.dropdown-toggle:focus {
	box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.5) !important;
}
.btn-primary:hover {
	color: #FFFFFF !important;
	background-color: #FFB75C !important;
	border-color: #FFB75C !important;
}
.btn-primary:not(:disabled):not(.disabled):active,
.btn-primary:not(:disabled):not(.disabled).active,
.show > .btn-primary.dropdown-toggle {
	color: #FFFFFF !important;
	background-color: #FFB75C !important;
	border-color: #FFB75C !important;
}
/*
.btn-primary,
.btn-primary.disabled,
.btn-primary:disabled {
	color: #FFFFFF !important;
	background-color: #343A40 !important;
	border-color: #343A40 !important;
}
.btn-primary:focus,
.btn-primary.focus,
.btn-primary:not(:disabled):not(.disabled):active:focus,
.btn-primary:not(:disabled):not(.disabled).active:focus,
.show > .btn-primary.dropdown-toggle:focus {
	box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.5) !important;
}
.btn-primary:hover {
	color: #FFFFFF !important;
	background-color: #6C757D !important;
	border-color: #6C757D !important;
}
.btn-primary:not(:disabled):not(.disabled):active,
.btn-primary:not(:disabled):not(.disabled).active,
.show > .btn-primary.dropdown-toggle {
	color: #FFFFFF !important;
	background-color: #6C757D !important;
	border-color: #6C757D !important;
}
*/
/* SECONDARY（Bootstrapデフォルトを変更して白背景黒枠線を指定） */
.btn-secondary {
	color: #343A40 !important;
	background-color: transparent !important;
	background-image: none !important;
	border-color: #343A40 !important;
}
.btn-secondary:hover,
.btn-secondary:not(:disabled):not(.disabled):active,
.btn-secondary:not(:disabled):not(.disabled).active,
.show > .btn-secondary.dropdown-toggle {
	color: #FFFFFF !important;
	background-color: #343A40 !important;
	border-color: #343A40 !important;
}
.btn-secondary:focus,
.btn-secondary.focus,
.btn-secondary:not(:disabled):not(.disabled):active:focus,
.btn-secondary:not(:disabled):not(.disabled).active:focus,
.show > .btn-secondary.dropdown-toggle:focus {
	box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.5) !important;
}
.btn-secondary.disabled,
.btn-secondary:disabled {
	color: #343A40 !important;
	background-color: transparent !important;
}
/* TERTIARY（グレー背景を指定） */
.btn-tertiary,
.btn-tertiary.disabled,
.btn-tertiary:disabled {
	color: #FFFFFF !important;
	background-color: #6C757D !important;
	border-color: #6C757D !important;
}
.btn-tertiary:focus,
.btn-tertiary.focus,
.btn-tertiary:not(:disabled):not(.disabled):active:focus,
.btn-tertiary:not(:disabled):not(.disabled).active:focus,
.show > .btn-tertiary.dropdown-toggle:focus {
	box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.5) !important;
}
.btn-tertiary:hover {
	color: #FFFFFF !important;
	background-color: #6C757D !important;
	border-color: #6C757D !important;
}
.btn-tertiary:not(:disabled):not(.disabled):active,
.btn-tertiary:not(:disabled):not(.disabled).active,
.show > .btn-tertiary.dropdown-toggle {
	color: #FFFFFF !important;
	background-color: #6C757D !important;
	border-color: #6C757D !important;
}
/************************************************
UTILITY
*************************************************/
.clear::before {
	content: "";
	display: block;
	clear: both;
}
.clear::after {
	content: "";
	display: block;
	clear: both;
}
.block_outer {
	width: 100%;
	margin-bottom: 25px;
}
.block_border {
	padding: 10px;
	border: 1px solid #CCCCCC;
	border-radius: 4px;
}
.btn_area {
	margin: 25px auto;
	text-align: center;
}
@media screen and (min-width: 768px){
	.btn_area {
		width: 50%;
	}
}
.mini {
	font-size: 1.2rem;
}
.notice,
.attention {
	color: #CC0000;
}
.info {
	margin: 15px 0;
}
.message {
	text-align: center;
	font-weight: bold;
	margin: 20px 0;
}
.title,
.price,
.point {
	font-weight: bold;
}
/************************************************
FORM
*************************************************/
input[type="text"],
input[type="password"],
input[type="tel"],
input[type="email"],
input[type="number"],
select {
	height: 45px;
	padding: 4px 8px;
	border-radius: 6px;
	border: 1px solid #EDEDED;
	background-color: #EDEDED;
}
select {
	border-color: #E5F1D5;
	background-color: #E5F1D5;
}
input[type="radio"],
input[type="checkbox"] {
	margin: 5px 5px 0;
}
textarea {
	width: 100%;
	padding: 4px;
	border-radius: 6px;
	background: 1px solid #EDEDED;
}
input[readonly]{
	background-color: #CCCCCC;
}
#form1 td {
	position: relative;
}
@media screen and (max-width: 767px){
	input[type="text"],
	input[type="password"],
	input[type="tel"],
	input[type="email"],
	input[type="number"],
	textarea {
		font-size: 1.6rem !important;
	}
}
/************************************************
TABLE
*************************************************/
table th {
	background-color: #F0F0F0;
	font-weight: normal;
	vertical-align: middle !important;
}
@media screen and (min-width: 768px){
	table.products th {
		text-align: center;
	}
}
@media screen and (max-width: 767px){
	table.sphone,
	table.sphone tbody,
	table.sphone tr,
	table.sphone th,
	table.sphone td {
		display: block;
	}
	table.sphone {
		border-bottom: 0 !important;
	}
	table.sphone th {
		border: 0 !important;
		background-color: transparent;
		padding-bottom: 0;
		font-weight: bold;
	}
	table.sphone td {
		border: 0 !important;
	}
	table.sphone tr {
		border-bottom: 1px solid #DEE2E6 !important;
	}
	table.products tr {
		border-bottom: 1px solid #DEE2E6 !important;
	}
	table.products td {
		border: 0 !important;
	}
}
/************************************************
ACCORDION
*************************************************/
@media screen and (min-width: 768px){
	.accordion {
		position: relative;
	}
	.accordion li {
		padding: 10px 0 10px;
	}
	.accordion-title {
		cursor: pointer;
		position: relative;
	}
	.accordion-title::before {
		background: #666666;
		content: "";
		height: 2px;
		position: absolute;
		right: 25px;
		top: 50%;
		transform: rotate(90deg);
		transition: transform .3s ease-in-out;
		width: 15px;
	}
	.accordion-title::after {
		background: #666666;
		content: "";
		height: 2px;
		position: absolute;
		right: 25px;
		top: 50%;
		transition: opacity .3s ease-in-out;
		width: 15px;
	}
	.accordion-title.open::before {
		transform: rotate(180deg);
	}
	.accordion-title.open::after {
		opacity: 0;
	}
	.accordion-content {
		display: none;
		margin-left: 15px;
	}
	.accordion li a {
		display: block;
		background-image: url("data:image/svg+xml,<svg viewBox='0 0 16 16' fill='currentColor' width='15' height='15' xmlns='http://www.w3.org/2000/svg'><path fill-rule='evenodd' d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708'/></svg>");
		background-repeat: no-repeat;
		background-position: right 25px bottom 50%;
	}
}
@media screen and (max-width: 767px){
	.accordion {
		position: relative;
	}
	.accordion li {
		padding: 10px 0 10px;
	}
	.accordion-title {
		cursor: pointer;
		position: relative;
	}
	.accordion-title::before {
		background: #666666;
		content: "";
		height: 2px;
		position: absolute;
		right: 25px;
		top: 50%;
		transform: rotate(90deg);
		transition: transform .3s ease-in-out;
		width: 15px;
	}
	.accordion-title::after {
		background: #666666;
		content: "";
		height: 2px;
		position: absolute;
		right: 25px;
		top: 50%;
		transition: opacity .3s ease-in-out;
		width: 15px;
	}
	.accordion-title.open::before {
		transform: rotate(180deg);
	}
	.accordion-title.open::after {
		opacity: 0;
	}
	.accordion-content {
		display: none;
		margin-left: 15px;
	}
	.accordion li a {
		display: block;
		background-image: url("data:image/svg+xml,<svg viewBox='0 0 16 16' fill='currentColor' width='15' height='15' xmlns='http://www.w3.org/2000/svg'><path fill-rule='evenodd' d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708'/></svg>");
		background-repeat: no-repeat;
		background-position: right 25px bottom 50%;
	}
}