@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に*/ }
.overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #000;
	z-index: 999;
}
body {
	color: #000;
	font-size: 16px;
	font-size: 1.6rem;
	font-weight: 500;
	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 {
	font-weight: bold;
	color: #02414c;
	text-decoration: none;
	display: block;
	outline: none;
}
#panel-btn a {
	width: 100%;
	height: 100%;
}
p a {
	display: inline-block;
}
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;
}
.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: middle;
}
.txt_wrap img {
    width: auto;
    max-width: 100%;
    height: auto;
    display: block;
    max-height: 100%;
}
img { vertical-align: top; }

/* img-autosize */
.img-autosize {
    position: relative;
    padding-bottom: 66.672%;
    overflow: hidden;
}
.img-autosize img {
	width: auto;
    height: auto;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    max-width: 100%;
    max-height: 100%;
    margin: auto;
    display: block;
}

/* img-coversize */
.img-coversize {
	position: relative;
	overflow: hidden;
	padding-bottom: 66.918%;
}
.img-coversize img {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 100%;
	min-height: 100%;
	object-fit: cover;
}

/* 文字 */
h1 {
	font-size: 74px;
	font-size: 7.4rem;
}
h2 {
	font-size: 60px;
	font-size: 6rem;
}
h3 {
	font-size: 30px;
	font-size: 3rem;
}
h4 {
	font-size: 24px;
	font-size: 2.4rem;
}
h5 {
	font-size: 22px;
	font-size: 2.2rem;
}
h6 {
	font-size: 20px;
	font-size: 2rem;
}
.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;
}
.t-18 {
	font-size: 18px;
	font-size: 1.8rem;
}
.t-19 {
	font-size: 19px;
	font-size: 1.9rem;
}
.t-20 {
	font-size: 20px;
	font-size: 2rem;
}
.t-21 {
	font-size: 21px;
	font-size: 2.1rem;
}
.t-22 {
	font-size: 22px;
	font-size: 2.2rem;
}
.t-23 {
	font-size: 23px;
	font-size: 2.3rem;
}
.t-24 {
	font-size: 24px;
	font-size: 2.4rem;
}
.t-26 {
	font-size: 26px;
	font-size: 2.6rem;
}
.t-28 {
	font-size: 28px;
	font-size: 2.8rem;
}
.t-30 {
	font-size: 30px;
	font-size: 3rem;
}
.t-34 {
	font-size: 32px;
	font-size: 3.2rem;
}
.t-34 {
	font-size: 34px;
	font-size: 3.4rem;
}
.t-36 {
	font-size: 36px;
	font-size: 3.6rem;
}
.t-40 {
	font-size: 40px;
	font-size: 4rem;
}
.t-42 {
	font-size: 42px;
	font-size: 4.2rem;
}
.t-46 {
	font-size: 46px;
	font-size: 4.6rem;
}
.t-48 {
	font-size: 48px;
	font-size: 4.8rem;
}
.t-50 {
	font-size: 50px;
	font-size: 5rem;
}
.t-56 {
	font-size: 56px;
	font-size: 5.6rem;
}
.t-64 {
	font-size: 64px;
	font-size: 6.4rem;
}

.ver-top { vertical-align: top !important; }
.red, .error { color: #fa4032; }
.bold { font-weight: bold; }
.indent {
	padding-left: 1em;
	text-indent: -1em;
}
strong {
	font-size: 18px;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 3rem;
	color: #ffea2a;
}
.fuchi {
	color: #386c85;
	text-shadow: 1px 1px 0 #fff, -1px 1px 0 #fff, 1px -1px 0 #fff, -1px -1px 0 #fff;
}
.thanks-comment {
	font-size: 20px;
	font-size: 2rem;
	line-height: 1.7;
	color: #fa4032;
	font-weight: bold;
	text-align: center;
	margin: 6rem 0 !important;
}

/* カラム */
.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-5, .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% - 16px);
	margin-left: 20px;
	display: inline-block;
	float: left;
}
.col-5 > .col:nth-child(5n+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
=========================================*/
/* 上下左右中央 */
.absolute-allcenter {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	-webkit-transform: translate(-50%,-50%);
	-ms-transform: translate(-50%,-50%);
}
.absolute-xcenter {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
}
.absolute-ycenter {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
}

/* 説明文 */
.caption {
	margin: 4rem 0 3rem;
	font-size: 16px;
	font-size: 1.6rem;
}

/* シングル矢印 */
.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; }

