@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 {
	font-family: "Noto Sans JP";
	color: #141414;
	font-size: 16px;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.7;
	z-index: 1;
	-webkit-text-size-adjust: 100%;
	background: #FFF;
    letter-spacing: 1.57px;
}
article,aside,canvas,details,figcaption,figure,
footer,header,hgroup,menu,nav,section,summary{
	display:block;
}
img {
    max-width: 100%;
}
a {
	font-weight: bold;
	color: #141414;
	text-decoration: none;
	display: block;
	width: 100%;
	height: 100%;
	outline: none;	
}
p a { 
	display: inline-block;
}

p {
    line-height: 2.1;
    letter-spacing: 1.57px;
    margin: 1em 0;
}
.font_en{
	font-family: Times New Roman;
	letter-spacing: 2px;
}
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 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;
}
.txt_wrap img {
	height: 100%;
	width: auto;
}

/* 文字 */
h1 {
	font-weight: bold;
	font-size: 36px;
	font-size: 3.6rem;
	line-height: 3.6rem;
}
h2 {
	font-weight: bold;
	font-size: 24px;
	font-size: 2.4rem;
	line-height: 2.4rem;
}
h3 {
	font-size: 22px;
	font-size: 2.2rem;
	line-height: 3.3rem;
	font-weight: bold;
}
h4 {
	font-size: 20px;
	font-size: 2rem;
	line-height: 3rem;
	font-weight: bold;
}
h5 {
	font-size: 18px;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 2.7rem;
}
h6 {
	font-size: 16px;
	font-size: 1.6rem;
	line-height:2.7rem;
	font-weight: bold;
}
.t-10 {
	font-size: 10px;
	font-size: 1rem;
	line-height: 1.7rem;
}
.t-11 {
	font-size: 11px;
	font-size: 1.1rem;
	line-height: 1.8rem;
}
.t-12 {
	font-size: 12px;
	font-size: 1.2rem;
	line-height: 2rem;
}
.t-13 {
	font-size: 13px;
	font-size: 1.3rem;
	line-height: 2.2rem;
}
.t-14 {
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 2.3rem;
}
.t-15 {
	font-size: 15px;
	font-size: 1.5rem;
	line-height: 2.5rem;
}
.t-16 {
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 2.7rem;
}
.t-17 {
	font-size: 17px;
	font-size: 1.7rem;
	line-height: 2.9rem;
	font-weight: bold;
}
.t-18 {
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 3rem;
}
.t-19 {
	font-size: 19px;
	font-size: 1.9rem;
	line-height: 3.2rem;
}
.t-20 {
	font-size: 20px;
	font-size: 2rem;
	line-height: 3.4rem;
}
.t-21 {
		font-size: 21px;
		font-size: 2.1rem;
		line-height: 3.5rem;
	}
.t-22 {
	font-size: 22px;
	font-size: 2.2rem;
    line-height: 3.7rem;
}
.t-23 {
	font-size: 23px;
	font-size: 2.3rem;
    line-height: 3.9rem;
}
.t-24 {
	font-size: 24px;
	font-size: 2.4rem;
    line-height: 4rem;
}
.t-26 {
	font-size: 26px;
	font-size: 2.6rem;
    line-height: 4.4rem;
}
.t-26 {
	font-size: 26px;
	font-size: 2.6rem;
    line-height: 4.4rem;
}
.t-30 {
	font-size: 30px;
	font-size: 3rem;
	line-height: 5.1rem;
}
.t-34 {
	font-size: 34px;
	font-size: 3.4rem;
	line-height: 3.4rem;
}
.t-46 {
	font-size: 46px;
	font-size: 4.6rem;
}
.ver-top { vertical-align: top !important; }
.red, .error { color: #bf1919; }
.error { font-weight: bold; }
.bold { font-weight: bold; }
.blue {
	color: #345BA0;
}
.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: #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: 440px;
}
.btn_wrap.col-2 {
    width: 80%;
    clear: both;
    overflow: hidden;
    margin: 0 auto;
    display: flex;
    max-width: 440px;
    flex-direction: column;
}
.btn_wrap.col-2 p.btn.btn-blue.col {
    order: 1;
}
.btn_wrap.col-2 p.btn.btn-gray.col {
    order: 2;
}
.btn_wrap.col-2.con-full {
	width: 100%;
	min-width: auto;
}
.btn_wrap.col-2 .col {
	width: 100%;
    float: left;
}
.col-4, .col-3, .col-2 {
	clear: both;
	overflow: hidden;
}
.btn_wrap.col-2 .col:first-child { margin-right: 8px; }
.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; }

