@charset "utf-8";
/* style CSS Document */

#overlay {
	background: #000;
	position: relative;
	width: 100%;
	height: 100%;
	opacity: 0.8;
	z-index: 1;
}

* {
  font-feature-settings : "palt";
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
html,body { height: 100%; }
html {
	font-size: 62.5%; /*ベースを10pxに*/
}
body {
	font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo",serif;
	/*font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体","Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro","ＭＳ ゴシック",sans-serif;*/
	color: #141414;
	font-size: 16px;
	font-size: 1.6rem;
	font-weight: 600;
	line-height: 1.7;
	z-index: 1;
	-webkit-text-size-adjust: 100%;
}
article,aside,canvas,details,figcaption,figure,
footer,header,hgroup,menu,nav,section,summary{
	display:block;
}
a {
	color: #141414;
	text-decoration: none;
	display: block;
	width: 100%;
	height: 100%;
	outline: none;	
}
p a { 
	display: inline-block;
}
.txt-link {
	font-size: 13px;
	font-size: 1.3rem;	
	line-height: 1.2;
	display: inline-block;
}
.caption .txt-link,
.caution .txt-link,
.caption.txt-link,
.caution.txt-link {
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 1.3;	
}
.caption .txt-link,
.caution .txt-link {
	margin: 0 5px;
}
.caption .txt-link i,
.caution .txt-link i,
.caption.txt-link i,
.caution.txt-link i { font-size: 1.2em; }
.txt-link a { 
	border-bottom: 1px solid #545454;
	/*display: inline;*/
}
a:hover {
	opacity: 0.5;
	filter: alpha(opacity=50);
	-ms-filter: “alpha( opacity=50 )”;
	-webkit-transition: all 0.1s linear;
    -moz-transition: all 0.1s linear;
    -o-transition: all 0.1s linear;
    -ms-transition: all 0.1s linear;
    transition: 0.1s linear;
}
div.square-arrow:hover {
	opacity: 0.4;
	filter: alpha(opacity=40);
	-ms-filter: “alpha( opacity=40 )”;
	-webkit-transition: all 0.1s linear;
    -moz-transition: all 0.1s linear;o-transition: all 0.1s linear;
    -ms-transition: all 0.1s linear;
    transition: 0.1s linear;
}
.img_wrap a:hover {
	transition: 0.1s linear;
    -webkit-transition: all 0.1s linear;
    -moz-transition: all 0.1s linear;
    -o-transition: all 0.1s linear;
    -ms-transition: all 0.1s linear;
	opacity: 0.5;
	filter: alpha(opacity=50);
	-ms-filter: “alpha( opacity=50 );
}
.caution {
    font-size: 14px;
    font-size: 1.4rem;
    display: block;
	margin-top: 0.5rem;
}
.caution a { display: inline; }
ul {
	margin:0;
	padding: 0;
	list-style: none;
}
span { display: inline-block; }
.left { float: left; }
.right { float: right; }
.txt-center { text-align: center !important; }
.txt-left { text-align: left !important; }
.txt-right { text-align: right !important; }
.block { display: block !important; }
.none { display: none; }
.clear { clear: both; }
.clearfix {
	clear:both;
	overflow: hidden;
}
.underline { 
	text-decoration: underline;
	color: #FF8417;
	margin-right: 3px;
}
.none { font-weight: bold; }
.img_wrap img { 
	width: 100%;
	height: auto;
	vertical-align: top;
}
.txt_wrap img {
	height: 100%;
	width: auto;
}

/* 文字 */
h1 {
	font-weight: bold;
	font-size: 36px;
	font-size: 3.6rem;
	font-size: calc(3rem + ((1vw - 0px) * 0.2083));
	line-height: 1;	
}
h2 {
	font-weight: bold;
	font-size: 42px;
	font-size: 4.2rem;
	font-size: calc(3.2rem + ((1vw - 0px) * 0.3125));
	line-height: 1;
	letter-spacing: 0.5rem;
}
h3 {
	font-size: 22px;
	font-size: 2.2rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.3125));
	font-weight: bold;
}
h4 {
	font-size: 20px;
	font-size: 2rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.2083));
	font-weight: bold;
}
h5 {
	font-size: 18px;
	font-size: 1.8rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.1042));
	font-weight: bold;
}
h6 {
	font-size: 16px;
	font-size: 1.6rem;
	font-weight: bold;
}
.t-10 {
	font-size: 10px;
	font-size: 1rem;
}
.t-11 {
	font-size: 11px;
	font-size: 1.1rem;
}
.t-12 {
	font-size: 12px;
	font-size: 1.2rem;
}
.t-13 {
	font-size: 13px;
	font-size: 1.3rem;
}
.t-14 {
	font-size: 14px;
	font-size: 1.4rem;
}
.t-15 {
	font-size: 15px;
	font-size: 1.5rem;
}
.t-16 {
	font-size: 16px;
	font-size: 1.6rem;
}
.t-17 {
	font-size: 17px;
	font-size: 1.7rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.0521));
}
.t-18 {
	font-size: 18px;
	font-size: 1.8rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.1042));
}
.t-19 {
	font-size: 19px;
	font-size: 1.9rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.1563));
}
.t-20 {
	font-size: 20px;
	font-size: 2rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.2083));
}
.t-21 {
	font-size: 21px;
	font-size: 2.1rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.2604));
}
.t-22 {
	font-size: 22px;
	font-size: 2.2rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.3125));
}
.t-23 {
	font-size: 23px;
	font-size: 2.3rem;
	font-size: calc(1.7rem + ((1vw - 0px) * 0.3125));
}
.t-24 {
	font-size: 24px;
	font-size: 2.4rem;
	font-size: calc(1.8rem + ((1vw - 0px) * 0.3125));
}
.t-26 {
	font-size: 26px;
	font-size: 2.6rem;
	font-size: calc(2rem + ((1vw - 0px) * 0.3125));
}
.t-28 {
	font-size: 28px;
	font-size: 2.8rem;
	font-size: calc(2.2rem + ((1vw - 0px) * 0.3125));
}
.t-30 {
	font-size: 30px;
	font-size: 3rem;
	font-size: calc(2.4rem + ((1vw - 0px) * 0.3125));
}
.t-34 {
	font-size: 34px;
	font-size: 3.4rem;
	font-size: calc(2.8rem + ((1vw - 0px) * 0.3125));
}
.t-46 {
	font-size: 46px;
	font-size: 4.6rem;
	font-size: calc(4rem + ((1vw - 0px) * 0.3125));
}
.ver-top { vertical-align: top !important; }
.red, .error { color: #bf1919; }
.error { font-weight: bold; }
.bold { font-weight: bold; }
strong {
	font-size: 18px;
	font-size: 1.8rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.1042));
	font-weight: bold;
	line-height: 3rem;
	color: #F5C007;
}
.thanks-comment {
	font-size: 20px;
	font-size: 2rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.2083));
	color: #BF1919;
	font-weight: bold;
	text-align: center;
	margin: 6rem 0 !important;
}

/* カラム */
.btn_wrap { padding-bottom: 2px; }
.btn_wrap.col-1 {
	width: 70%;
    margin: 0 auto;
    max-width: 500px;
}
.btn_wrap.col-2 { 
	width: 80%;
	clear: both;
	overflow: hidden;
	margin: 0 auto;
}
.btn_wrap.col-2.con-full {
	width: 45.99%;
	min-width: auto;
}
.btn_wrap.col-2 > .col {
	width: calc(50% - 5px);
    float: left;
}
.col-4, .col-3, .col-2 {
	clear: both;
	overflow: hidden;
}
.btn_wrap.col-2 > .col:first-child { margin-right: 10px; }
.col-2 > .col { 
	width: calc(50% - 10px);
	float: left;
}
.col-2 > .col:nth-child(odd) { margin-right: 20px; }
.col-3 > .col { 
	width: calc(33.333% - 7px);
	float: left;
	margin-left: 10px;
}
.col-3 > .col:nth-child(3n+1) { margin-left: 0; }
.col-4 > .col {
    width: calc(25% - 15px);
    margin-left: 20px;
    float: left;
}
.col-4 > .col:nth-child(4n+1) { margin-left: 0; }
.col-5 > .col {
	width: calc(20% - 20px);
	margin-left: 20px;
	display: inline-block;
	float: left;
}
.col-5 > .col:nth-child(5n+1) { margin-left: 0; }
.col-6 > .col {
	width: calc(16.666% - 21px);
	margin-left: 25px;
	display: inline-block;
	float: left;
}
.col-6 > .col:nth-child(6n+1) { margin-left: 0; }

/* 余白 */
.mt-80 { margin-top: 8rem !important; }
.mt-70 { margin-top: 7rem !important; }
.mt-60 { margin-top: 6rem !important; }
.mt-50 { margin-top: 5rem !important; }
.mt-40 { margin-top: 4rem !important; }
.mt-30 { margin-top: 3rem !important; }
.mt-25 { margin-top: 2.5rem !important; }
.mt-20 { margin-top: 2rem !important; }
.mt-15 { margin-top: 1.5rem !important; }
.mt-10 { margin-top: 1rem !important; }
.mt-5 { margin-top: 0.5rem !important; }
.mt-0 { margin-top: 0rem !important; }
.mb-80 { margin-bottom: 8rem !important; }
.mb-70 { margin-bottom: 7rem !important; }
.mb-60 { margin-bottom: 6rem !important; }
.mb-50 { margin-bottom: 5rem !important; }
.mb-40 { margin-bottom: 4rem !important; }
.mb-30 { margin-bottom: 3rem !important; }
.mb-25 { margin-bottom: 2.5rem !important; }
.mb-20 { margin-bottom: 2rem !important; }
.mb-15 { margin-bottom: 1.5rem !important; }
.mb-10 { margin-bottom: 1rem !important; }
.mb-5 { margin-bottom: 0.5rem !important; }
.mb-0 { margin-bottom: 0 !important; }

.pt-80 { padding-top: 8rem !important; }
.pt-70 { padding-top: 7rem !important; }
.pt-60 { padding-top: 6rem !important; }
.pt-50 { padding-top: 5rem !important; }
.pt-40 { padding-top: 4rem !important; }
.pt-30 { padding-top: 3rem !important; }
.pt-20 { padding-top: 2rem !important; }
.pt-5 { padding-top: 0.5rem !important; }
.pt-10 { padding-top: 1rem !important; }
.pt-0 { padding-top: 0 !important; }
.pb-80 { padding-bottom: 8rem !important; }
.pb-70 { padding-bottom: 7rem !important; }
.pb-60 { padding-bottom: 6rem !important; }
.pb-50 { padding-bottom: 5rem !important; }
.pb-40 { padding-bottom: 4rem !important; }
.pb-30 { padding-bottom: 3rem !important; }
.pb-20 { padding-bottom: 2rem !important; }
.pb-10 { padding-bottom: 1rem !important; }
.pb-5 { padding-bottom: 0.5rem !important; }
.pb-0 { padding-bottom: 0 !important; }

/*=========================================
		parts
=========================================*/
/* インデント */
.indent {
	text-indent: -1em;
	padding-left: 1em;
}

