@charset "UTF-8";

html {
	width: 100%;
	height: 100%;
	color: #333;
	margin: 0;
	padding: 0;
	font-feature-settings: "palt" 1;
}
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td,figure {
	margin: 0;
	padding: 0;
}

body{
	font-size: 14px;
	font-family: "游ゴシック体", YuGothic, "游ゴシック","Yu Gothic","メイリオ",Meiryo,"Verdana",sans-serif;
	line-height: 1.43;
	counter-reset:number;
	height: 100%;
	-webkit-text-size-adjust: none;
}

table {
	font: 100%;
	font-size: inherit;
	border-collapse: collapse;
	border-spacing: 0;
}
caption,th { text-align:left; }

fieldset,img { border: 0;}

h1,h2,h3,h4,h5,h6 {
	font-size: 100%;
	font-weight: normal;
}
address,caption,cite,code,dfn,em,th,var {
	font-style: normal;
	font-weight: normal;
}
ol,ul { list-style: none;}

q:before,q:after { content:'';}
abbr,acronym {
	border: 0;
	font-variant: normal;
}
sup { vertical-align: text-top; }
sub { vertical-align: text-bottom;}
input,textarea,select {
	font-family: inherit;
	font-size: inherit;
	font-weight: inherit;
	outline: 0;
}
legend{ color:#555;}

div,select,ul,li,a,input,button,textarea{ font-family: "source-han-sans-japanese", YuGothic, "游ゴシック","Yu Gothic","メイリオ",Meiryo,"ＭＳ Ｐゴシック","Verdana",sans-serif; font-weight: 400;}

.font_primary{
	font-family: "source-han-sans-japanese", YuGothic, "游ゴシック","Yu Gothic","メイリオ",Meiryo,"ＭＳ Ｐゴシック","Verdana",sans-serif;
	font-weight: 700;
}
.font_secondary{
	font-family: "futura-pt", sans-serif;
	font-weight: 500;
	font-style: normal;
}
.font_tertiary{
	font-family: "futura-pt-bold", sans-serif;
	font-weight: 700;
	font-style: normal;
}

pre,code,kbd,samp,tt{
	font-family: monospace;
	line-height: 100%;
}

main { display: block; }

a {
	color: #333;
	outline: none;
	text-decoration: none;
}
/* a:hover {
	text-decoration: none;
	opacity: 0.7;
	filter:alpha(opacity=70);
	-moz-opacity: 0.7;
} */
a:focus { text-decoration: none; }
a:active { text-decoration: none; }

a img { border: none; }

li img,
dt img,
dd img{ vertical-align: top; }

button::-moz-focus-inner,
input::-moz-focus-inner {
	border: 0;
	padding: 0;
}

html, body {
	height: 100%;
	text-align: justify;
	text-justify: inter-ideograph;
}
body { -webkit-text-size-adjust: 100%; }

.clear { clear: both; }
.cf:after {
	content: "";
	display: block;
	clear: both;
}

@media screen and (min-width:769px), print{ .sp { display: none !important; } }
@media screen and (max-width:768px){ .pc { display: none !important; } }

/* 共通スタイル */
@media screen and (min-width:769px), print{
	/* PC版スタイル */
}
@media screen and (max-width:768px){
	/* SP版スタイル */
}