/* インラインの矢印 */
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; }

/* テキストリンク */
.text-link {
	margin: 0 3px;
/*    display: inline;
    font-weight: 400; */
}
/* .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 a, .td-btn p a {
	font-size: 16px;
	font-size: 1.6rem;
	text-decoration: none;
	font-weight: bold;
	text-align: center;
	display: block;
	padding: 18px 0 14px;
}
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: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-i a div {
	display: table;
	margin: 0 auto;
}
.btn-i a div i { display: table-cell; }
.btn-i a div p {
	display: table-cell;
    vertical-align: middle;
    text-align: left;
}
.btn-i_l a div p { padding-left: 1rem; }
.btn-i_r a div p { padding-right: 1rem; }

/* アイコン */
i { display: inline-block; }
i img {
	width: 100%;
	height: auto;
}

/* modal */
.mfp-title { padding-right: 4em !important; }

/* 角丸 */
.round-5 { border-radius: 0.5rem; }
.round-10 { border-radius: 1rem; }
.round { border-radius: 5rem; }

.cannot {
	background: #D8D8D8;
	box-shadow: none;
	border-radius: 5px;
}
.cannot a { cursor: default; }
p.cannot:hover, p.cannot a:hover{
	opacity: 1;
	filter: alpha(opacity=100);
	-ms-filter: “alpha( opacity=100 )”
}

/* position */
.relative { position: relative; }
.absolute { position: absolute; }

/* 入力フォーム */
input, textarea {
	font-size: 16px;
	font-size: 1.6rem;
	font-family:  "fot-tsukuardgothic-std",sans-serif;
}
input, select { vertical-align: top; }
input[type="text"] {
	border-radius: 5px;
	padding: 8px;
}
input[type="tel"] {
	border-radius: 5px;
    padding: 8px;
}
input::-webkit-input-placeholder {
	color: rgba(20,20,20,.5);
}
textarea {
	width: 100%;
	height: 200px;
	resize: vertical;
}
input.min-input { width: 93px; }
input.middle-input {
	width: calc(50% - 2rem);
	display: inline-block;
}
.label-l { margin-right: 8px; }
.label-r { margin-left: 5px; }
.input-l { margin-right: 15px; }

/* float */
.float-l {
	display: inline-block;
	float: left;
}
.float-r {
	display: inline-block;
	float: right;
}


/* エラーメッセージ */
.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;
	border-radius: 100%;
}
input[type="radio"]:checked + label::after {
	position: absolute;
	content: '';
	top: 50%;
	border-radius: 100%;
}


/* セレクトメニュー */
.selectmenu {
	overflow:hidden;
	position: relative;
	padding: 0 !important;
}
.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;
	padding: 0 30px 0 10px;
	border: 0;
	border-radius: 5px 8px 8px 5px;
	background: url(../img/common/arrow-pull.png) no-repeat center right 10px, #DEE5E5;
    background-size: 10px;
	height: 4.4rem;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
	font-size: 15px;
	font-size: 1.5rem;
	color: #02414C;
}
select::-ms-expand {
	display: none;
}
select {
  -moz-appearance: none;
  text-indent: 0.01px;
  text-overflow: '';
}

/* お知らせのカテゴリー色 */
.cate {
	padding: 0 1rem;
	display: inline-block;
	border-radius: 3rem;
	color: #fff;
	letter-spacing: 0.1rem;
	min-width: 7.65rem;
	text-align: center;
}

/* 商品番号 */
.code {
	display: inline-block;
	font-size: 12px;
	font-size: 1.2rem;
}

/* カテゴリー */
#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%;
}
table.default th,
.table-default .thead .td {
	padding: 0.8rem 0;
	white-space: nowrap;
	text-align: center;
	font-weight: bold;
	min-width: 80px;
}
table.default td,
.table-default .td {
	vertical-align: middle;
	padding: 1.5rem !important;
	text-align: left;
}
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; }