/* 説明文 */
.caption { 
	margin: 5rem 0 4rem;
	font-size: 15px;
	font-size: 1.5rem;
}

/* シングル矢印 */
.single-arrow, .single-arrow_r{
	position: relative;
	display: inline-block;
}
.single-arrow::before{
	left: 7px;
    top: 4px;
    width: 0;
    height: 0;
    border: 4px solid transparent;
    border-left: 4px solid #fff;
	position: absolute;
    margin: auto;
    content: "";
    vertical-align: middle;
	z-index: 1;
}
.single-arrow_r::after{
	right: 0;
    top: 40%;
    width: 0;
    height: 0;
    border: 5px solid transparent;
    border-left: 7px solid #141414;
	position: absolute;
    margin: auto;
    content: "";
    vertical-align: middle;
	z-index: 1;
}

/* 二重の矢印 */
.double-arrow a {
	position: relative;
    padding: 0 0 0 14px;
    display: inline;
}
.double-arrow a::before, .double-arrow a::after {
	position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
}
.double-arrow a::before, .double-arrow a::after {
	width: 5px;
    height: 5px;
    border-top: 1px solid #000000;
    border-right: 1px solid #000000;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.double-arrow a::after { margin-left: 5px; }
.fa-angle-double-right { margin-right: 2px; }

/* インラインの矢印 */
a.double-arrow {
	position: relative;
    padding: 0 0 0 14px;
	display: inline-block;
    width: auto;
}
a.double-arrow::before, a.double-arrow::after {
	position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
}
a.double-arrow::before, a.double-arrow::after {
	width: 5px;
    height: 5px;
    border-top: 1px solid #386E82;
    border-right: 1px solid #386E82;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
a.double-arrow::after { margin-left: 5px; }

/* 四角に矢印 */
.square-arrow{
	position: relative;
	display: inline-block;
	padding: 0 0 0 21px;
	color: #000000;
	vertical-align: middle;
	text-decoration: none;
}
.square-arrow::before,
.square-arrow::after{
	position: absolute;
	top: 0;
	left: 0;
	margin: auto;
	content: "";
	vertical-align: middle;
}
.square-arrow::before{
	width: 16px;
	height: 16px;
	background: #4D0917;
}
.square-arrow::after{
	left: 4px;
	width: 4px;
	height: 4px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.square-arrow a { line-height: 1.6rem; }

/* 円に矢印 */
.circle-arrow{
	position: relative;
	display: inline-block;
	padding: 0 0 0 21px;
	color: #65C7EB;
	vertical-align: middle;
	text-decoration: none;
}
.circle-arrow::before,
.circle-arrow::after{
	position: absolute;
	top: 0;
	left: 0;
	margin: auto;
	content: "";
	vertical-align: middle;
}
.circle-arrow::before{
	width: 16px;
	height: 16px;
	background: #fff;
	border-radius: 50%;
}
.circle-arrow::after{
	left: 7px;
    width: 4px;
    height: 4px;
    top: 4px;
    width: 0;
    height: 0;
    border: 4px solid transparent;
    border-left: 4px solid #65C7EB;
}
.circle-arrow a { line-height: 1.6rem; }

/* スライドトグルの矢印 */
.slide-arrow { position: relative; }
.slide-arrow:after {
	font-family: "Font Awesome 5 Pro";
	content: "\f105";
	-webkit-font-smoothing: antialiased;
	display: inline-block;
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	line-height: 1;
	font-size: 18px;
	font-size: 1.8rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.1042));
	color: #141414;
	position: absolute;
	z-index: 2;
	top: 50%;
	right: 2rem;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	font-weight: 500;
}
.slide-arrow.slide-arrow_b:after {
	-ms-transform: rotate(90deg);
	-webkit-transform: rotate(90deg);
	transform: rotate(90deg);
}

/* 角丸 */
.round { border-radius: 50px; }
.circle { border-radius: 50%; }
.round-corner { border-radius: 5px; }
.round-corner-min { border-radius: 3px; }
.round-corner-big { border-radius: 10px; }

/* float */
.float-left {
	display: inline-block;
	float: left;
}
.float-right {
	display: inline-block;
	float: right;
}

/* テキストリンク */
.text-link { 
	display: inline-block;
	margin-left: 3px;
}
.text-link a { 
	line-height: 1;
	color: #141414 !important;	
}
.text-link a.circle-arrow::before { background: #65C7EB; }
.text-link a.circle-arrow::after { border-left: 4px solid #fff; }

/* ボーダーリンク */
a.link-under { 
	display: inline-block;
	color: #386E82 !important;
	line-height: 1.3;
}
a.link-under:hover {
	opacity: 1;
	filter: alpha(opacity=100);
	-ms-filter: “alpha( opacity=100 )”;
	border-bottom: 1px dotted #386E82;	
}

/* ボタン */
/*.btn_wrap p, .td-btn p { border-radius: 50px; }
*/.btn_wrap p a, .td-btn p a {
	font-size: 16px;
	font-size: 1.6rem;
	text-decoration: none;
	font-weight: bold;
	text-align: center;
	display: block;
	padding: 14px 0;
	/*box-shadow: 0 2px 3px 0px rgba(0,0,0,.2);
    border-radius: 50px;*/
}
td .btn:hover, td .btn-gray:hover, .td .btn-gray:hover, .td-btn p:hover, .full-form dl .btn-bl:hover, .remodal-close:hover {
	transition: 0.05s linear;
    -webkit-transition: all 0.05s linear;
    -moz-transition: all 0.05s linear;
    -o-transition: all 0.05s linear;
    -ms-transition: all 0.05s linear;
	opacity: 0.6;
	filter: alpha(opacity=60);
	-ms-filter: “alpha( opacity=60 )”
}
.btn {
	box-shadow: 0 2px 1px 0px rgba(0,0,0,.1);
	text-align: center;
	margin-bottom: 0.2rem;
}
.btn a { 
	padding: 1.2rem;
}
.btn a:hover {
	opacity: 1;
	filter: alpha(opacity=100);
	-ms-filter: “alpha( opacity=100 )”;
}
/*.btn:hover {
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: “alpha( opacity=70 )”;
	-webkit-transition: all 0.1s linear;
    -moz-transition: all 0.1s linear;
    -o-transition: all 0.1s linear;
    -ms-transition: all 0.1s linear;
    transition: 0.1s linear;
}*/
.btn-border { 
	border: 2px solid;
	box-sizing: border-box;
}
.btn-cannot {
	background: #D8D8D8;
	box-shadow: none;
}
.cannot a { cursor: default; }
p.cannot:hover, p.cannot a:hover{	
	opacity: 1;
	filter: alpha(opacity=100);
	-ms-filter: “alpha( opacity=100 )”
}
.btn-centering a { text-align: center; }
.btn-centering a div { 
	display: inline-block;
	vertical-align: middle;
}
.btn-i i {
	margin-right: 7px;
    line-height: 1.7;
}
.btn-enter { position: relative; }
.btn-enter:after {
	font-family: "Font Awesome 5 Pro";
    content: "\f105";
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    font-size: 18px;
	font-size: 1.8rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.1042));
    color: #fff;
    position: absolute;
    z-index: 2;
	top: 50%;
	right: 2rem;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
	font-weight: 500;
}
.btn-subcolor.btn-enter:after {
	color: #141414;
}
.btn-return { position: relative; }
.btn-return:after {
	font-family: "Font Awesome 5 Pro";
    content: "\f104";
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    font-size: 18px;
	font-size: 1.8rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.1042));
    color: #fff;
    position: absolute;
    z-index: 2;
	top: 50%;
	left: 2rem;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
	font-weight: 500;
}
.btn-delete a {
    font-size: 14px;
    font-size: 1.4rem;
    padding: 1rem;
    line-height: 1;
	color: #fff;
}

/* position */
.relative { position: relative; }
.absolute { position: absolute; }

/* 入力フォーム */
input, textarea {
	font-size: 16px;
	font-size: 1.6rem;
	border-radius: 0 !important; 
/*	font-family:  "fot-tsukuardgothic-std",sans-serif;
*/}
input, select { vertical-align: top; }
input[type="text"] { 
	width: 70%;
	border: 1px solid #ccc;
	padding: 8px;
}
input[type="number"] {
	border: 1px solid #ccc;
	padding: 8px
}
input[type="tel"], input[type="password"] {
	border: 1px solid #ccc;
    padding: 8px;
}
input::-webkit-input-placeholder {
	color: rgba(0,0,0,.5);
}
textarea {
	width: 100%;
	height: 200px;
	resize: vertical;
	border: 1px solid #ccc;
	font-family: "游ゴシック","YuGothic","Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro","ＭＳ ゴシック",sans-serif;
	font-weight: 500;
}
.required {
	color: #bf1919;
    display: inline-block;
    font-size: 22px;
    font-size: 2.2rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.3125));
    margin: 0 3px 0 0;
    letter-spacing: 0.1rem;
	line-height: 1;
	font-weight: 500;
}
.l-label { margin-right: 8px; }
.r-label { margin-left: 5px; }
.l-input { margin-right: 15px; }

/* エラーメッセージ */
.error-message {
	border: 1px dotted #9d0b0b;
	color: #9d0b0b;
	padding: 1.5rem;
	line-height: 1.6rem;
	width: 100%;
	margin: 0 auto 2rem;
	text-align: center;
}
.error-message > div {
	margin: 0 auto;
}
.error-message .img_wrap {
	padding-right: 10px;
	vertical-align: middle;
}
.error-message p { 
	text-align: left;
	vertical-align: middle;
}

/* ラジオボタン */
input[type="radio"] {
	display: none;
}
.design-radio label {
	position: relative;
	display: inline-block;
	padding: 1rem 3px 1rem 20px;
	cursor: pointer;
	line-height: 1.6rem;
}
.design-radio label::before {
	position: absolute;
	content: '';
	top: 50%;
	left: 0;
	width: 14px;
	height: 14px;
	margin-top: -8px;
	background: #fff;
	border: 1px solid #ccc;
	border-radius: 100%;
}
input[type="radio"]:checked + label::after {
	position: absolute;
	content: '';
	top: 50%;
	left: 5px;
	width: 6px;
	height: 6px;
	margin-top: -3px;
	background: #141414;
	border-radius: 100%;
}

/* セレクトメニュー */
.selectmenu {
	overflow:hidden;
	position: relative;
	padding: 0 !important;
	border: 1px solid #ccc;
}
.selectmenu:after {
	content: "\f107";
	display: inline-block;
	font-family: "Font Awesome 5 Pro";
	-webkit-font-smoothing: antialiased;
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	line-height: 1;
	font-size: 14px;
	font-size: 1.4rem;
	color: #404040;
	position: absolute;
	z-index: 2;
	top: 50%;
	right: 1rem;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	font-weight: 500;
}
.half-select:after {
	background: url(../img/common/arrow-pull2.png) no-repeat top right;
	background-size: contain;
	width: 20px;
	height: 36px;
}
.selectmenu select {
	width: 100%;
	-webkit-appearance: none;
	outline: none;
	cursor: pointer;
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 1.4rem;
	padding: 0.5rem 15px;	
	border: 0;
	height: 4.4rem;
	background: #fff;
}
select::-ms-expand {
	display: none;
}
select {
  -moz-appearance: none;
  text-indent: 0.01px;
  text-overflow: '';
}

