@charset "utf-8";
/*----------------------------------------------------------------------------------------------------
	リセット及びbody初期設定 (このCSSは通常変更しない)
----------------------------------------------------------------------------------------------------*/

/* Style Reset(html5) */

html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,
big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,
dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,
aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,
summary,time,mark,audio,video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	vertical-align: baseline;
}
main{
	display: block;
}
ol,ul {
	list-style: none;
}
blockquote,
q {
	quotes: none;
}
blockquote:before,
blockquote:after,
q:before,
q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
	vertical-align: top;
}
address {
	font-style: normal;
}
caption,
th,
td {
	font-weight: normal;
	text-align: left;
}

a:focus {
	outline: thin dotted;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
nav,
section {
	display: block;
}
audio,
canvas,
video {
	display: inline-block;
}
audio:not([controls]) {
	display: none;
}
del {
	color: #333;
}
ins {
	background: #fff9c0;
	text-decoration: none;
}
hr {
	border: 0;
	height: 1px;
	border-bottom: 1px solid #ccc;
}
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}
button{
	border: none;
	background: none;
	display: block;
	cursor:pointer;
}
textarea,
input {
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
sup {
	top: -0.5em;
}
sub {
	bottom: -0.25em;
}
small {
	font-size: smaller;
}

button,
a {
	text-decoration:none;
	opacity: 1.0;
	transition: opacity 400ms cubic-bezier(0.26, 0.06, 0, 1), color 400ms cubic-bezier(0.18, 0.06, 0.23, 1), background-color 400ms cubic-bezier(0.18, 0.06, 0.23, 1), border-color 400ms cubic-bezier(0.18, 0.06, 0.23, 1), box-shadow 400ms cubic-bezier(0.26, 0.06, 0, 1);


}
button:hover,
a:hover{
}



html {
	/*overflow-y: scroll;*/
	font-size: 100%;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
}

/*　画像
---------------------------------------------------------------------------------------*/
img{
	border:0px none;
	margin:0;
	padding:0;
	border: 0;
	vertical-align: middle;
	-ms-interpolation-mode: bicubic;
	max-width: 100%;
	height: auto;
	image-rendering: -webkit-optimize-contrast;
}

/*　body
---------------------------------------------------------------------------------------*/
body {
	word-break: break-all;
	line-break: strict;
	word-break: normal !important;
	word-wrap: break-word;
}
h1,h2,h3,h4,h5,h6{
  font-weight: normal;
}

/*　clearfix
---------------------------------------------------------------------------------------*/
.clr:after {
	content: " ";
	display: block;
	height: 0;
	line-height: 0;
	clear: both;
	visibility: hidden;
}

.clr {
	display: inline-block;
	min-height: 1%;
}

/* Hides from IE-mac \*/

* html .clr {
	height: 1%;
}

.clr {
	display: block;
}
/* End hide from IE-mac */


a:focus, *:focus {
 outline:none;
}

/*　form
---------------------------------------------------------------------------------------*/

form{
	display: inline;
}

select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    outline: none;
    background: transparent;
    background-position: 100% 50%;
    background-repeat: no-repeat;
    padding: 0;
    font-size: 16px;
    border: 0; 
    border-radius: 0;       
}
select::-ms-expand {
    display: none;
}

textarea {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    resize: none;
    padding: 0;
    border: 0;
    outline: none;
    background: transparent;
    font-size: 16px;
    border-radius: 0;

}

input[type="text"],
input[type="number"],
input[type="time"],
input[type="week"],
input[type="month"],
input[type="date"],
input[type="datetime"],
input[type="password"],
input[type="email"],
input[type="url"],
input[type="tel"],
input[type="search"]{
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    resize: none;
    border: 0;
    outline: none;
    background: transparent;
    border-radius: 0;
}


*{
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.noBar{
 -ms-overflow-style: none; /* IE対策 */
 scrollbar-width: none;
}
.noBar::-webkit-scrollbar { /* Google Chrome対策 */
 display: none;
}



/*---------------------------------------------------------
	スマホ
---------------------------------------------------------*/

html body .sp-block,html body .sp-inline,html body .sp-inlineB,html body .sp-flex{
	display: none;
}

@media only screen and (max-width: 767px) {

  html body .sp-none{
    display: none;
  }
  html body .sp-block{
    display: block;
  }  
  html body .sp-flex {
    display: flex;
  }  
  html body .sp-inline {
    display: inline;
  }
  html body .sp-inlineB {
    display: inline-block;
  }  
  html body .sp-brNone br{
    display: none;
  }


}