*,
*::before,
*::after {
	box-sizing: border-box;
}

/* Remove default padding */

ul,
ol {
	padding: 0;
}

/* Remove default margin */

body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
figure,
blockquote,
dl,
dd {
	margin: 0;
}

body.modal-open {
	overflow: hidden;
  }
/* Set core root defaults */

/* html {
	scroll-behavior: smooth;
} */
/* Natural flow and rhythm in articles by default */

article > * + * {
	margin-top: 1em;
}

/* Inherit fonts for inputs and buttons */

input,
button,
textarea,
select {
	font: inherit;
}

/* Blur images when they have no alt attribute */

/* フォームリセット */

input,
button,
select,
textarea {
	/* -webkit-appearance: none;
	-moz-appearance: none;
	appearance: none; */
	background: transparent;
	border: none;
	border-radius: 0;
	font: inherit;
	outline: none;
}

textarea {
	resize: vertical;
}

/* input[type=checkbox],
input[type=radio] {
	display: none;
} */

input[type=submit],
input[type=button],
label,
button,
select {
	cursor: pointer;
}

select::-ms-expand {
	display: none;
}

body {
	line-height: 1.9;
	min-height: 100vh;
	text-rendering: optimizeSpeed;
	font-weight: 400;
	font-style: normal;
	font-family: "PT Serif Caption", serif;
	background-color: #E9E9E9;
}
body.is-fixed{
	position: fixed;
	top: 0;
	left: 0;
}
/* Remove list styles on ul, ol elements with a class attribute */

ul {
	list-style: none;
}

/* A elements that don't have a class get default styles */

a:not([class]) {
	-webkit-text-decoration-skip: ink;
	text-decoration-skip-ink: auto;
}

/* Make images easier to work with */

img {
	display: block;
	max-width: 100%;
	width: 100%;
}