/* お知らせ */
.newscate {
	padding: 0.5rem 1rem;
    display: inline-block;
    letter-spacing: 0.1rem;
    min-width: 7.65rem;
    text-align: center;
	font-size: 14px;
	font-size: 1.4rem;
	margin-left: 10px;
	line-height: 1;
}
#news dl .data {
	color: #828278;
	margin-right: 8px;
}
#news dl .ttl { margin-bottom: 0.5rem; }
#news dl{ border-bottom: 1px solid #D9D9D9; }
#news dl a {
    background: #fff;
    padding: 2rem;
	font-weight: 500;
	position: relative;
}
#news dl a:after {
	font-family: "Font Awesome 5 Pro";
    content: "\f105";
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    font-size: 20px;
    font-size: 2rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.2083));
    color: #434343;
    position: absolute;
    z-index: 1;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
	right: 20px;
}
#news dl dd { 
	margin-right: 2rem;
	margin-top: 1rem;
}
#news_wrap .txt-link {
	margin-top: 2rem;
	display: inline-block;
	float: right;
}

/* ない場合 */
#no-have {
	/*background: #EDEDE8;
    padding: 7rem 1rem;
    border-radius: 5px;*/
	text-align: center;
	font-weight: bold;
}

/* 別窓ウィンドウ */
.blank:after {
	content: "";
	display: inline-block;
	width: 15px;
	height: 15px;
	background: url(../img/common/i-window.png) no-repeat;
	background-size: contain;
	margin-left: 5px;
}

/* position */
.position-rel { position: relative; }
.position-abs { position: absolute; }
.position-sta { position: static; }
.top0 { top: 0; }
.left0 { left: 0; }
.right0 { right: 0; }
.bottom0 { bottom: 0; }

/* 商品番号 */
.code {
	display: inline-block;
	padding: 5px 6px !important;
	/*margin: 3px 0;*/
	font-size: 12px;
	font-size: 1.2rem;
	border: 1px solid #ccc;
}

/* カテゴリー */
#category ul li {
    width: calc(11.111% - 1px);
    background: #fff;
    float: left;
    margin-left: 1px;
    padding: 7px 5px 14px;
	text-align: center;
}
#category ul li:first-child { margin-left: 0; }
#category ul li.on, #category ul li:hover {
	box-shadow: 0 0 0 4px #8b1129 inset;
	position: relative;
	z-index: 0;
}
#category ul li.on:before {
	content: "";
	position: absolute;
	bottom: -8px; left: 50%;
	margin-left: -8px;
	width: 0px;
	height: 0px;
	border-style: solid;
	border-width: 8px 8px 0 8px;
	border-color: #8b1129 transparent transparent transparent;
	z-index: 0;
}
#category ul li img {
	display: inline-block;
}
#category ul li span {
	display: block;
	font-size: 14px;
	font-size: 1.4rem;
	margin-top: 6px;
	font-weight: bold;
	line-height: 1.8rem;
}
#category ul li span.spacing { letter-spacing: -0.15rem; }

/* テーブル */
table.default,
.table-default {
	width: 100%;
/*	border-top: 1px solid #ccc;
*/}
table.default th,
.table-default .thead .td {
	padding: 0.8rem 0;
	white-space: nowrap;
	text-align: center;
	font-weight: bold;	
	min-width: 80px;
	border-left: 1px solid #fff;
}
table.default td,
.table-default .td {
	vertical-align: middle;
	padding: 1.5rem !important;
/*	text-align: left;
*/	line-height: 1.5;
}
table.default th:first-of-type, table.default td:first-of-type,
.table-default .thead .td:first-of-type, .table-default .thead .td:first-of-type { border-left: none; }
/*table.default tr,
.table-default .tr { border-bottom: 1px solid #ccc; }*/
table.default thead tr { border-bottom: none; }

/* cssでtable対応 */
.table { 
	display: table;
	table-layout: fixed;
}
.table-full { width: 100%; }
.tr { display : table-row; }
.th, .td { display: table-cell; }
.th {
	white-space: nowrap;
	text-align: right;
}
.td {
	text-align: left;
	vertical-align: middle;
}
.td img { vertical-align: top; }
.ver-top { vertical-align: top; }
.ver-middle { vertical-align: middle; }
.ver-bottom { vertical-align: bottom; }

/* ページャー */
.pager_wrap { text-align: center; }
.pager {
	clear: both;
	overflow: hidden;
	display: inline-block;
}
.pager div {
	text-align: center;
    line-height: 4rem;
    width: 4rem;
    height: 4rem;
    border: 1px solid #FF8417;
	border-radius: 5px;
	float: left;
}
.pager ul { 
	display: table;
	border-radius: 5px;
	float: left;
	margin: 0 5px 0 10px;
	border: 1px solid #FF8417;	
	
}
.pager ul li {
	display: table-cell;
    list-style: none;
	line-height: 4rem;
	height: 4rem;
	border-left: 1px solid #FF8417;
}
.pager li:first-child { 
	border-left: none;
}
.pager li a {
    text-align: center;
    line-height: 4rem;
    width: 4rem;
    height: 4rem;
}
.pager li.visited a:hover {
	 opacity: 1;
	filter: alpha(opacity=100);
	-ms-filter: “alpha( opacity=100 );
	cursor: default;
}
/*.pager a:hover {
	transition: 0.05s linear;
    -webkit-transition: all 0.05s linear;
    -moz-transition: all 0.05s linear;
    -o-transition: all 0.05s linear;
    -ms-transition: all 0.05s linear;
	opacity: 1;
	filter: alpha(opacity=100);
	-ms-filter: “alpha( opacity=100 );
}*/
.pager div {
	position: relative;
	display: inline-block;
}
.pager div::before{
	content: '';
	width: 7px;
	height: 7px;
	border: 0px;
	border-top: solid 1px #402D24;
	border-right: solid 1px #402D24;
	-ms-transform: rotate(-135deg);
	-webkit-transform: rotate(-135deg);
	transform: rotate(-135deg);
	position: absolute;
	top: 50%;
	left: 50%;
	right: 0;
	margin-top: -4px;
	bottom: 0;
	margin-left: -7px;
}
.pager div.next::before {
	-ms-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

/* タブメニュー */
.tab-menu li { position: relative; }
.tab-menu li a {
    color: #141414;
	padding-bottom: 2.2rem;
	font-size: 18px;
    font-size: 1.8rem;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.1042));
	line-height: 1;
	letter-spacing: 0.1rem;
    text-decoration: none;
    text-align: center;
    display: block;
}
.tab-menu li a:hover {
	opacity: 1;
    filter: alpha(opacity=100);
    -ms-filter: “alpha( opacity=100 )”;
}
.tab-menu .selected { 
	font-weight: bold;
}
.tab-menu .selected:after {
    content: "";
    display: inline-block;
    border-bottom: 3px solid #FF5126;
    position: absolute;
    top: 0;    
    bottom: 0;    
    width: 100%;
    height: calc(100% - 10px);	
}
.tab-menu a:after {
    content: "";
    display: inline-block;
    border-bottom: 3px solid #ccc;
    position: absolute;
    top: 0;
    bottom: 0;
    width: 100%;
    height: calc(100% - 10px);
}
.tab-menu .selected:before {
	content: '';
    position: absolute;
    left: 50%;
	-webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    transform: translateX(-50%);
    bottom: 0;
    display: block;
    width: 0;
    height: 0;
    border-right: 7px solid transparent;
    border-top: 10px solid #FF5126;
    border-left: 7px solid transparent;
}
.tab-menu.col-4 > .col {
	width: calc(25% - 6px);
	margin-left: 8px;
}
.tab-menu.col-4 > .col:nth-child(4n+1) { margin-left: 0; }
/*.tab_wrap {
	background: #F9F8F8;
	padding: 1rem 8px;
	width: 100%;
}
.tab {
	display: table;
	margin: 0 auto;
	border-collapse: separate;
	table-layout: fixed;
	border-spacing: 10px 0;
	width: 100%;
}
.tab li {
	display: table-cell;
	width: 100%;
	line-height: 4.2rem;
	letter-spacing: 0.1rem;
}
.tab .active.btn-dash {
	border-color: #fff;
	background: #CCCCCC;
    -webkit-transition: all 0.1s linear;
    -moz-transition: all 0.1s linear;
    -o-transition: all 0.1s linear;
    -ms-transition: all 0.1s linear;
    transition: 0.1s linear;
}
.tab .active.btn-dash a { color: #fff; }*/

/* ポイント */
.point {
	border: 2px solid #cee3eb;    
    padding: 1rem 0 1.5rem;
    line-height: 2.6rem;
    background: #fff;
    border-radius: 5px;
}
.point h3 { 
	border-bottom: 1px solid #E4E4D4;	
	text-align: center;
	color: #65C7EC;
	margin-bottom: 2rem !important;
	padding: 0 2rem 2rem;
	margin-top: 1rem;
}
.point .caution { font-weight: 500; }
.point ol, .point ul { 
	padding: 0 4rem;
	display: inline-block;
}
.point ol li, .point ul li { 
	margin-top: 2rem;
	text-align: left;
}
.point ol li:first-of-type,
.point ul li:first-of-type { margin-top: 0; }
.point ul li { list-style: disc; }

/* colorbox */
.colorbox {
	border-top: 2px solid;
	border-bottom: 2px solid;
}
.colorbox h3 { 
    padding: 2rem 1rem 1.5rem 1rem;
    text-align: center;
    border-bottom: 1px dotted;
	font-size: 24px;
	font-size: 2.4rem;
	font-size: calc(1.8rem + ((1vw - 0px) * 0.3125));
	margin-bottom: 0 !important; 
}
.colorbox .inner { padding: 2rem 0 3rem 0; }
.colorbox .inner p { line-height: 2; }
.colorbox .inner .caution { line-height: 1.7; }
.colorbox ol li,
.colorbox ul li { margin-top: 1rem; }
.colorbox ul li:first-of-type,
.colorbox ol li:first-of-type {
    margin-top: 0;
}

/* ttl-mark */
.ttl-mark {
    border-left: 2px solid #141414;
    padding: 0 1rem;
/*	line-height: 1;
*/}

/* レビュー */
.review .star { 
	color: #F5C007;
	float: left;
    margin-right: 4px; 
}

/*=========================================
		header
=========================================*/
#headmenu li .btn {
    display: inline-block;
    float: left;
}
#headmenu li .btn:first-of-type { margin-right: 5px; }
#headmenu li:first-of-type { 
	padding: 5px;
	border-radius: 0 0 0 5px;
}
#headmenu li:last-of-type { 
	padding: 5px;
	border-radius: 0 0 5px 0;
}
.btn-cart_wrap .txt-cart {
	display: inline-block;
    width: 4em;
}
.btn-cart_wrap .img_wrap {
	width: 24px;
	float: left;
}
.btn-cart_wrap .cart-inner {
	background: #D8E6E1;
	min-width: 115px;
	padding: 0.6rem 5px;
	display: inline-block;
	text-align: right;
	border-radius: 0 0 5px 0;
}
.btn-cart_wrap:hover {
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: “alpha( opacity=70 )”;
	-webkit-transition: all 0.1s linear;
    -moz-transition: all 0.1s linear;
    -o-transition: all 0.1s linear;
    -ms-transition: all 0.1s linear;
    transition: 0.1s linear;
}