/* 余白 */
.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
=========================================*/


.wide1400 {
    max-width: 1400px;
    width: 90%;
    margin: 50px auto;
}

.wide1200 {
    max-width: 1200px;
    width: 90%;
    margin: 50px auto;
}

/* 説明文 */
.caption { margin-bottom: 4rem; }

/* シングル矢印 */
.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; }

/* 矢印 */
a.circle-arrow {
    position: relative;
    padding-right: 4rem;
}
a.circle-arrow::after {
    content: "";
    width: 21px;
    height: 10px;
	background: url(../img/common/arrow.png) no-repeat center;
	background-size: contain;
    position: absolute;
    right: 0;
    top: 0;
	bottom:0;
	margin: auto;
    transition: 0.5s;
}

/*別窓*/
a.download-arrow {
    position: relative;
}
a.download-arrow::after {
    content: "";
    width: 16px;
    height: 26px;
    background: url(../img/common/i-window2.png) no-repeat center;
    background-size: contain;
    position: absolute;
    right: 1em;
    top: 0;
    bottom: 0;
    margin: auto;
    transition: 0.5s;
}

/*ダウンロード*/
a.i-down2 {
    position: relative;
}
a.i-down2::after {
    content: "";
    width: 22px;
    height: 19px;
    background: url(../img/i-down2.png) no-repeat center;
    background-size: contain;
    position: absolute;
    right: 2em;
    top: 0;
    bottom: 0;
    margin: auto;
    transition: 0.5s;
}


/* テキストリンク */
.text-link { 
	display: inline-block;
	margin-left: 3px;
    width: auto;
}
.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: #345BA0;
    line-height: 1.3;
    text-decoration: underline;
}
a.link-under:hover {
	opacity: 1;
	filter: alpha(opacity=100);
	-ms-filter: “alpha( opacity=100 )”;
}


/* ボタン */
.btn_style01 {
    margin: 50px auto 0;
    overflow: hidden;
    max-width: 1400px;
}
.btn_style01 > a {
    line-height: 1.8;
    max-width: 300px;
    width: 90%;
    padding: 5px 0;
    box-sizing: border-box;
    border-top: 2px solid #000000;
	transition: 0.5s;
}
.btn_style01.btn_left > a {
    float: left;
}
.btn_style01.btn_right > a {
    float: right;
}
.btn_style01 > a:hover  {
    opacity: 0.7;
}
.btn_style01 > a:hover p {
    -webkit-animation-name: kf-label;
    animation-name: kf-label;
    -webkit-animation-duration: 1s;
    animation-duration: 1s;
    -webkit-animation-timing-function: ease;
    animation-timing-function: ease;
    -webkit-animation-delay: 0s;
    animation-delay: 0s;
    -webkit-animation-iteration-count: 1;
    animation-iteration-count: 1;
    -webkit-animation-direction: normal;
    animation-direction: normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
}
@keyframes kf-label {
    0% {
        transform: translateY(0);
        opacity: 1;
    }
    49.9% {
        transform: translateY(-100%);
        opacity: 0;
    }
    50.1% {
        transform: translateY(100%);
        opacity: 0;
    }
    100% {
        transform: translateY(0);
        opacity: 1;
    }
}

.text_white,
.text_white a {
    color: #fff;
}
.text_white a {
    font-weight: normal;
}
.btn_style01.text_white > a {
    color: #fff;
    border-color: #fff;
}
.text_white > a::after,
.btn_style01.text_white > a::after {
    -webkit-filter: brightness(0) invert(1);
    filter: brightness(0) invert(1);
}

.text_blue,
.text_blue a {
    color: #345BA0;
}
.btn_style01.text_blue > a {
    color: #345BA0;
    border-color: #345BA0;
}
.text_blue > a::after,
.btn_style01.text_blue > a::after {
    background: url(../img/common/arrow02.png) no-repeat center;
    background-size: contain;
}


