@charset "utf-8";

* {
	zoom:1;
	-moz-box-sizing:border-box;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
}

/* body
----------------------------------------------- */
body{
	/*font-family:Noto Sans JP, sans-serif;*/
	/* font-family:source han sans,sans-serif; */
	font-family:Zen Kaku Gothic New,sans-serif;
	/*position:relative;*/
	font-size:16px;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-variation-settings:"wdth" 100;
}

img {vertical-align:bottom;}
ul li {line-height:1.2; list-style:none;}
dl dt, dl dd {line-height:1.2;}
address {font-style:normal; line-height:1.2;}
a{
	text-decoration: none;
	color: #000;
}

html,body{
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: top;
	background: transparent;
}
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre, strong, 
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
input,textarea,select,label,
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section,
table, caption, tbody, tfoot, thead, tr, th, td {
	/* 幅に余白や罫線も含める */
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	font-size: inherit;
	line-height:inherit;
	-webkit-text-size-adjust: 100%;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
	display:block;
	margin:0px;
	padding:0px;
}
dl,dt,dd{
	margin:0px;
	padding:0px;
	
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
	margin-block-start: 0;
	margin-block-end: 0;
	margin-inline-start: 0;
	margin-inline-end: 0;
	padding-inline-start: 0;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table,tr,tbody,thead,tfoot,th,td{
	font-size: inherit;
	line-height:inherit;
	vertical-align:top;
}
select, input, textarea, button {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	font-size: inherit;
	font-family: inherit;
	margin: 0;
	vertical-align: bottom;
	letter-spacing: inherit;
}
/* remember to define focus styles! */
:focus {
	outline: 0;
}

/* remember to highlight inserts somehow! */
ins {
	text-decoration: none;
}
del {
	text-decoration: line-through;
}

/* tables still need 'cellspacing=0' in the markup */
table {
	border-collapse: collapse;
	border-spacing: 0;
}
p{
	margin:0;
	padding:0;
}
.alignleft{
	float:left;
}
.alignright{
	float:right;
}

/*****************/
body, html {
  width: auto; /* 明示的に100%や100vwを使わない */
  max-width: 100%;
}

.header, .main, .footer {
  max-width: 100%;
  box-sizing: border-box;
}
h1,
h2,
h3,
h4,
h5,
h6{
	margin:0;
	padding:0;
	font-weight:400;
}