/* 注意事項 */
.note {
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 1.7;
	text-indent: -1em;
	padding-left: 1em;
}
.note li { margin-top: 1rem; }
.note li:first-of-type { margin-top: 0; }
.caution-box { border: 1px solid #fa4032; }
.caution-box.table { table-layout: auto; }
.caution-box dt {
    box-sizing: content-box;
    padding: 1rem;
    font-weight: bold;    text-align: center;
    vertical-align: middle;
}
.caution-box dd {
	padding: 2rem 1rem;
	font-weight: bold;
}
.caution-box ul li { 
	list-style: disc;
	margin-left: 2em;
	margin-top: 1rem;
}
.caution-box ul li:first-of-type { margin-top: 0; }
.caution-box li, .note li,
.caution-box li, .note li {
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 1.7;
}
/*.caution-box {
    padding: 2rem 0;
    line-height: 2.6rem;
    background: #fff;
    border-radius: 5px;
    border: 4px solid #bf4343;
	color: #BF1919;
}
.caution-box h3 { 
	color: #BF1919;
	margin-bottom: 1rem;
	border-bottom: 3px dotted #E4E4D4;
	padding: 0 2rem;
	padding-bottom: 0.5rem;
	text-align: center;
}
.caution-box .caution { font-weight: 500; }
.caution-box ol, .caution-box ul { padding: 0 4rem; }
.caution-box ol li, .caution-box ul li { margin-top: 2rem; }
.caution-box ul li { list-style: disc; }*/


/*=========================================
		gnav
=========================================*/
#gnav {
	width: 94.144%;
    min-width: 1000px;
	max-width: 1200px;
    margin: 0 auto;
    background: #fff;
    border-radius: 50px;
    padding: 8px 0 5px;
	box-shadow: 0 1px 2px 1px rgba(0,0,0,0.2);
}
#gnav ul { 
	width: 100%;
	table-layout: fixed;
}
#gnav ul.table li.td > a .i_wrap {
	background: #FFE6D0;
    border-radius: 50%;
    width: 45px;
    height: 46px;
    margin: 0 auto 5px;
}
#gnav ul li a .i_wrap img { margin: 10px auto; }
#gnav ul li.line_wrap { 
	width: 10px;
	vertical-align: middle;
}
#gnav ul li.line_wrap p { 
	font-size: 2rem;
	font-size: 20px;
	font-size: calc(1.6rem + ((1vw - 0px) * 0.2083));
}

/* 検索メニュー */
.search dl {
	border: none;
	width: 100%;
	padding: 1.2rem 0;
}
.search dl dt { 
	width: 141px;
	margin-right: 0;
	text-align: right;
	vertical-align: middle;
}
.search input[type="text"] { width: 100%; }
.search dl.price div { float: left; }
.search dl.price .selectmenu { width: calc(50% - 17px); }
.search dl.price .nyoro { display: inline-block; }
.search dl.price .nyoro p { line-height: 3.6rem; }

/* ランキング */
#rank_wrap li.col.item { position: relative; }
.item-list_wrap .item-ttl {
    margin: 1.2rem 0 0.5rem;
}
.item-list_wrap .item .price {
	margin: 0;
	text-align: right;
	display: block;
}
/*#rank_wrap li.col.item:first-child:after {
	content: "";
    background: url(../common/img/rank1.png) no-repeat;
    display: inline-block;
    width: 80px;
    height: 76px;
    position: absolute;
    top: 0;
    left: 0;
}
#rank_wrap li.col.item:nth-child(2):after {
    content: "";
	background: url(../common/img/rank2.png) no-repeat;
    display: inline-block;
    width: 80px;
    height: 76px;
    position: absolute;
    top: 0;
    left: 0;
}
#rank_wrap li.col.item:nth-child(3):after {
	content: "";
    background: url(../common/img/rank3.png) no-repeat;
    display: inline-block;
    width: 80px;
    height: 76px;
    position: absolute;
    top: 0;
    left: 0;
}
*/

/*=========================================
		maincontent
=========================================*/
#thanks .caption { margin: 3rem 0 4rem; }

/* パンくずリスト */
#pan_wrap {
	background: #D8033A;
}
#pan li {
    float: left;
    display: inline-block;
/*	padding-left: 2rem;
*/}
#pan li:first-child {
	padding-left: 0;
}
/*#pan li a {
	display: block;
	float: left;
	position: relative;
	text-decoration: none;
	color: #fff;
    padding: 0.8rem 0 0.8rem 1rem;
}*/
/*#pan li.visited:hover a:after { 
	border-left: 20px solid #B9CCD3;
}*/
#pan li a span {
	margin-right: 0.8rem;
    vertical-align: bottom;
    float: left;
	width: 13px; 
}
#pan li a span img { vertical-align: middle; }
#pan li a p { float: left; }
/*#pan li a:hover {
	opacity: 1;
    filter: alpha(opacity=100);
    -ms-filter: “alpha( opacity=100 );
}
*/

/* ページタイトル */
#page-ttl_wrap { position: relative; }
#page-ttl_wrap #inner { background: #FFFAEE; }
#page-ttl {	
    width: 45.755%;
    max-width: 825px;
    margin: 0 auto;
	display: table;
}
#page-ttl p {	
	background: #fff;
   padding: 5.2rem 0 2rem;
    margin: 0 auto;
	text-align: center;
	display: table-cell;
}
#page-ttl p img { height: 8.1rem; }
#page-ttl:before {
	content: "";
    background: url(../img/common/ttl-l.png) no-repeat;
    width: 31px;
    height: 15.9rem;
	display: table-cell;
	background-size: contain;
}
#page-ttl:after {
	content: "";
    background: url(../img/common/ttl-r.png) no-repeat;
    width: 31px;
    height: 15.9rem;
	display: table-cell;
	background-size: contain;
}

/* 合計価格表示 */
.total .price_wrap .ttl {
    display: inline-block;
    white-space: nowrap;
    text-align: right;
    float: left;
    width: 90px;
}

/* ステップ */
.step { 
	text-align: center;
	margin-top: 6rem !important;
}
.cd-multi-steps { display: inline-block }
.cd-multi-steps::after {
  clear: both;
  content: "";
  display: table;
}
.cd-multi-steps li {
  display: inline-block;
}
.cd-multi-steps li:last-of-type::after {
  display: none;
}
.cd-multi-steps li > * {
  display: inline-block;
  color: #141414;
}
.cd-multi-steps li a { width: auto; }
.cd-multi-steps li.current > * {
  color: #24708a;
}
/*.cd-multi-steps li.visited > * { color: #24708a; }*/
.no-touch .cd-multi-steps a:hover {
  color: #24708a;
}
.cd-multi-steps.custom-separator li::after {
  content: '';
  height: 16px;
  width: 16px;
  background: url(../img/cd-custom-separator.svg) no-repeat center center;
  vertical-align: middle;
}
.cd-multi-steps.custom-icons li > *::before {
  content: '';
  display: inline-block;
  height: 20px;
  width: 20px;
  margin-right: .4em;
  margin-top: -2px;
  background: url(../img/cd-custom-icons-01.svg) no-repeat 0 0;
  vertical-align: middle;
}
.cd-multi-steps.custom-icons li:not(.current):nth-of-type(2) > *::before {
  background-position: -20px 0;
}
.cd-multi-steps.custom-icons li:not(.current):nth-of-type(3) > *::before {
  background-position: -40px 0;
}
.cd-multi-steps.custom-icons li:not(.current):nth-of-type(4) > *::before {
  background-position: -60px 0;
}
.cd-multi-steps.custom-icons li.current:first-of-type > *::before {
  background-position: 0 -20px;
}
.cd-multi-steps.custom-icons li.current:nth-of-type(2) > *::before {
  background-position: -20px -20px;
}
.cd-multi-steps.custom-icons li.current:nth-of-type(3) > *::before {
  background-position: -40px -20px;
}
.cd-multi-steps.custom-icons li.current:nth-of-type(4) > *::before {
  background-position: -60px -20px;
}
.cd-multi-steps li::after {
    display: inline-block;
    content: '\00bb';
}
@media only screen and (min-width: 768px) {
  .cd-multi-steps {
    padding: 0 1.2em;
  }
  .cd-multi-steps li > * {
	font-size: 15px;
	font-size: 1.5rem;
  }  
}
@media only screen and (min-width: 768px) {
.cd-multi-steps.text-top li.current > *::before,
.cd-multi-steps.text-bottom li.current > *::before {
	background: #24708a;
	width: 12px;
    height: 12px;
    border-radius: 50%;
	background-size: contain;
}
.cd-multi-steps li::after {
	position: absolute;
    content: '';
    height: 2px;
    background: #FF5126;
    margin: 0;
  }
.cd-multi-steps li > *, .cd-multi-steps li.current > * {
    position: relative;
    color: #141414;
  }
.cd-multi-steps.text-top li > *::before, .cd-multi-steps.text-bottom li > *::before {
    content: '';
    position: absolute;
    z-index: 1;
    left: 50%;
    right: auto;
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    transform: translateX(-50%);
    background: #ccc;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background-size: contain;
  }
	.cd-multi-steps.text-top li::after, .cd-multi-steps.text-bottom li::after {
		position: absolute;
	}  
	.cd-multi-steps.text-top li.visited > *::before,
	.cd-multi-steps.text-bottom li.visited > *::before {
		background: #FF5126;
		width: 12px;
		height: 12px;
	}
  .cd-multi-steps {
    background-color: transparent;
    padding: 0;
    text-align: center;
  }

  .cd-multi-steps li {
    position: relative;
    float: left;
  }
  .cd-multi-steps li:last-of-type {
    padding-right: 0;
	margin-right: 0;
  }  
  

  .cd-multi-steps.custom-separator li::after {
    height: 4px;
    background: #edeff0;
  }

  .cd-multi-steps.text-center li::after {
    width: 100%;
    top: 50%;
    left: 100%;
    -webkit-transform: translateY(-50%) translateX(-1px);
    -moz-transform: translateY(-50%) translateX(-1px);

    -ms-transform: translateY(-50%) translateX(-1px);
    -o-transform: translateY(-50%) translateX(-1px);
    transform: translateY(-50%) translateX(-1px);
  }
  .cd-multi-steps.text-center li > * {
    z-index: 1;
    padding: .6em 1em;
    border-radius: .25em;
    background-color: #edeff0;
  }
  .no-touch .cd-multi-steps.text-center a:hover {
    background-color: #051f33;
  }
  .cd-multi-steps.text-center li.current > *, .cd-multi-steps.text-center li.visited > * {
    color: #ffffff;
    background-color: #96c03d;
  }
  .cd-multi-steps.text-center.custom-icons li.visited a::before {
    background-position: 0 -60px;
  }

  .cd-multi-steps.text-top li, .cd-multi-steps.text-bottom li {
    width: 80px;
    text-align: center;
  }
  .no-touch .cd-multi-steps.text-top a:hover, .no-touch .cd-multi-steps.text-bottom a:hover {
    color: #96c03d;
  }
  .no-touch .cd-multi-steps.text-top a:hover::before, .no-touch .cd-multi-steps.text-bottom a:hover::before {
    box-shadow: 0 0 0 3px rgba(150, 192, 61, 0.3);
  }

  .cd-multi-steps.text-top li::after {
    bottom: 4px;
  }
  .cd-multi-steps.text-top li > * {
    padding-bottom: 20px;
  }
  .cd-multi-steps.text-top li > *::before {
    bottom: 0;
  }
  .cd-multi-steps.text-bottom li > *::before {
    top: 0;
  }
}