.btn_style02 a.circle-arrow {
    max-width: 180px;
    border: 2px solid;
    padding: 5px 20px;
    box-sizing: border-box;
    border-radius: 50px;
    transition: 0.5s;
}
.btn_style02 a.circle-arrow::after {
    right: 14px;
}

.btn_style02 a:hover {
    background: #141414;
    border-color: #141414;
    color: #fff;
    transition: 0.5s;
}
.btn_style02 a:hover::after {
    -webkit-filter: brightness(0) invert(1);
    filter: brightness(0) invert(1);
}
.btn_style02 a.circle-arrow:hover::after {
    right: 6px;
}

.btn_style02 a.circle-arrow p {
    margin: 0;
}
.btn_style02.text_white a.circle-arrow:hover {
    background: #fff;
    border-color: #fff;
    color: #4E75BA;
}
.btn_style02.text_white a.circle-arrow:hover::after {
    right: 6px;
    filter: none;
    background: url(../img/common/arrow02.png) no-repeat center;
    background-size: contain;
}

.btn_style02.text_blue a.circle-arrow:hover {
    background: #4E75BA;
    border-color: #4E75BA;
    color: #fff;
}
.btn_style02.text_blue a.circle-arrow:hover::after {
    right: 6px;
    -webkit-filter: brightness(0) invert(1);
    filter: brightness(0) invert(1);
}

.btn_style02.btn_center a.circle-arrow {
    margin: 0 auto;
    max-width: 300px;
    width: 80%;
}

.btn_style02 a.i-down2 {
    border: 2px solid;
    padding: 5px 20px;
    box-sizing: border-box;
    border-radius: 50px;
    transition: 0.5s;
    max-width: 80%;
    margin: 1.5em auto !important;
    display: block !important;
}

.btn_style02 a.i-down2 p {
    /*display: flex;
    align-items: center;
    justify-content: center;*/
}

.btn_style02 a.i-down2 p span {
    margin: 0 0 0 1em;
}


/*リスト*/
ul.list01 li {
    padding-left: 1.5em;
    margin: 0.25em 0;
    line-height: 1.8;
    position: relative;
    list-style: none;
}
ul.list01 li::before {
    content: "";
    width: 0.7em;
    height: 0.7em;
    background: #345BA0;
    border-radius: 50px;
    position: absolute;
    left: 0.25em;
    top: 0.6em;
}



/*画像ブロック*/
.img_block {
    position: relative;
    width: 100%;
    padding-bottom: 100%;
}
.img_block 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_action {
    overflow: hidden;
}
.img_action img {
    transition: 0.5s;
}
.img_action:hover img {
    transform: scale(1.2);
    transition: 0.5s;
}

@media screen and (max-width: 1500px) {
.btn_style01 {
    width: 100%;
}
}

.btn_wrap .btn {
    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: 18px 0 14px;
}
td .btn:hover,
td .btn-gray:hover,
.td .btn-gray:hover,
.btn_wrap p: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 { border-radius: 5px; }
.btn a {
	color: #fff !important;
	font-weight: bold;
	padding: 1rem 1.1rem;
	text-align: center;
}
.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;
}
.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 )”
}


/* ボタン 色 */
.btn-green {
    background: #549E87;
    box-shadow: 0 3px 1px 0px rgba(84,158,135,.3);
}
.btn-blue {
    background: #345BA0;
    border: 2px solid #345BA0;
}
.btn-blue:hover {
    opacity: 1;
    background: #fff;
}
.btn-blue:hover a {
    opacity: 1;
    color: #345BA0 !important;
}
.btn-gray {
    background: #fff;
    color: #333;
    border: 2px solid #333;
}
.btn_wrap .btn-gray a {
    padding: 7px 0 5px;
    color: #333 !important;
}
.btn-gray:hover {
    opacity: 1;
    background: #fff;
}
.btn-gray:hover a {
    opacity: 1;
    color: #666 !important;
}
.btn-gray2 {
    background: #ADADAD;    
    box-shadow: 0 3px 1px 0px rgba(0,0,0,.15);
}
.btn-movie { 
	width: 30px;
	height: 3rem;
	margin-left: 10px;
}
.btn-cart, .btn-red {
	background: #BF1919;
	box-shadow: 0 3px 1px 0px rgba(0,0,0,.3);
}
.btn-movie img{ width: 20.5px; }

