
.cf:before, .cf:after{
	content=" ";
	clear: both;
	display: block;
}

.toplogo {
	display: block;
	margin: 6px auto;
	max-width: 165px;
	vertical-align: middle;
}

.toplogo img {
	width: 100%;
}

.topbtn{
	margin: 0 auto;
	vertical-align: middle;
	padding: 0 30px;
}

.topbtn ul {
	width: 100%;
	display: table;
	list-style: none;
}

.topbtn ul li {
	width: 50%;
	table-layout: fixed;
	display: table-cell;
	vertical-align: middle;
	background: #ffffff; /* Old browsers */
	background: -moz-linear-gradient(top,  #ffffff 0%, #f4f4f4 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ffffff), color-stop(100%,#f4f4f4)); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(top,  #ffffff 0%,#f4f4f4 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(top,  #ffffff 0%,#f4f4f4 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(top,  #ffffff 0%,#f4f4f4 100%); /* IE10+ */
	background: linear-gradient(to bottom,  #ffffff 0%,#f4f4f4 100%); /* W3C */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#f4f4f4',GradientType=0 ); /* IE6-9 */
	text-align: center;
	box-sizing: border-box;
}

.topbtn ul li:nth-child(1){
	border-top-left-radius: 10px;
	border-bottom-left-radius: 10px;
	border: 1px solid #d5d5d5;
}

.topbtn ul li:nth-child(2){
	border: 1px solid #d5d5d5;
	border-top-right-radius: 10px;
	border-bottom-right-radius: 10px;
	border-left: 0px;
}

.topbtn ul li a {
	display: block;
	padding: 10px 0;
	font-size: 12px;
	font-weight: bold;
	text-decoration: none;
}




.designermenu  {
	max-width:100%;
	margin: 0 auto;
	z-index:1000;
	width:100%;
	border-top: 2px solid #fb8b1a;
/*	border-left: 5px solid #fb8b1a;*/
}

.designermenu_ul {
	display: table;
	table-layout: fixed;
	width: 100%;
	list-style: none;
}

.designermenu li{
	vertical-align: middle;
	width: 50%;
	display: table-cell;
	list-style: none;
	background:#333333;
	border-bottom: 1px dotted #e6e6e6;
	border-right: 1px dotted #e6e6e6;
	box-sizing: border-box;
	background: #fff4dd;
}

.designermenu li a{
	position: relative;
	display:block;
	margin:0;
	padding:10px 6px;
	background: #FFFFFF;
/*	color: #666666;*/
	color: #fb8b1a;
/*	font-weight: bold;*/
	text-decoration:none;
	background: #fff4dd;
}

.designermenu li a:before{
	display:block;
	content:"";
	position: absolute;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 50%;
	right:8px;
	width:10px;
	height:10px;
	margin-top:-5px;
	background:#fb8b1a;
}

.designermenu li a:after{
	display: block;
	content:"";
	position:absolute;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 50%;
	right: 12px;
	width: 10px;
	height: 10px;
	margin-top: -5px;
	background: #fff4dd;
}





.materialmenu {
	max-width:100%;
	margin: 0 auto;
	z-index:1000;
	width:100%;
	border-top: 2px solid #698d1d;
/*	border-left: 5px solid #698d1d;*/
}

.materialmenu_ul {
	display: table;
	table-layout: fixed;
	width: 100%;
	list-style: none;
}

.materialmenu li{
	vertical-align: middle;
	width: 50%;
	display: table-cell;
	list-style: none;
	background:#333333;
	border-bottom: 1px dotted #e6e6e6;
	border-right: 1px dotted #e6e6e6;
	box-sizing: border-box;
	background: #eff5de;
}

.materialmenu li a{
	position: relative;
	display:block;
	margin:0;
	padding:10px 6px;
	background: #FFFFFF;
/*	color: #666666;*/
	color: #698d1d;
/*	font-weight: bold;*/
	text-decoration:none;
	background: #eff5de;
}

.materialmenu li a:before{
	display:block;
	content:"";
	position: absolute;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 50%;
	right:8px;
	width:10px;
	height:10px;
	margin-top:-5px;
	background:#698d1d;
}

.materialmenu li a:after{
	display: block;
	content:"";
	position:absolute;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 50%;
	right: 12px;
	width: 10px;
	height: 10px;
	margin-top: -5px;
	background: #eff5de;
}





.giftmenu {
	max-width:100%;
	margin: 0 auto;
	z-index:1000;
	width:100%;
	border-top: 2px solid #cf475d;
/*	border-left: 5px solid #cf475d;*/
}

.giftmenu_ul {
	display: table;
	table-layout: fixed;
	width: 100%;
	list-style: none;
}

.giftmenu li{
	vertical-align: middle;
	width: 50%;
	display: table-cell;
	list-style: none;
	background:#333333;
	border-bottom: 1px dotted #e6e6e6;
	border-right: 1px dotted #e6e6e6;
	box-sizing: border-box;
	background: #fff0f0;
}

.giftmenu li a{
	position: relative;
	display:block;
	margin:0;
	padding:10px 6px;
	background: #FFFFFF;
/*	color: #666666;*/
	color: #cf475d;
/*	font-weight: bold;*/
	text-decoration:none;
	background: #fff0f0;
}

.giftmenu li a:before{
	display:block;
	content:"";
	position: absolute;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 50%;
	right:8px;
	width:10px;
	height:10px;
	margin-top:-5px;
	background:#cf475d;
}

.giftmenu li a:after{
	display: block;
	content:"";
	position:absolute;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 50%;
	right: 12px;
	width: 10px;
	height: 10px;
	margin-top: -5px;
	background: #fff0f0;
}

















.topbanner{
	width: 100%;
	min-width: 320px;
}

.banner01{
	max-width: 616px;
	margin: 0 auto 6px;
	padding: 0 6px;
}

.banner01 img{
	width: 100%;
}

.banner02{
	max-width: 628px;
	margin: 0 auto;
}

.banner02 ul{
	display: table;
	table-layout: fixed;
	list-style: none;
	margin: 0 auto 6px;
	border-collapse: separate;
	border-spacing: 6px 0;
}

.banner02 ul li{
	max-width: 100%;
	display: table-cell;
	vertical-align: middle;
}

.banner02 img{
	width: 100%;
}

.footer{
	font-family:inherit;
	font-weight:bold;
	color:inherit;
	line-height: 40px;
	text-align: center;
	margin-right: auto;
	margin-left: auto;
	margin-top: auto;
	margin-bottom: auto;
	width:100%;
	height:40px;
	background: #F5F5F5; 
	/*
	background: -moz-linear-gradient(top,  #ffffff 0%, #e5e5e5 100%); 
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ffffff), color-stop(100%,#e5e5e5)); 
	background: -webkit-linear-gradient(top,  #ffffff 0%,#e5e5e5 100%); /
	background: -o-linear-gradient(top,  #ffffff 0%,#e5e5e5 100%); /
	background: -ms-linear-gradient(top,  #ffffff 0%,#e5e5e5 100%); 
	background: linear-gradient(to bottom,  #ffffff 0%,#e5e5e5 100%); 
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#e5e5e5',GradientType=0 ); 
	*/
	border-top: 1px solid #e6e6e6;
	border-bottom: 1px solid #e6e6e6;
	box-sizing: border-box;
}

.next{
	text-align:center;
	font-family:inherit;
	font-weight:500;
	line-height:1.1;
	color:inherit;
	font-size:17px;
	line-height:20px;
	color:#FFFFFF;
	width:80%;
	margin: 15px 0px;
/*	background: #ff8cb5;*/
	background: #A2384F;
/*	border: 1px solid #DDD;*/
	border: 1px solid #711f32;
	border-radius: 8px;
	-moz-border-radius: 8px;
	-webkit-border-radius: 8px;
	padding: 6px 0;
}

.title{
	font-family:inherit;
	font-weight:bold;
	color:inherit;
	line-height: 40px;
	text-align: center;
	margin-right: auto;
	margin-left: auto;
	margin-top: 10px;
	margin-bottom: 0px;
	width:100%;
	height:40px;
	background: #ffe8df; 
	border-top: 2px solid #A2384F;
	border-bottom: 1px solid #e9c9c5;
	box-sizing: border-box;
}

.privilege{
	text-align: left;
	margin-right: auto;
	margin-left: auto;
	margin-top: 10px;
	margin-bottom: 0px;
	padding: 0 14px;
}

.privilege span{
	font-weight:bold;
}

.privilege img{
	display: block;
	margin: 0 auto;
}

.menu{
	font-family:inherit;
	font-weight:bold;
	color:inherit;
	color:#FFFFFF;
	line-height: 30px;
	text-align: center;
	margin-right: auto;
	margin-left: auto;
	margin-top: 10px;
	margin-bottom: 10px;
	width:100%;
	height:30px;
	
	background: #cc3366; /* Old browsers */
	background: -moz-linear-gradient(top,  #cc3366 0%, #a43850 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#cc3366), color-stop(100%,#a43850)); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(top,  #cc3366 0%,#a43850 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(top,  #cc3366 0%,#a43850 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(top,  #cc3366 0%,#a43850 100%); /* IE10+ */
	background: linear-gradient(to bottom,  #cc3366 0%,#a43850 100%); /* W3C */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#cc3366', endColorstr='#a43850',GradientType=0 ); /* IE6-9 */
	box-sizing: border-box;
}

/*
marqueeは一部のブラウザでしか動作しないのでCSSで対応する場合は下記を使用
<div id="marquee">
	<div><?= $topic ?></div>
</div>
*/
#marquee{
	overflow:hidden;
}
#marquee div{
	width:100%;
	text-align:center;
	display:inline-block;
	white-space:nowrap;

	-moz-animation-duration: 30s;
	-moz-animation-name: marquee;
	-moz-animation-iteration-count: infinite;
	-moz-animation-timing-function: linear;

	-webkit-animation-duration: 20s;
	-webkit-animation-name: marquee;
	-webkit-animation-iteration-count: infinite;
	-webkit-animation-timing-function: linear;

	-ms-animation-duration: 20s;
	-ms-animation-name: marquee;
	-ms-animation-iteration-count: infinite;
	-ms-animation-timing-function: linear;

	-o-animation-duration: 20s;
	-o-animation-name: marquee;
	-o-animation-iteration-count: infinite;
	-o-animation-timing-function: linear;
}
@-webkit-keyframes marquee {
	from {margin-left: 100%; width: 100%; }
	to { margin-left: -500%; width: 100%; }
}
@-moz-keyframes marquee {
	from {margin-left: 100%; width: 100%; }
	to { margin-left: -500%; width: 100%; }
}
@-ms-keyframes marquee {
	from {margin-left: 100%; width: 100%; }
	to { margin-left: -500%; width: 100%; }
}
@-o-keyframes marquee {
	from {margin-left: 100%; width: 100%; }
	to { margin-left: -500%; width: 100%; }
}

.submenu_gift {
	max-width:100%;
	margin: 0 auto;
	z-index:1000;
	width:100%;
	border-top: 1px solid #e6e6e6;
}

.submenu_gift_ul {
	display: table;
	table-layout: fixed;
	width: 100%;
	list-style: none;
}

.submenu_gift li{
	vertical-align: middle;
	width: 50%;
	display: table-cell;
	list-style: none;
	background:#333333;
	/*border-top: 1px solid #e6e6e6;*/
	border-bottom: 1px solid #e6e6e6;
	border-right: 1px solid #e6e6e6;
	box-sizing: border-box;

	background: #ffffff; /* Old browsers */
	background: -moz-linear-gradient(top,  #ffffff 0%, #f4f4f4 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ffffff), color-stop(100%,#f4f4f4)); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(top,  #ffffff 0%,#f4f4f4 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(top,  #ffffff 0%,#f4f4f4 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(top,  #ffffff 0%,#f4f4f4 100%); /* IE10+ */
	background: linear-gradient(to bottom,  #ffffff 0%,#f4f4f4 100%); /* W3C */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#f4f4f4',GradientType=0 ); /* IE6-9 */
}

.submenu_gift li a{
	position: relative;
	display:block;
	margin:0;
	padding:6px 6px;
	background: #FFFFFF;
/*	color: #ffffff;*/
	font-weight: bold;
	text-decoration:none;
	
	background: #ffffff; /* Old browsers */
	background: -moz-linear-gradient(top,  #ffffff 0%, #f4f4f4 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ffffff), color-stop(100%,#f4f4f4)); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(top,  #ffffff 0%,#f4f4f4 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(top,  #ffffff 0%,#f4f4f4 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(top,  #ffffff 0%,#f4f4f4 100%); /* IE10+ */
	background: linear-gradient(to bottom,  #ffffff 0%,#f4f4f4 100%); /* W3C */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#f4f4f4',GradientType=0 ); /* IE6-9 */
	
}

.submenu_gift li a:before{
	display:block;
	content:"";
	position: absolute;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 50%;
	right:8px;
	width:10px;
	height:10px;
	margin-top:-5px;
	background:#A2384F;
}

.submenu_gift li a:after{
	display: block;
	content:"";
	position:absolute;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 50%;
	right: 12px;
	width: 10px;
	height: 10px;
	margin-top: -5px;
	background: #FFFFFF;
	
	background: #FCFCFC; /* Old browsers */
	background: -moz-linear-gradient(top,  #FCFCFC 0%, #F7F7F7 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#FCFCFC), color-stop(100%,#F7F7F7)); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(top,  #FCFCFC 0%,#F7F7F7 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(top,  #FCFCFC 0%,#F7F7F7 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(top,  #FCFCFC 0%,#F7F7F7 100%); /* IE10+ */
	background: linear-gradient(to bottom,  #FCFCFC 0%,#F7F7F7 100%); /* W3C */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#FCFCFC', endColorstr='#F7F7F7',GradientType=0 ); /* IE6-9 */
}

.listthumb {
	display: table-cell;
	vertical-align: middle;
	width: 42px;
}

.listthumb p{
	display: block;
	width: 42px;
	height: 42px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	table-layout: fixed;
}

.listtext{
	font-size: 12px;
	padding-left: 8px;
	padding-right: 19px;
	font-weight: bold;
	text-decoration:none;
	display: table-cell;
	vertical-align: middle;
}

.submenu {
	max-width:100%;
	margin: 0 auto;
	z-index:1000;
	width:100%;
}

.submenu_ul {
	list-style: none;
 	min-height:1px;
}

.submenu li{
	list-style: none;
	width:100%;
	float:left;
	display:inline;
	background:#333333;
/*	border-top: 1px solid #e6e6e6;*/
	border-bottom: 1px solid #e6e6e6;
}

.submenu li a{
	position: relative;
	display:block;
	margin:0;
	padding:10px;
	background: #FFFFFF;
/*	color: #ffffff;*/
	font-weight: bold;
	text-decoration:none;
	
	background: #ffffff; /* Old browsers */
	background: -moz-linear-gradient(top,  #ffffff 0%, #f4f4f4 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ffffff), color-stop(100%,#f4f4f4)); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(top,  #ffffff 0%,#f4f4f4 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(top,  #ffffff 0%,#f4f4f4 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(top,  #ffffff 0%,#f4f4f4 100%); /* IE10+ */
	background: linear-gradient(to bottom,  #ffffff 0%,#f4f4f4 100%); /* W3C */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#f4f4f4',GradientType=0 ); /* IE6-9 */
	
}

.submenu li a:before{
	display:block;
	content:"";
	position: absolute;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 50%;
	right:8px;
	width:10px;
	height:10px;
	margin-top:-5px;
	background:#A2384F;
}

.submenu li a:after{
	display: block;
	content:"";
	position:absolute;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 50%;
	right: 12px;
	width: 10px;
	height: 10px;
	margin-top: -5px;
	background: #FFFFFF;
	
	background: #FCFCFC; /* Old browsers */
	background: -moz-linear-gradient(top,  #FCFCFC 0%, #F7F7F7 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#FCFCFC), color-stop(100%,#F7F7F7)); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(top,  #FCFCFC 0%,#F7F7F7 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(top,  #FCFCFC 0%,#F7F7F7 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(top,  #FCFCFC 0%,#F7F7F7 100%); /* IE10+ */
	background: linear-gradient(to bottom,  #FCFCFC 0%,#F7F7F7 100%); /* W3C */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#FCFCFC', endColorstr='#F7F7F7',GradientType=0 ); /* IE6-9 */
}





.footermenu {
	max-width:100%;
	margin: 0 auto;
	z-index:1000;
	width:100%;
/*	border-top: 1px dotted #e6e6e6;*/
}

.footermenu_ul {
	display: table;
	table-layout: fixed;
	width: 100%;
	list-style: none;
}

.footermenu li{
	vertical-align: middle;
	width: 50%;
	display: table-cell;
	list-style: none;
	background:#333333;
	border-bottom: 1px dotted #e6e6e6;
	border-right: 1px dotted #e6e6e6;
	box-sizing: border-box;
	background: #FAFAFA;
}

.footermenu li a{
	position: relative;
	display:block;
	margin:0;
	padding:10px 6px;
	background: #FFFFFF;
	color: #666666;
/*	font-weight: bold;*/
	text-decoration:none;
	background: #FAFAFA;
}

.footermenu li a:before{
	display:block;
	content:"";
	position: absolute;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 50%;
	right:8px;
	width:10px;
	height:10px;
	margin-top:-5px;
	background:#CCCCCC;
}

.footermenu li a:after{
	display: block;
	content:"";
	position:absolute;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 50%;
	right: 12px;
	width: 10px;
	height: 10px;
	margin-top: -5px;
	background: #FAFAFA;
}