.cd-multi-steps.count li { width: 140px; }

@media only screen and (min-width: 768px) {
  .cd-multi-steps.text-top.count li > *::before,
  .cd-multi-steps.text-bottom.count li > *::before {
	  color: #fff;
	}
.cd-multi-steps.text-bottom.count li > * {
    padding-top: 2.2rem;
  }	
.cd-multi-steps.text-top li::after, .cd-multi-steps.text-bottom li::after {
	position: absolute;
    left: 50%;
    width: calc(100% - 12px);
    top: 4px;
    margin-left: 6px;
}
.cd-multi-steps a:hover:before {
    box-shadow: 0 0 0 3px rgba(36, 112, 138, 0.4);
    transition: 0.05s linear;
    -webkit-transition: all 0.05s linear;
    -moz-transition: all 0.05s linear;
    -o-transition: all 0.05s linear;
    -ms-transition: all 0.05s linear;
}
  .cd-multi-steps li.visited em::before {
	  color: #fff !important;
  }  
  .cd-multi-steps.text-top.count li::after {
    bottom: 11px;
  }

  .cd-multi-steps.text-top.count li > * {
    padding-bottom: 34px;
  }
    
}
@media screen and (max-width: 999px) {
	.cd-multi-steps li { line-height: 2rem; }
}
.cd-multi-steps a:hover {
	opacity: 0.5;
	filter: alpha(opacity=50);
	-ms-filter: “alpha( opacity=50 )”;
	-webkit-transition: all 0.05s linear;
    -moz-transition: all 0.05s linear;
    -o-transition: all 0.05s linear;
    -ms-transition: all 0.05s linear;
    transition: 0.05s linear;
}

/*=========================================
		footer
=========================================*/
footer #animation_container {
    padding-bottom: 77.2rem !important;
    height: 0 !important;
}
footer canvas {
	position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
}
footer .circle-arrow::before { background: #384D32; }
.fbg-none footer { background: none; }
footer section div > ul li ul.td { padding-left: 0.5em; }
footer section div > ul li ul.td li { 
	padding-bottom: 2.5rem;
	display: block;
}
footer section div > ul li ul.td li:first-child { padding-top: 1rem; }
footer section div > ul li ul.td li a {
	color: #fff;
	line-height: 2rem;
	display: inline;
}
footer section div > ul li ul.td li a:hover {
	transition: 0.05s linear;
    -webkit-transition: all 0.05s linear;
    -moz-transition: all 0.05s linear;
    -o-transition: all 0.05s linear;
    -ms-transition: all 0.05s linear;
	opacity: 0.5;
	filter: alpha(opacity=50);
	-ms-filter: “alpha( opacity=50 )”
}
#about-city .address_wrap dl { display: table }
#about-city .address_wrap dl dt { 
	display: table-cell;
	white-space: nowrap;
}	
#animation_container {
	background: url(../img/common/bg-footer.png) no-repeat top center;
	position: relative;
	width: 100% !important;
	padding-bottom: 89.2rem !important;
    height: 0 !important;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    transform: translateX(-50%);
}
#dom_overlay_container {
	background: url(../img/common/bg-footer2.png) no-repeat top center;
	background-size: cover;
	position: absolute;
	top: 0;
	width: 100% !important;
    height: 0 !important;
    padding-bottom: 89.2rem !important;
	left: 0;
}
.couple {
	position: absolute;
	top: 27%;
	right: 43.8%;
	width: 28px;
}

/* ページトップへ */
footer #to_top {
	position: fixed;
	bottom: 4rem;
    right: 40px;
	z-index: 9999;
}

/* 市町情報 */
#about-city {
    background: #fff;
    margin-top: 4rem;
    margin-bottom: 3px;
    width: 22.756%;
    border-radius: 10px;
	padding: 0;
}
#about-city .img_wrap {
	    padding: 2rem 1.5rem 1.5rem;
    border-bottom: 1px solid #80A374;
    text-align: center;
}
#about-city .img_wrap img {
	display: inline-block;
    max-width: 200px;
	height: auto;
}
#about-city .logo_wrap {
	vertical-align: middle;
    border-right: 1px solid #d9d9d9;
    padding: 0 20px 0 10px;
}
#about-city .address_wrap { padding: 1.5rem 1.5rem 2rem; }
#about-city .address_wrap dl {
	font-size: 13px;
	font-size: 1.3rem;
	line-height: 2.5rem;
}
#about-city .address_wrap dl.table dt { 
	width: 39px;
}

/* フッターメニュー */
footer section .fm-list_wrap > ul li { padding-top: 1.5rem; }
footer section .fm-list_wrap .fm-items > ul > li { padding-top: 0;}
footer section ul.table > li { 
	padding-top: 0;
	vertical-align: top;
}
/*footer section ul li > div:first-of-type {
	border-bottom: 2px dotted #fff;	
	padding-bottom: 0.5rem;
	padding-left: 10px;
}
footer section ul li > div:first-of-type img {
	height: 18px;
	width: auto;
}*/
footer section ul li .table { width: 100%; }
footer section ul li .table .td {
	width: 50%; 
	display: table-cell;
}
footer section #footermenu li {
	border-radius: 5px;
    width: 10.6rem;
    height: 6.6rem;
    float: left;
    margin-left: 5px;
	padding: 0;
    box-shadow: 0 1px 2px 1px rgba(0,0,0,0.2);
	text-align: center;
}
footer section #footermenu li.bg {
	background: #FFE6D0;
    border: 2px solid #FFE6D0;
}
footer section #footermenu li:first-of-type { margin-left: 0; }
footer section #footermenu li.border {
	    background: #fff;
    border: 2px solid #FFE6D0;
}
footer section #footermenu li .i_wrap { margin: 1.3rem 0 0.5rem; }
footer section #footermenu .txt_wrap { 
    height: 12px;
    width: auto;
	margin-top: 3px;
}
footer section #footermenu li.cart_wrap {
	width: 233px;    
}
footer section #footermenu li.cart_wrap a { padding: 0 19%; }
footer section #footermenu li.cart_wrap div {
	    height: 100%;
    vertical-align: middle;
}
footer section #footermenu li.cart_wrap div .i_wrap {
	height: 22px;
    padding-right: 10px;
    vertical-align: middle;
	width: auto;
}
footer section #footermenu li .i_wrap { margin: 1rem 0 0; }
footer section #footermenu li .i_wrap img { width: 23px; }
footer section #footermenu li.cart_wrap div .i_wrap img{
	    height: 100%;
    width: auto;
    vertical-align: middle;
}
footer section #footermenu li.cart_wrap p.txt_wrap { vertical-align: middle; }
footer .arrow-circle:after { top: 2px; }
footer dd span { padding: 0; }

/*=========================================
		cssハック
=========================================*/
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
	body.is-fixed #gnav_wrap #gnav li a { padding: 2.5rem 0; }
} /* IE10 */

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
	.pan li { padding-top: 5px; }
	.pan li span { bottom: 3px; }
	#goods_cnt_pc { padding-top: 3px; }
	.fixed#top-head .logo { height: 74px !important; }
	.t-22 { line-height: 2.4rem; }	
}

/* Firefoxハック */
@-moz-document url-prefix() {
	/* サイドメニュー */
	#side-right {
		background:url(../img/common/balloon.png), linear-gradient(top center, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 7.4%, rgba(255,255,255,1) 7.4%);
		padding-top: 237px;
		background-repeat: no-repeat;
	}

	/* ページタイトル */
	#page-ttl::before, #page-ttl::after, #page-ttl p { height: auto; }
}

@media screen and (min-width: 1540px) {
	/*=========================================
			gnav
	=========================================*/
	/* gnav追従設定 */
	body.is-fixed #gnav_wrap #gnav {
		width: calc(100% - 377px);
	}
	body.is-fixed #gnav_wrap .logo {
		width: 54px;
		margin: 0.3rem 10px 0.3rem 0;
	}
	body.is-fixed #gnav_wrap #gnav li:first-child { width: 26%; }
	body.is-fixed #gnav_wrap #gnav li:nth-child(2) { width: 35%; }
	body.is-fixed #gnav_wrap #gnav li:nth-child(3) { width: 17%; }
	body.is-fixed #gnav_wrap #gnav li:last-child { width: 22%; }
	body.is-fixed #gnav_wrap .head-menu { margin-left: 10px; }
}

@media screen and (max-width: 1539px) and (min-width: 1000px) {
	/*=========================================
			gnav
	=========================================*/
	/* gnav追従設定 */
	body.is-fixed #gnav_wrap .logo {
		width: 40px;
		margin: 1.1rem 10px 1.1rem 0;
	}
	body.is-fixed #gnav_wrap #gnav {
		width: calc(100% - 353px);
	}
	body.is-fixed #gnav_wrap #gnav li:first-child { width: 25%; }
	body.is-fixed #gnav_wrap #gnav li:nth-child(2) { width: 32%; }
	body.is-fixed #gnav_wrap #gnav li:nth-child(3) { width: 16%; }
	body.is-fixed #gnav_wrap #gnav li:last-child { width: 27%; }
}

@media screen and (max-width: 1024px) and (min-width: 1000px){
	footer section #footermenu li { width: 7.6rem; }
}

@media screen and (min-width: 1000px) {
	.padsp { display: none !important; }
	.pad { display: none !important; }
	
	.limit-width {
		width: 94.144%;
		min-width: 1000px;
		max-width: 1366px;
		margin: 0 auto;
	}
	
	/*=========================================
			header
	=========================================*/
	/* header */
	header ul li a img { margin-right: 0; }
	#headmenu .txt_wrap {
		height: 12px;
		width: auto;
	}	
	header #roof #headmenu_wrap {
		width: 94.144%;
		min-width: 1000px;
	} 
	header #roof #headmenu_wrap #headmenu {
		position: absolute;
		right: 0;
		top: 0;
	}
		
	/*=========================================
			gnav
	=========================================*/
	#gnav .img_wrap img {
		height: 29px;
		width: auto;
	}
	#gnav .txt_wrap img {
		height: 14px;
		width: auto;
	}
	/*#search_wrap, .sp-gmenu {
		display: none;
		opacity: 0;
	}*/
	
	
	/*=========================================
			parts
	=========================================*/
	/* パンくず */
