@charset "UTF-8";

/*! normalize.css v6.0.0 | MIT License | github.com/necolas/normalize.css */

html {
  line-height: 1.15;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

article,
aside,
footer,
header,
nav,
section {
  display: block;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

figcaption,
figure,
main {
  display: block;
}

figure {
  margin: 1em 40px;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

pre {
  font-family: monospace, monospace;
  font-size: 1em;
}

a {
  background-color: transparent;
  -webkit-text-decoration-skip: objects;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

b,
strong {
  font-weight: inherit;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

dfn {
  font-style: italic;
}

mark {
  background-color: #ff0;
  color: #000;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

audio,
video {
  display: inline-block;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

img {
  border-style: none;
}

svg:not(:root) {
  overflow: hidden;
}

button,
input,
optgroup,
select,
textarea {
  margin: 0;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

[type=reset],
[type=submit],
button,
html [type=button] {
  -webkit-appearance: button;
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring,
button:-moz-focusring {
  outline: 1px dotted ButtonText;
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  display: inline-block;
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  padding: 0;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

details,
menu {
  display: block;
}

summary {
  display: list-item;
}

canvas {
  display: inline-block;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

/**
 * width や height がパディングやボーダーに依存しないようにする
 */

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

/**
 * デフォルトのマージンを削除
 */

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 1em;
  margin: 0;
}

/**
 * IE6/7 で 2 つ個以上の連続した br タグは無視するバグに対応
 */

br {
  letter-spacing: 0;
}

/**
 * デフォルトのマージンを削除
 */

p,
blockquote,
dl,
dd,
figure {
  margin: 0;
}

/**
 * 行が長くなると改行させる
 * デフォルトのマージンを削除
 */

pre {
  white-space: pre-wrap;
  word-wrap: break-word;
  margin: 0;
}

/**
 * デフォルトのマージンを削除
 */

ol,
ul {
  padding: 0;
  margin: 0;
}

/**
 * デフォルトのマージンを削除
 */

li {
  list-style: none;
}

/**
 * フォントのサイズを統合
 */

button,
input,
optgroup,
select,
textarea {
  font-size: 1em;
}

/**
 * マージンとボーダーを削除
 */

fieldset {
  border: 0;
  padding: 0;
  margin: 0;
}

/**
 * Chrome で selectbox の background-color を継承しない対策
 */

select {
  background-color: inherit;
  line-height: inherit;
}

/**
 * セルの文字寄せをリセット
 */

th,
td {
  text-align: left;
}

/**
 * 文字寄せをリセット
 * 余白を削除
 */

caption {
  text-align: left;
  padding: 0;
}

html {
  font-size: 0.71428571vw;
  scroll-padding-top: 13rem;
}

body {
  color: #333333;
  background-color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.8rem;
  font-optical-sizing: auto;
  -webkit-font-smoothing: antialiased;
  font-weight: 500;
  line-height: 1.6;
  margin: 0;
  padding: 0;
  overflow-y: scroll;
}

p,
ul,
ol,
dl {
  margin-bottom: 1.5em;
}

a {
  color: #1f9485;
  text-decoration: underline;
  transition-property: color;
  transition-duration: 0.3s;
}

a:hover {
  opacity: 0.8;
  text-decoration: none;
}

img {
  vertical-align: bottom;
}

input,
textarea,
select {
  font-family: inherit;
}

@media screen and (min-width: 1400px) {
  html {
    font-size: 10px;
  }
}

@media all and (max-width: 900px) {
  html {
    font-size: 3.125vw;
    scroll-padding-top: 7.1rem;
  }

  body {
    font-size: 1.2rem;
  }
}

@media screen and (max-width: 320px) {
  html {
    font-size: 10px;
  }
}