@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+1p&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&display=swap');
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, p, blockquote, th, td, form, fieldset, legend {
	margin:0;
	padding:0;
}
article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary,section { 
	display:block;
}
html {
	background: #fff;
	font-size: 62.5%;
	overflow: auto;
}

body {
	min-width: 320px;
	background: #fff;
	color:#2c3034;
	-webkit-text-size-adjust: none;
	font-size: 62.5%;
    line-height: 1.8;
	box-sizing: border-box;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
	overflow: hidden;
	-webkit-text-size-adjust: 100%;
	letter-spacing: .1em;
	
}
@media all and (min-width: 1023px) {
	body {
		min-width: 1100px;
		font-size: 1.8rem;
	}
}

h1 {
    font-size: clamp(2.4rem, calc(2.2rem + 0.625vw), 2.9rem);
    line-height: 1.8;
}
h2 {
    font-size: clamp(2.0rem, calc(1.8rem + 0.625vw), 2.5rem);
    line-height: 1.8;
	letter-spacing: 0.1em;
}
h3 {
    font-size: clamp(1.4rem, calc(1.2rem + 0.625vw), 1.9rem);
    line-height: 1.8;
	letter-spacing: 0.1em;
}
h4 {
    
    font-size: clamp(1.4rem, calc(1.2rem + 0.625vw), 1.9rem);
	line-height: 1.8;
}
h5 {
    font-size: clamp(1.4rem, calc(1.2rem + 0.625vw), 1.9rem);
    line-height: 1.8;
}
p,li,th,td,dl {
    font-size: clamp(1.1rem, calc(0.9rem + 0.625vw), 1.6rem);
    line-height: 1.8;
}

a,a:link {
	color: inherit;
	text-decoration: none;
}
a:hover, a:active {
	text-decoration:none;
}

ul, ol {
	list-style: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
	font-size: 100%;
	font-family: inherit;
	line-height: 1.2;
	empty-cells: show;
}
caption, th, td {
	/* vertical-align: top; */
}
fieldset {
	border: none;
}
input, textarea, select, label {
	margin-top: 0;
	margin-bottom: 0;
	padding-top: 0;
	padding-bottom: 0;
	font-size: 100%;
	font-family: inherit;
	vertical-align: middle;
}
label {
	cursor: pointer;
}
textarea {
	overflow: auto;
}
button,input[type="button"],input[type="submit"]{
	font-family: inherit;
	padding:0;
	line-height: 1.5;
    box-sizing: content-box;
    -webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    -ms-box-sizing: content-box;
    -o-box-sizing: content-box;
    border-radius: 0;
    -webkit-appearance: none;
	cursor:pointer;
}
input[type="search"], input[type="txt"], input[type="submit"]{
	-webkit-appearance: none;
    border-radius: 0;
    box-sizing: content-box;
    -webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    -ms-box-sizing: content-box;
    -o-box-sizing: content-box;
}
button:focus{
	outline:none;
}
img {
	border: none;
	vertical-align: bottom;
	-ms-interpolation-mode: bicubic;
	max-width: 100%;
	height: auto
}
object {
	vertical-align: middle;
	outline: none;
}
em, strong {
	font-weight: bold;
	font-style: normal;
}
abbr, acronym {
	border: none;
	font-variant: normal;
}
q:before, q:after {
	content: '';
}
address, caption, cite, code, dfn, var {
	font-weight: normal;
	font-style: normal;
}
code, pre {
	font-family: monospace;
}
sup {
	vertical-align: text-top;
}
sub {
	vertical-align: text-bottom;
}
hr {
	height:0;
	margin:25px 0;
	border:none;
	border-top:1px dotted #ccc;
}
*:first-child + html body, *:first-child + html br {
	letter-spacing: 0;
}