/*	#pan li a:before {
		content: "";
		border-top: 20px solid transparent;
		border-bottom: 20px solid transparent;
		border-left: 20px solid #fff;
		position: absolute;
		right: -22px;
		top: 0;
	}
*/	/*#pan li a:after {
		content: "";
		border-top: 20px solid transparent;
		border-bottom: 20px solid transparent;
		border-left: 20px solid #A5022C;
		position: absolute;
		right: -20px;
		top: 0;
		z-index: 1;
	}*/
	
	/* #side-right */
	#side-right .feature-bnr-area li {
		width: 168px;
		border-bottom: 1px solid #fff;
	}
	side-right .feature-bnr-area li img {
		width: 100%;
		height: auto;
	}
	
	/* タブメニュー */
	.tab-menu { margin-bottom: 1.5rem; }
	
	/*=========================================
			maincontent
	=========================================*/
	#maincontent_wrap {
		width: 94.144%;
		min-width: 1000px;
		max-width: 1366px;
		margin: 0 auto;
	}
	/*#maincontent {
		width: calc(100% - 200px);
		margin-left: 40px;
	}*/
	#maincontent.no-side { 
		width: 100%;
		padding: 0;
	}
	.main-2col #maincontent {
		width: calc(100% - 167px);
		padding: 0 0 0 20px;
	}	

	/*=========================================
			footer
	=========================================*/	
	.square-arrow::before, .square-arrow::after { bottom: 0; }
	footer section div > ul li div.td {
		border-right: 1px solid #fff;
		padding: 1rem 0.8rem 1rem 0;
		width: 18px;
	}
	/*footer section div > ul {
		width: 50%;
		float: left;
	}	*/	
	footer section ul li .table .td { margin-bottom: 2rem; }
	footer section .fm-list_wrap > ul > li:first-of-type { width: 40%; }
	
	/* copyright */
	footer section #footermenu { width: 40%; }
}

@media screen and (max-width: 999px) {		
	.pc { display: none !important; }
	
	/* 文字 */
	html{
		font-size: 58.5% !important;
	}
	body{
		font-size: 14px;
		font-size: 1.4rem;
		line-height: 1.7;
	}
	
	/* 余白 */
	.mt-80 { margin-top: 5.6rem !important; }
	.mt-70 { margin-top: 4.9rem !important; }
	.mt-60 { margin-top: 4.2rem !important; }
	.mt-50 { margin-top: 3.5rem !important; }
	.mt-40 { margin-top: 2.8rem !important; }
	.mt-30 { margin-top: 2.1rem !important; }
	.mt-20 { margin-top: 1.4rem !important; }
	.mt-5 { margin-top: 0.35rem !important; }
	.mb-80 { margin-bottom: 5.6rem !important; }
	.mb-70 { margin-bottom: 4.9rem !important; }
	.mb-60 { margin-bottom: 4.2rem !important; }
	.mb-50 { margin-bottom: 3.5rem !important; }
	.mb-40 { margin-bottom: 2.8rem !important; }
	.mb-30 { margin-bottom: 2.1rem !important; }
	.mb-20 { margin-bottom: 1.4rem !important; }
	.mb-10 { margin-bottom: 0.7rem !important; }
	.mb-5 { margin-bottom: 0.35rem !important; }
	
	.pt-80 { padding-top: 5.6rem !important; }
	.pt-70 { padding-top: 4.9rem !important; }
	.pt-60 { padding-top: 4.2rem !important; }
	.pt-50 { padding-top: 3.5rem !important; }
	.pt-40 { padding-top: 2.8rem !important; }
	.pt-30 { padding-top: 2.1rem !important; }
	.pt-20 { padding-top: 1.4rem !important; }
	.pt-10 { padding-top: 0.7rem !important; }
	.pt-5 { padding-top: 0.35rem !important; }
	.pb-80 { padding-bottom: 5.6rem !important; }
	.pb-70 { padding-bottom: 4.9rem !important; }
	.pb-60 { padding-bottom: 4.2rem !important; }
	.pb-50 { padding-bottom: 3.5rem !important; }
	.pb-40 { padding-bottom: 2.8rem !important; }
	.pb-30 { padding-bottom: 2.1rem !important; }
	.pb-20 { padding-bottom: 1.4rem !important; }
	.pb-10 { padding-bottom: 0.7rem !important; }
	.pb-5 { padding-bottom: 0.35rem !important; }
	
	/* スマホの時のみ余白 */
	.smt-40 { margin-top: 40px !important; }
	.smt-0 { margin-top: 0 !important; }
	.smb-0 { margin-bottom: 0 !important; }
	.spb-0 { padding-bottom: 0 !important; }
	
	/* カラム */	
	.col-2 > .col:nth-of-type(odd) { margin-right: 10px !important; }
	.btn_wrap.col-2 .col:nth-of-type(even) { margin-left: 0 !important; }
	.col-2 > .col { width: calc(50% - 5px) !important; }
	.col-3 > .col {
		width: calc(33.333% - 7px);
		margin-left: 10px;
	}		
	
	/*=========================================
			parts
	=========================================*/
	.caption { margin: 4rem 0 3rem; }
	
	/* ボタン */
	.btn_wrap p a { padding: 15px 11px; }
	.btn_wrap p a {
		font-size: 16px;
		font-size: 1.6rem;
	}
	.btn_wrap.col-2, .btn_wrap.col-2.con-full { width: 100%; }		
	.btn-enter:after { right: 1rem; }
	.btn-return:after { left: 1rem; }
 	
	/* 生年月日 */
	#birth ul li { 
		margin-bottom: 0.8rem;
		width: auto;
	}
	
	/* シングル矢印 */
	.single-arrow { padding: 0 0 0 11px; }
	.single-arrow::before { bottom: 8px; }
	.single-arrow.slide-arrow_b:before { left: 0; }
	
	/* 四角に矢印 */
	.square-arrow::after { top: 5px; }
	
	/* シェアボタン */
	#share { 
		padding-top: 0;
		margin: 8rem auto 2rem;
	}
		
	/* ページ内メニュー */
	.page-menu ul li:nth-child(even) { margin-left: 20px; }
	.page-menu ul li:nth-child(even) { margin-left: 0; }
	.page-menu ul li a { border-top: none !important; }
	.page-menu ul li:first-child a { border-top: 3px solid #FCF6E8 !important; }
		
	/* テーブル */	
	table.default td { padding: 1.5rem 1rem !important; }
	
	/* ステップ */
	.inner nav {
		margin-top: 2rem;
		margin-bottom: 2rem;		
	}
	
	/* 入力フォーム */
	input.big-input { width: 100%; }
	input.min-input { width: 6em; }
	
	/* お知らせ */
	span.type-news, span.type-event, span.type-important, span.area {
		height: 24px;
		line-height: 2.4rem;
	}
	
	/* colorbox */
	.colorbox p { 
		text-align: left !important;
		display: inline-block;
	}
	.colorbox p.btn { width: 100%; }
	
	/* ポイント */
	.point ol, .point ul { padding: 0 3rem; }
	
	/* 注意事項 */
	/*.caution-box ol, .caution-box ul { padding: 0 3rem; }*/
	/*.caution-box ol li, .caution-box ul li { margin-top: 1rem; }*/
	
	/* bottom-menu */
/*	#bottom-menu li:first-of-type { margin-top: 0; }
*/	#bottom-menu ul li a {
		position: relative;
	}
	#bottom-menu li span {
		width: 20px;
	}
	#bottom-menu li .td {
		display: table-cell;
	}
	#bottom-menu li p.td {
		padding-left: 5px;
		vertical-align: middle;
	}
	#bottom-menu li .td img { vertical-align: middle; }
	#maincontent #bottom-menu h1 {
		background: #C70235;
		color: #fff;
		padding: 0.8rem 1.5rem 0.5rem;
		line-height: 2rem;
		font-size: 20px;
		font-size: 2rem;
		font-size: calc(1.6rem + ((1vw - 0px) * 0.2083));
		width: 100%;
		margin-bottom: 0;
		height: auto;
	}
	#maincontent #bottom-menu h1 img { height: 2.4rem; }
	#bottom-menu h1.txt_wrap { height: 2.4rem; }
	
	/* thanks-comment */
	.thanks-comment { margin: 4rem 0 !important; }
	
	/* cssのtable */
	.table-responsive-block_pad,
	.table-responsive-block_pad > .td { display: block; }
		
	/*=========================================
			header
	=========================================*/
	header #roof { background-size: cover; }
	header #search-menu {
		display: inline-block;
		float: left;
	}
	header #search-menu .border {
		background: #fff;
		border: 2px solid #FFE6D0;
		border-radius: 5px;
		width: 5rem;
		height: 5rem;
		float: left;
		box-shadow: 0 1px 2px 1px rgba(0,0,0,0.2);
		margin-right: 0;
		text-align: center;
	}
	header #search-menu .border .i_wrap {
		padding: 1.1rem 0;
		width: 24px;
	}
	header #search-menu .border .i_wrap img {
		vertical-align: middle;
		float: none;
	}
	header #roof #headmenu_wrap {
		clear: both;
		overflow: hidden;
		margin: 0 10px;
		padding-bottom: 1.1rem;
	}
	header #roof #headmenu_wrap #headmenu > li {
		width: 5rem;
		height: 5rem;
	}
	header .head-menu {
		width: 100%;		
		height: 5rem;
		border-top: 1px solid #fff;
	}
	header .head-menu li {
		display: table-cell;
		line-height: initial;
		vertical-align: middle;
		text-align: center;
		width: 50%;
	}
	.b08_3d_pushback div:nth-child(1) { 
		background: #402D24;
		color: #fff;
	}
	header #roof #headmenu_wrap #headmenu > li { margin-left: 10px; }
	
	/* ハンバーガーメニュー */
	nav.sp{ 
		border-bottom: 1px solid #fff;
		position: fixed;
		top: 0;
		z-index: 9997;
	}
	nav .logo {
		display: inline-block;
		margin: 5px 10px;
		height: 5rem;
	}
	nav .logo a {
		display: block;
		width: auto;
		height: 100%;
	}
	nav .logo a img {
		width: auto;
		height: 100%;
	}
	.menu-trigger,
	.menu-trigger span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
	}
	.menu-trigger {
		position: relative;
	}
	.menu-trigger span {
		position: absolute;
		width: 60%;
		height: 3px;
		background-color: #FF8133 ;
	}
	.menu-trigger span:nth-of-type(1) {
		top: 12px;
		left: 10px;
	}
	.menu-trigger span:nth-of-type(2) {
		top: 21px;
		left: 10px;
	}
	.menu-trigger span:nth-of-type(3) {
		bottom: 12px;
		left: 10px;
	}
	#top .header_after { padding-top: 9rem; }
	
	/*=========================================
			gnav
	=========================================*/
	.overlay {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: #000;
		z-index: 999;
	}
	.fixed {
	  width: 100%;
	  height: 100%;
	}
	/*.sp-gmenu, #search_wrap {
	  overflow-y: scroll;
	  -webkit-overflow-scrolling:touch;
		position: fixed;
		top: 0;
		left: 0;
		z-index: 1;
		width: 100%;
		height: 100%;
		opacity: 0;
		display: none;
		transition: opacity .3s;
	}*/
	.open {
		opacity: 1 !important;
		display: block !important;
	}
	#gnav {
		width: 100%;
		height: 100%;
		margin: 0 auto;
		top: 50%;
		left: 50%;
		transform: translate(-50%,-50%);
		-webkit-transform: translate(-50%,-50%);
		position: fixed;
		z-index: 100000;
		font-size: 16px;
		font-size: 1.6rem;
		font-weight: bold;
		min-width: inherit;
		border-radius: 0;
		overflow-y: scroll;
		padding: 0;
	}
	#gnav ul {
		margin: 0 auto;
	}
	#gnav ul li {
		display: table;
		margin: 0 auto;
	}
	#gnav ul li.line_wrap { display: none; }
	#gnav ul li a .i_wrap {
		display: table-cell;
		padding: 7px;
	}
	#gnav ul.category-menu { background: #FFFAF7; }
	#gnav ul.category-menu li { 
		width: 100%;
		border-bottom: 1px dotted #C9C0B9;		
		padding: 0 20px;
	}
	#gnav ul.category-menu li:first-of-type { border-top: 1px solid #C9C0B9; }
	#gnav ul.category-menu li a { 
		margin: 0;
		padding: 1.2rem 0;
	}
	#gnav ul.category-menu li a .i_wrap {
		width: 24px;
		padding: 0;
		float: left;
	}
	#gnav ul.category-menu li p { 
		display: inline-block;
		float: left;
		margin-left: 7px;
	}
	#gnav ul li a .txt_wrap {
		display:table-cell;
		padding-left: 10px;
		height: auto;
		vertical-align: middle;
	}
	#gnav ul li a .txt_wrap img { height: 1.7rem; }
	#gnav #loginmenu { 
		width: 85%;
		border-spacing: 10px;
		margin-top: 3.5rem;
		margin-bottom: 1rem;
	}
	#gnav #loginmenu li.bg {
		background: #FFE6D0;
    	border: 2px solid #FFE6D0;
	}
	#gnav #loginmenu li {
		border-radius: 5px;
		width: calc(50% - 5px);
		box-shadow: 0 1px 2px 1px rgba(0,0,0,0.2);
		display: table-cell;
	}
	#gnav #loginmenu li.border {
		    background: #fff;
		border: 2px solid #FFE6D0;
	}

	#gnav #loginmenu li a { 
		padding: 0;
		margin: 0;
	}
	#gnav #loginmenu li a  .i_wrap {
		width:auto;
		height:auto;
	}
	#gnav #loginmenu li a  .i_wrap img {
		margin: 0;
	}
	#gnav #loginmenu li a .txt_wrap {
		vertical-align: middle;
	    	height: auto;
		padding: 0;
	}
	#gnav #loginmenu li a .txt_wrap img { height: 1.5rem; }
	#gnav #loginmenu li a .i_wrap {
		background: none;
		margin: 0;
		padding: 0;
		width: 23px;
		vertical-align: middle;
	}
	#gnav ul li a .i_wrap img { margin: 0; }
	#gnav ul:nth-of-type(2) li a {
		position: relative;
		display: inline-block;
	}
	#gnav ul:nth-of-type(2) li a::before{
		content: '';
		width: 7px;
		height: 7px;
		border: 0px;
		border-top: solid 1px #402D24;
		border-right: solid 1px #402D24;
		-ms-transform: rotate(45deg);
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		position: absolute;
		top: 50%;
		right: 0;
		margin-top: -4px;
		bottom: 0;
		margin-left: -7px;
	}
	#gnav ul:nth-of-type(2) li a.slide-arrow_b::before {
		-ms-transform: rotate(136deg);
		-webkit-transform: rotate(136deg);
		transform: rotate(136deg);
	}
	#search_wrap .close span {
		background: url(../img/i-close.png) no-repeat;
		width: 31px;
		height: 31px;
		display: inline-block;
		z-index: 99999;
		background-size: contain;
		right: 10px; 
		left: auto !important;
		top: auto !important;
	}
	#gnav .close {
		width: 34px;
		height: 34px;
		right: 17px;
		position: absolute;
	}
	#gnav .close span {
		width: 100%;
	}
	#gnav .close span:nth-of-type(1) {
		-webkit-transform: translateY(20px) rotate(-45deg);
		transform: translateY(20px) rotate(-45deg);
		top: 0;
		left: 10px
	}
	#gnav .close span:nth-of-type(2) {
		-webkit-transform: translateY(-20px) rotate(45deg);
		transform: translateY(-20px) rotate(45deg);
		bottom: 50px;
		top: 40px;
	}
	
	/* 検索メニュー */
	#search_wrap {
		position: fixed;
		z-index: 100000;
	}
	#search_wrap #search {
		width: calc(100% - 20px);
	    height: calc(100% - 10rem);
		margin: 0 auto;		
		font-size: 16px;
		font-size: 1.6rem;
		font-weight: bold;
		min-width: inherit;
		border-radius: 10px;
		overflow-y: scroll;
		top: 52%;
		transform: translate(-50% , -50%);
		position: fixed;
		left: 50%;
		background: #fff;		
		padding-bottom: 1rem;
	}
	#search_wrap #search > div { 
		width: 85%;
		margin: 0 auto !important;
	}
	#search_wrap #search .wordsearch { margin-top: 3.5rem !important; }
	#search_wrap h1 {
		background: #D8033A;
		position: relative;
		display: inline-block;
		padding: 0.5rem 1rem;
		width: 100%;
		border-bottom: 1px solid #fff;
	}
	#search_wrap h1.txt_wrap img { height: 2.4rem; }
	#search_wrap h1::before{
		right: 10px;
		width: 4px;
		height: 0;
		top: 0;
		bottom: 0;
		border: 6px solid transparent;
		border-left:6px solid #fff;
		position: absolute;
		margin: auto;
		content: "";
		vertical-align: middle;
	}
	#search_wrap h1.slide-arrow_b::before {
		-ms-transform: rotate(90deg);
		-webkit-transform: rotate(90deg);
		transform: rotate(90deg);
		top: 30%;
	}
	#search_wrap .category-menu .td {
		display: table-cell;
	}
	#search_wrap .category-menu .td.i_wrap {
		padding-right: 5px;
		width: 26px;
		height: auto;
		vertical-align: middle;
	}
	#search_wrap ul li {
		background: #FFFAF7;
		border-bottom: 1px solid #F2E7DF;
	}
	#search_wrap ul li a {
		    padding: 0.8rem 10px;
		    table-layout: fixed;
	}
	#search_wrap .prosearch, #search_wrap .wordsearch { background: #FFFAF7; }
	#search_wrap .wordsearch { 
		margin: 4.5rem 10px 0;
	}
	#search_wrap .wordsearch input { width: 100%; }
	#search_wrap form { padding: 1rem; }
	#search_wrap .btn_wrap { margin: 1rem 0; }
	#search_wrap .close { padding: 0; }
	#search_wrap .price li { font-family: "メイリオ", "Hiragino Kaku Gothic ProN", sans-serif; }
	#search_wrap .category-menu .td.i_wrap { width: 28px; }
	#search_wrap ul li a { 
		padding: 1.2rem 10px;
		position: relative;
		table-layout: initial;
	}
	#search_wrap ul li a::before {
		content: '';
		width: 7px;
		height: 7px;
		border: 0px;
		border-top: solid 1px #402D24;
		border-right: solid 1px #402D24;
		-ms-transform: rotate(45deg);
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		position: absolute;
		top: 50%;
		right: 20px;
		margin-top: -4px;
		bottom: 0;
		margin-left: -7px;
	}
	
	/*=========================================
			maincontent
	=========================================*/
	#maincontent_wrap { 
		margin: 1rem auto 0;
		width: 100%;
	}
	#maincontent {
		width: 100%;
		padding: 0 10px;
	}	
	#main { 
		width: 100%;
		min-width: auto;
		margin-bottom: 0;
	}
	#area, #area.no-side {
		width: 100%;
		margin: 0 auto;
	}
	#maincontent.no-side section { padding: 3rem 1rem !important; }		
	
	.limit-width {
		width: calc(100% - 4rem);
		margin: 0 auto;
	}
	
	/*=========================================
			スマホ用SNSバナーエリア
	=========================================*/	
	.bnr-area {
		padding: 4rem 10px 0;
		text-align: center;
	}
	.bnr-area ul { font-size: 0; }
	.bnr-area .sns {
		list-style: none;
		display: inline-block;
	}
	.bnr-area .sns li { float: left; }
	.bnr-area .sns li a { width: 60px; }
	.bnr-area .bnr_wrap { text-align: center; }
	.bnr-area .col-4 {
		display: inline-block;
		margin-top: 2rem;
		width: 100%;
	}
	.bnr-area .col-4 li { 
		margin-bottom: 1rem;
		float: none !important;
		display: inline-block;
	}
	
	/*=========================================
			footer
	=========================================*/		
	footer section { padding-top: 0; }	
	footer section, footer #copyright { 
		margin-top: 0;
		width: 100%;
	}
	footer #copyright { 
		padding-top: 0;
		position: relative;
	}
	footer article section > div {
		width: 100%;
		padding: 0 10px;
	}
	footer section div > ul li div.slide-arrow_b::before {
		-ms-transform: rotate(136deg);
		-webkit-transform: rotate(136deg);
		transform: rotate(136deg);
	}