.btn-movie a { padding: 0.5rem !important; }


/* 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"] { 
	width: 70%;
	border: none;
	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: 190px;
	display: inline-block;
}
.required {
	color: #bf1919;
    display: inline-block;
    font-size: 22px;
    font-size: 2.2rem;
    font-weight: bold;
    margin: 0 3px 0 0;
    letter-spacing: 0.1rem;
	line-height: 1;
}
.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 #CDCDCC;
	border-radius: 100%;
}
input[type="radio"]:checked + label::after {
	position: absolute;
	content: '';
	top: 50%;
	left: 5px;
	width: 6px;
	height: 6px;
	margin-top: -3px;
	background: #65C7EB;
	border-radius: 100%;
}

/* セレクトメニュー */
.selectmenu {
   overflow:hidden;
   position: relative;
   border-radius: 5px;
   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;
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.4rem;
    padding: 0 58px 0 10px;
    border: 0;
    border-radius: 5px 8px 8px 5px;
    background: url(../img/common/arrow-pull.png) no-repeat 88% 65%, #fff;
    /* background-size: contain; */
    height: 4.4rem;
}
select::-ms-expand {
	display: none;
}
select {
  -moz-appearance: none;
  text-indent: 0.01px;
  text-overflow: '';
}

/* お知らせのカテゴリー色 */
.cate {
    padding: 0 1rem;
    display: inline-block;
    color: #333;
    letter-spacing: 0.1rem;
    min-width: 7.65rem;
    text-align: center;
}
.news .cate-1, .category-menu_main .cate-1 { background: #FFCB40; }
.news .cate-2, .category-menu_main .cate-2 { background-color: #FF8E2B; }
.news .cate-3, .category-menu_main .cate-3 { background-color: #C70235; }
.news .cate-4, .category-menu_main .cate-4 { background: #029C64; }
.news .cate-5, .category-menu_main .cate-5 { background-color: #00ADD4; }
.news .cate-6, .category-menu_main .cate-6 { background-color: #0270BF; }

/* 商品番号 */
.code {
	background: #FCF6E8;
	display: inline-block;
	padding: 5px 6px;
	margin: 3px 0;
	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 {
	background: #F0F0F0;
	padding: 0.8rem 0;
	white-space: nowrap;
	text-align: center;
	font-weight: bold;	
	min-width: 80px;
	border-left: 2px dotted #fff;
}
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; }
table.default tr,
.table-default .tr { border-bottom: 1px solid #E4E4D4; }

/* 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 {
    display: table-cell;
}
.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; }

/* ポイント */
.point {
    padding: 3rem;
    line-height: 2.6rem;
    background: #EEFBFE;
    border-radius: 5px;
}
.point h3 {
    margin-bottom: 3rem;
    padding: 0 2rem;
    padding-bottom: 0.5rem;
    text-align: center;
    color: #000000;
}
.point .caution { font-weight: 500; }
.point ol, .point ul { padding: 0 4rem; }
.point ol li, .point ul li { margin-top: 2rem; }
.point ul li { list-style: disc; }
#cart-input #onestop .point ol li::marker, 
#cart-input #onestop .point ol li span {
    color: #345BA0;
}
/* colorbox */
.colorbox {
    background: #F2F2F2;
    line-height: 2.6rem;
    border-radius: 5px;
    padding-bottom: 2rem;
}
.colorbox h3 {
    margin-top: 1rem;
    margin-bottom: 1rem;
    border-bottom: 2px solid;
    padding-bottom: 1.5rem;
    text-align: center;
}

/*=========================================
		header
=========================================*/


/* 注意事項 */
.note {
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 1.8;
	text-indent: -1em;
	padding-left: 1em;
}
.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; }*/

.caution-box.caution-box_blue {
    background: #EEFBFE;
    border: none;
	color: #000000;
}
.caution-box.caution-box_blue  h3 {
    color: #000000;
    border-bottom: none;
}
.caution-box ul li:marker { color: #345BA0; }


/*=========================================
		gnav
=========================================*/


/* 検索メニュー */
.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;
}

/*=========================================
		maincontent
=========================================*/
#thanks .caption { margin: 3rem 0 4rem; }



/* ページタイトル */
#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 #to_top {
	position: fixed;
	    bottom: 4rem;
    right: 40px;
	z-index: 9997;
	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;

}


/* フッターメニュー */


/*=========================================
		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
	=========================================*/
}

@media screen and (max-width: 1024px) and (min-width: 1000px){
}

@media screen and (min-width: 1000px) {
	.padsp { display: none !important; }
	.pad { display: none !important; }
	
	/*=========================================
			header
	=========================================*/

		
	/*=========================================
			gnav
	=========================================*/
	
	
	/*=========================================
			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;
	}
	
	/*=========================================
			maincontent
	=========================================*/
	#maincontent_wrap {
		
	}
	#maincontent {

	}
	#maincontent.no-side { 
		width: 100%;
		padding: 0;
	}
	.main-2col #maincontent {
		width: calc(100% - 167px);
		padding: 0 0 0 20px;
	}	

	/*=========================================
			footer
	=========================================*/	
}