/* 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: top;
}
.td img { vertical-align: top; }

/* ページャー */
.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_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; }

/* colorbox */
.colorbox {
    background: #fff;
    line-height: 2.6rem;
    background: #F6F5F2;
    padding: 2rem;
    color: #313130;
}
.colorbox h3 {
	margin: 0rem 0 1.5rem;
    text-align: center;
    color: #FA4737;
}
.colorbox ol {
    display: inline-block;
    text-align: left;
	margin-left: 2rem;
}
.colorbox ol li {
    margin-bottom: 1.5rem;
    font-weight: bold;
}
.colorbox ol li p {
    font-weight: 500;
    color: #000;
    font-size: 15px;
    font-size: 1.5rem;
}

/* frame */
.frame {
    text-align: center;
    padding: 2.5rem 1.5rem;
    color: #fff;
    background: rgba(2,33,38,.16);
    border: 1px solid rgba(255,255,255,.4);
}

/* slider */
.bx-viewport li { min-height: 1px; min-width: 1px; }
.bx-clone {display: none;}

/* flex */
.flex-parents {
	display:-webkit-box;
  	display:-ms-flexbox;
	display: flex;
}

/*=========================================
		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;
}
.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;
}

/* 検索メニュー */
.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;
	padding: 5px 5px 2rem;
}
#rank_wrap li.col.item .item-ttl {
    margin: 1.2rem 5px;
}
#rank_wrap li.col.item .price {
	margin-right: 5px;
}
#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;
}

/* リスト */
.list-disc {
	list-style: disc;
	margin-left: 1.5em;
}
.list-square {
	list-style: square;
	margin-left: 1.5em;
}
.list-kakko li {
	list-style-type: none;
	counter-increment: cnt;
}
.list-kakko li::before { content: "(" counter(cnt) ") "; }

/*=========================================
		maincontent
=========================================*/
#thanks .caption { margin: 3rem 0 4rem; }

/* パンくずリスト */
#pan { margin: 1rem auto 3rem; }
#pan li {
    float: left;
    display: inline-block;
}
#pan li:first-child {
	padding-left: 0;
}
#pan li a {
	display: inline-block;
	float: left;
	width: auto;
}
#pan li.visited:after {
	content: "/";
	display: inline-block;
	font-size: 16px;
	font-size: 1.6rem;
    float: left;
    margin: 0 8px;
	line-height: 2.2rem;
}
#pan li.visited:hover a:after {
	border-left: 20px solid #B9CCD3;
}
#pan li a span {
	margin-right: 0.4rem;
    vertical-align: bottom;
    float: left;
	width: 20px;
}
#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; }

/*=========================================
		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: 9;
	width: 92px;
}
footer #to_top:hover {
	bottom: 5.5rem;
	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;

}

/* 市町情報 */
#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 ul.table > li { padding-top: 0; }
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; }
}



@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: 768px) {
	/*=========================================
			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: 768px){
	footer section #footermenu li { width: 7.6rem; }
}

@media screen and (max-width: 959px) {
	.pc { display: none !important; }
}

@media screen and (min-width: 768px) {
	.sp { display: none !important; }

	/*=========================================
			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
	=========================================*/
	/* 説明文 */
	.caption { text-align: center; }

	/* #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;
	}

	/*=========================================
			maincontent
	=========================================*/
	#maincontent_wrap {
		width: 94.144%;
		min-width: 1000px;
		max-width: 1366px;
		height: 100%;
	}
	#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 ul li .table .td { margin-bottom: 2rem; }
	footer section #footermenu { width: 40%; }
}

@media screen and (min-width: 769px) {
	.padsp { display: none !important; }
	.pad { display: none !important; }
}