/*	footer section ul.table > li { 
		margin: 4rem 10px;
	}	
*/	.col-1_sp .btn_wrap .col { padding: 0; }
	.col-1_sp:first-child > .col:first-child { padding-top: 0; }
	footer section div > ul li ul.td {
		clear: both;
		overflow: hidden;
	}
	footer section div > ul li ul.td li:first-child { padding-top: 0; }
	footer section div > ul li ul.td li {
		width: 50%;
		float: left;
	}
	footer section #footermenu { margin: 0 10px; }
	footer #footermenu .txt_wrap img { height: 15px; }
	footer section #footermenu li.cart_wrap div .i_wrap {
		height: auto;
		padding-right: 15px;
		vertical-align: middle;
		width: 52px;
	}
	footer section #footermenu .txt_wrap { height: auto; }
	footer section #footermenu li.cart_wrap div .i_wrap img {
		width: 100%;
		height: auto;
	}
	footer section ul li .table .td { width: auto; }	
	footer article:before {
		content: "";
		display: block;
		background: #80A774;
		width: 100%;
		height: 100%;
		position: absolute;
		top: 27%;
		bottom: 0;
		z-index: 0;		
	}
	footer #animation_container { width: 190% !important; }	
	#dom_overlay_container {
	    width: 140% !important;
		height: auto !important;
		padding-bottom: inherit !important;
		background-size: contain;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
	}
	.couple { 
		top: 23%;
		right: 43%;
	}
	
	/* 市町情報 */
	#about-city { 
		width: calc(100% - 20px);
		margin: 0 10px;
		display: table;
		margin-bottom: 3rem;
	}
	#about-city .img_wrap { 
		border-right: 1px solid #80A374;
		vertical-align: middle;
		border-bottom: none;
	}
	#about-city .img_wrap,
	#about-city .address_wrap{
		display: table-cell;
		padding: 1rem;
	}	
	#about-city .address_wrap { word-break: break-all; }
	#about-city .address_wrap dl dt { vertical-align: top; }
	#about-city .logo_wrap {
		width: 100%;
		margin: 0 auto;
		border-right: none;
		border-bottom: 1px solid #d9d9d9;
		padding: 10px 0;
		margin-bottom: 10px;
	}
	#about-city .logo_wrap img {
		width: 100%;
		height: auto;
		max-width: 136px;
	}			
	
	/* copyright */
	#copyright { 
		padding: 1rem;
		margin-top: 3rem;
	}
}

