@charset "UTF-8";

body {
    min-height: 100vh;
    scroll-behavior: smooth;
    text-rendering: optimizeSpeed;
}

html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, hr, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, input, textarea, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-size: 62.5%;
    font-weight: 300;
    vertical-align: baseline;
    background: transparent;
}

div, p, a, iframe, footer, header, section, article, menu, nav, pre, table, th, td, dl, dt, dd, ul, ol, li, label, input, textarea, img, audio, video {
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
}

body, div, span, p, a, b, i, pre, footer, header, section, article, menu, nav, th, td, dl, dt, dd, ul, ol, li, label, strong, var, input, textarea, h1, h2, h3, h4, h5, h6 {
	font-size: 1.6rem;
	line-height: 1.2;
	color: #333;
    font-weight: 300;
    -webkit-font-feature-settings: "palt";
    -moz-font-feature-settings: "palt";
    font-feature-settings: "palt";
}

ul,
ol {
    list-style: none;
}

blockquote, q {
    quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content:'';
    content: none;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
    display: block;
}

a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
    text-decoration: none;
}

strong, b {
    font-weight: 700;
}

table {
	border-collapse: collapse;
    border-spacing: 0;
}

pre {
	white-space: pre-wrap;
}

sup {
	font-size: 70%;
	vertical-align: top;
	position: relative;
	top: -0.03em;
}

sub {
	font-size: 70%;
	vertical-align: bottom;
	position: relative;
	bottom: -0.03em;
}

input[type=text]: focus,
select: focus,
textarea: focus {
    outline: none;
}

textarea {
    resize: none;
}

input, select {
    vertical-align: middle;
}

::placeholder {
    color: #999;
}