@media screen and (max-width: 767px) {
	.pcpad { display: none !important; }

	html { font-size: 58.5%; }

	/* 文字 */
	h1 {
		font-size: 60px;
		font-size: 6rem;
	}
	h2 {
		font-size: 44px;
		font-size: 4.4rem;
	}
	h3 {
		font-size: 26px;
		font-size: 2.6rem;
	}
	h4 {
		font-size: 20px;
		font-size: 2rem;
	}
	h5 {
		font-size: 18px;
		font-size: 1.8rem;
	}
	h6 {
		font-size: 16px;
		font-size: 1.6rem;
	}
	.t-10,.t-11,.t-12,.t-13,.t-14 {
		font-size: 15px;
		font-size: 1.5rem;
	}
	.t-28 {
		font-size: 24px;
		font-size: 2.4rem;
	}
	.t-30 {
		font-size: 26px;
		font-size: 2.6rem;
	}
	.t-32 {
		font-size: 28px;
		font-size: 2.8rem;
	}
	.t-34 {
		font-size: 30px;
		font-size: 3rem;
	}
	.t-36 {
		font-size: 30px;
		font-size: 3rem;
	}
	.t-42 {
		font-size: 30px;
		font-size: 3rem;
	}
	.t-48 {
		font-size: 34px;
		font-size: 3.4rem;
	}
	.t-50 {
		font-size: 36px;
		font-size: 3.6rem;
	}
	.t-56 {
		font-size: 42px;
		font-size: 4.2rem;
	}

	/* 余白 */
	.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
	=========================================*/
	/* ボタン */
	.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%; }

	/* 生年月日 */
	#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: 5em; }

	/* お知らせ */
	span.type-news, span.type-event, span.type-important, span.area {
		height: 24px;
		line-height: 2.4rem;
	}

	/* ステップ */
	.cd-multi-steps { margin: 0 auto; }

	/* colorbox */
	.colorbox > p {
		text-align: left !important;
		display: inline-block;
	}
	.colorbox p.btn { width: 100%; }

	/* ポイント */
	.point ol, .point ul { padding: 0 3rem; }

	/* 説明文 */
	.caption { margin-top: 2rem; }

	/* 注意事項 */
	.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 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;
		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: 3rem 0 3rem !important;
	}

	/*=========================================
			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
	=========================================*/
	/*.fixed {
	  position: 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; }

	/*=========================================
			スマホ用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 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 0;
	}
	.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;
	}
}

@media screen and (max-width: 767px) and (min-width: 481px) {
	/* カラム */
	.col-4 .col {
		width: calc(25% - 8px);
		margin-left: 10px;
		float: left;
	}
	.col-3_pad .col {
		width: calc(33.333% - 20px) !important;
		margin-left: 20px;
	}
	.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
	=========================================*/
	/* ページャー */
	.pager_wrap { padding-top: 0.3rem !important; }

	/* ステップ */
	.cd-multi-steps.count li { width: 108px; }

	/* ページタイトル */
	#page-ttl { width: 91%; }
	.max-width #page-ttl p img {
		height: 100%;
		width: auto;
		max-height: 8rem;
	}

	/*=========================================
			footer
	=========================================*/
	footer ul.table { display: block; }
	footer #animation_container { padding-bottom: 90rem !important; }
	footer section { top: 28%; }
	footer section ul.table > li {
		display: inline-block;
		margin: 0 10px 0 0;
	}
	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: 768px) and (max-width: 1199px) {
	html { font-size: 0.833vw; }
}

@media screen and (min-width: 481px) {
	/*=========================================
			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) {
	.pad { display: none !important; }

	.td { display: block; }
	.table-abs .td { display: table-cell; }

	/* カラム */
	.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 .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; }
	.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; }

	/* thanks-comment */
	.thanks-comment { text-align: left; }

	/*=========================================
			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%;
	}

	/*=========================================
			gnav
	=========================================*/
	.sp-gmenu li a {
		padding: 0;
		margin: 1.7rem 0;
		font-size: 18px;
		font-size: 1.8rem;
		line-height: 1.8rem;
		height:auto;
	}
	#gnav ul li { width: 79%; }

	/*=========================================
			parts
	=========================================*/
	/* ステップ */
	.cd-multi-steps { padding: 0 1rem 1rem; }
	.cd-multi-steps.count li { width: auto !important; }
	.cd-multi-steps.count li.visited > *::before { color: #FF5126; }
	.cd-multi-steps li.current > *,
	.cd-multi-steps li.visited em { color: #FF5126 !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; }

	/* ランキング */
	#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%;
	}

	/*=========================================
			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; }
}