@media screen and (max-width: 999px) {		
	.pc { display: none !important; }
	
	/* 文字 */
	/*html{
		font-size: 60%;
		line-height: 1.7;
	}
	body{font-size: 1.4rem;}*/
	.td { display: block; }
	/* 余白 */
	.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%; }		
	.btn_wrap.col-2 .btn {
    width: 100% !important;
}
	/* 生年月日 */
	#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; }
	
	.btn_style01 {
    width: 100%;
}
	section > .btn_style01 {
    width: 90%;
    }
	
	/* シェアボタン */
	#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; }
	
	/* 注意事項 */
	.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;
		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;
		text-align: left;
	}
	
	/*=========================================
			header
	=========================================*/

	/*=========================================
			gnav
	=========================================*/

	
	/* 検索メニュー */
	#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%;
	}	
	#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
	=========================================*/		

}

@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% - 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
	=========================================*/
	
	/*=========================================
			gnav
	=========================================*/

	
	/*=========================================
			parts
	=========================================*/
	/* ページャー */
	.pager_wrap { padding-top: 0.3rem !important; }
	
	/* ステップ */
	.cd-multi-steps.count li:last-of-type { width: 105px; }
	
	/* ステップ */
	.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
	=========================================*/	
}

@media screen and (min-width: 481px) {	
	.sp { display: none !important; }
	
	/*=========================================
			header
	=========================================*/
	#sitename a p:first-of-type { margin-right: 5px; }

		
	/*=========================================
			footer
	=========================================*/
}

@media screen and (max-width: 480px) {
	body {
    font-size: 3.4vw;
}
	p {
    letter-spacing: 0.1vw;
    font-size: 3.35vw;
}
	/* 文字 */
	h3 {
    font-size: 4.5vw;
}
	h5 {
    font-size: 3.65vw;
}
	.t-12 {
    font-size: 2.8vw;
}
	.t-14 {
    font-size: 3vw;
}
	.t-16 {
    font-size: 3.3vw;
}
	.t-18 {
    font-size: 3.65vw;
}
	.t-20 {
    font-size: 4vw;
}
	.pcpad { display: none !important; }
	.pad { display: none !important; }
	
	.td { display: block; }
	.table-abs .td { display: table-cell; }
	.font_en {
    letter-spacing: 0.25vw;
}
	/* カラム */
	.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; }
	
	.wide1400 {
    margin: 8vw auto;
}
	
	.point {
    padding: 1rem;
}
	.point ol, .point ul {
    padding: 0px 1rem;
}

	.thanks-comment {
    font-size: 4.2vw;
}
	
	/*=========================================
			header
	=========================================*/



	
	/*=========================================
			gnav
	=========================================*/

	
	/*=========================================
			parts
	=========================================*/	
	/* ステップ */
	.cd-multi-steps { padding: 1rem; }
	.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; }
	
	/* ボタン */

	
	ul.list01 li {
    font-size: 3.4vw;
}
	
	/* テーブル */
	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 dotted #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%;
	}
		
	/*=========================================
			footer
	=========================================*/	
	
	/* トップへボタン */
	footer #to_top { 
		right: 10px;
		bottom: 10px;
	}
	footer #to_top:hover {
		bottom: 2rem;
	}	
}

@media screen and (max-width: 320px) {
	#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
	=========================================*/	
}