@media screen and (max-width: 999px) and (min-width: 481px) {
	/* カラム */
	.col-4 > .col {
		width: calc(25% - 8px);
		margin-left: 10px;
		float: left;
	}	
	.col-3_pad > .col { 
		width: calc(33.333% - 10px) !important;
		margin-left: 10px !important;
	}
	.col-3_pad > .col:nth-of-type(3n+1) { margin-left: 0 !important; }
	.col-2_pad > .col:nth-of-type(even) { margin-left: 20px !important; }
	.col-2_pad > .col:nth-of-type(odd) { margin-left: 0 !important; }
	.col-2_pad > .col { width: calc(50% - 10px) !important; }
	
	/*=========================================
			header
	=========================================*/
	header #roof { padding: 1.2rem 0 5rem; }
	#sitename a p:last-of-type { height: 2.4rem; }
	#sitename { 
		background-size: contain;
		position: absolute;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		padding: 0.6rem 2rem 0.9rem;
	}
	
	/*=========================================
			gnav
	=========================================*/
	#gnav ul li { width: 60%; }
	#gnav ul:nth-of-type(2) li a { padding: 1rem 10px; }
	
	/*=========================================
			parts
	=========================================*/		
	/* ページタイトル */
	#page-ttl { width: 91%; }
	.max-width #page-ttl p img {
		height: 100%;
		width: auto;
		max-height: 8rem;
	}
	
	/* タブメニュー */
	.tab-menu { margin-bottom: 1rem; }
	
	/*=========================================
			footer
	=========================================*/	
/*	footer ul.table { display: block; }
*/	footer #animation_container { padding-bottom: 90rem !important; }
	footer section { top: 28%; }
	footer section .fm-list_wrap > ul > li { 
		display: inline-block;
		margin: 0 10px 0 0;
		width: calc(30% - 15px);
	}
	footer section #footermenu li.cart_wrap div {
		width: auto;
		margin: 0 auto;
	}
	footer section #footermenu { width: 63%; }
	footer section #footermenu li.cart_wrap a { padding: 0 19%; }	
}

@media screen and (min-width: 481px) {	
	.sp { display: none !important; }
		
	/*=========================================
			parts
	=========================================*/
	/* 注意事項 */
	.caution-box dt { border-right: 1px dotted #fa4032; }
	
	/* タブメニュー */
	.tab-menu .selected:after,
	.tab-menu a:after {
		width: calc(100% - 8px);
		right: 4px;
		left: 4px;
	}
	
	/*=========================================
			header
	=========================================*/
	#sitename a p:first-of-type { margin-right: 5px; }

		
	/*=========================================
			footer
	=========================================*/
	footer section div > ul li ul.td li a { letter-spacing: 0.2rem; }
	footer section #footermenu {
		position: absolute;
		right: 0;
		bottom: 0;
	}
	footer section #footermenu li.cart_wrap { width: calc(100% - 222px); }
}

@media screen and (max-width: 480px) {
	.pcpad { display: none !important; }
	.pad { display: none !important; }
	
	.table-responsive-block, .table-responsive-block .td, .table-responsive-block .tr,.table-responsive { display: block; }
	.table-responsive .th, .table-responsive .td { display: inline-block; }
	
	/* カラム */
	.col-4 > .col {
		width: calc(50% - 4px);
		margin-left: 8px;
		float: left;
		margin-bottom: 8px;
	}
	.col-4 > .col:nth-child(odd) { margin-left: 0; }
	.col-4 > .col:nth-child(3), .col-4 > .col:last-child { margin-bottom: 0; }
	.col-2_sp { 
		clear: both;
		overflow: hidden;
	}
	.col-2_sp > .col:nth-of-type(even) { margin-left: 10px !important; }
	.col-2_sp > .col:nth-of-type(odd) { margin-left: 0 !important; }
	.col-2_sp > .col { 
		width: calc(50% - 5px) !important;
		float: left;
	}
	.col-1_sp > .col { 
		width: 100% !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
	}
/*	.col-1_sp > .col { padding: 1.2rem 0 0 0; }
*/	
	/*=========================================
			header
	=========================================*/
	header #roof #headmenu_wrap { padding-bottom: 0; }
	#sitename { 
		padding: 0.4rem 1rem 0.6rem;
		width: calc(100% - 180px);
	}
	#sitename a p { 
		float: none;
		margin-bottom: 0;
		height: 1.1rem;
	}
	#sitename a p:first-of-type { margin-bottom: 0.3rem; }
	#sitename a p:last-of-type { 
		margin-top: 0.5rem;
		height: 2.2rem;
	}	
	#sitename a p img {
		width: auto;
		height: 100%;
	}
	
	/*=========================================
			parts
	=========================================*/	
	.caption { text-align: left !important; }
	
	/* ステップ */
	.cd-multi-steps.count li { width: auto !important; }
	.cd-multi-steps.count li.visited > *::before { color: #FF8417; }
	.cd-multi-steps li.visited em { color: #FF8417; }
	.step { margin-top: 4rem !important; }
	
	/* ボタン */
	.btn_wrap.col-1 { width: 100%; }
	.btn_wrap.col-2 > .col a { padding: 1.6rem 0.5rem !important; }
	.btn_wrap.col-2 > .col a.circle-arrow:before,
	.btn_wrap.col-2 > .col a.circle-arrow:after { display: none; }
/*	.btn_wrap.col-2 > .col:first-child { margin-bottom: 1.2rem; }
*/	.btn_wrap p a { padding: 18px 11px; }
	
	/* テーブル */
	table.default th, table.default td { display: inline-block; }
	table.default th { padding: 0.8rem 5px; }	
	
	/* ページャー */
	.pager li { margin-bottom: 1rem; }	
	
	/* 電話リンク */
	.tel-link { 
		font-weight: 500;		
		line-height: 1.3;
	}
	.tel-link:hover { border-bottom: 1px solid #141414; }
	
	/* ランキング */
	#rank_wrap li.col.item {
		width: calc(50% - 5px);
		margin-left: 0;
	}
	#rank_wrap li.col.item:last-child { margin-left: 10px; }
	#rank_wrap li.col.item:first-child {
		width: 100%;
		margin-bottom: 1rem;
	}
	#rank_wrap li.col.item .img_wrap { height: 100px; }
	#rank_wrap li.col.item:first-child .img_wrap { height: 200px; }
	#rank_wrap li.col.item:nth-child(2):after,#rank_wrap li.col.item:last-child:after {
		width: 60px;
		height: 60px;
		background-size: contain;
	}
	
	/* ページタイトル */
	.max-width #page-ttl p img {
		width: auto;
		height: 100%;
		max-height: 5.2rem;
	}
	#page-ttl { width: 100%; }	
	#page-ttl p { padding: 3.6rem 0 2rem; }
	#page-ttl img { height: 5.2rem !important; }		
	#page-ttl:before, #page-ttl:after {
		width: 22px;
		height: 11rem;
		background-size: 100%;
	}
		
	/* スライドトグルの矢印 */
	.slide-parent_sp { position: relative; }
	.slide-parent_sp:after {
		font-family: "Font Awesome 5 Pro";
		content: "\f105";
		-webkit-font-smoothing: antialiased;
		display: inline-block;
		font-style: normal;
		font-variant: normal;
		text-rendering: auto;
		line-height: 1;
		font-size: 18px;
		font-size: 1.8rem;
		font-size: calc(1.6rem + ((1vw - 0px) * 0.1042));
		color: #141414;
		position: absolute;
		z-index: 2;
		top: 50%;
		right: 2rem;
		transform: translateY(-50%);
		-webkit-transform: translateY(-50%);
		font-weight: 500;
	}
	.slide-parent_sp.slide-arrow_b:after {
		-ms-transform: rotate(90deg);
		-webkit-transform: rotate(90deg);
		transform: rotate(90deg);
		bottom: 50%;
		right: 1rem;
	}
	
	/* 注意事項 */
	.caution-box.table-responsive dt.th { 
		display: block;
		border-bottom: 1px dotted #fa4032;
	}
	
	/* タブメニュー */
	.tab-menu { margin-bottom: 0; }
	.tab-menu li { margin-bottom: 2rem !important; }
	.tab-menu li a { padding-bottom: 2rem; }
	.tab-menu .selected:after,
	.tab-menu a:after {
		width: 100%;
		right: 0;
		left: 0;
	}
	
	/* thanks-comment */
	.thanks-comment { text-align: left; }

	/*=========================================
			footer
	=========================================*/	
	footer section div > ul li ul.td li a { letter-spacing: 0.1rem; } 
	footer #animation_container {
		padding-bottom: 137rem !important;
		background-size: contain;
	}
	footer canvas {
		width: 1250px !important;
		height: auto !important;
	}
/*	footer section { top: 8%; }
*/	footer section #footermenu li.cart_wrap {
		width: 100%;
		margin-left: 0;
		margin-top: 10px;
	}
	footer section #footermenu li {
		width: calc(50% - 5px);
		margin-left: 10px;
	}
	footer section #footermenu li.cart_wrap a { padding: 0 30%; }
	#about-city .img_wrap img { width: 140px; }
	footer article:before { top: 14%; }
	.couple {
		top: 6%;
		right: 41%;
		width: 18px;
	}
	footer canvas { top: -3%; }
	#dom_overlay_container { top: -2%; }
	
	/* トップへボタン */
	footer #to_top { 
		right: 10px;
		bottom: 10px;
	}
	footer #to_top:hover {
		bottom: 2rem;
	}	
}

@media screen and (max-width: 320px) {
	#sitename { 
		left: 40%;
		max-width: 120px;
		padding: 0.6rem 0.3rem 0.8rem;
	}
	#sitename a p { height: 0.8rem; }
	#sitename a p:last-of-type { height: 1.6rem; }
	#top .header_after {
		padding-top: 8.3rem;
	}
	
	/*=========================================
			parts
	=========================================*/
	/* ページャー */
	.pager div {
		line-height: 3.3rem;
		width: 3.3rem;
		height: 3.3rem;
	}
	.pager ul li {
		line-height: 3.3rem;
		height: 3.3rem;
	}
	.pager ul li a {
		line-height: 3.3rem;
		width: 3.3rem;
		height: 3.3rem;
	}
	
	/*=========================================
			main
	=========================================*/
	/* ページタイトル */
	#page-ttl img { height:75%; }	
	
	/*=========================================
			footer
	=========================================*/	
	#about-city .img_wrap {
		width: 100px;
		padding: 0.5rem;
	}
	footer #animation_container { padding-bottom: 146rem !important; }
}

