@charset "UTF-8";

/* ============================================================
   Reset
   ============================================================ */

html, body, div, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-family: "Noto Sans JP", sans-serif;
	line-height: 2;
	letter-spacing: 0.08rem;
	font-weight: 700;
	color: #000;
	font-size: 16px;
}

/* HTML5 display */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

ol, ul { list-style: none; }

blockquote, q { quotes: none; }
blockquote:before, blockquote:after,
q:before, q:after { content: ''; content: none; }

table { border-collapse: collapse; border-spacing: 0; }

img { vertical-align: bottom; }

a {
	text-decoration: none;
	font-weight: bold;
	transition: .3s ease;
}
a:hover { opacity: .7; }

/* ============================================================
   Responsive base font size
   ============================================================ */

@media screen and (min-width:768px) {
	html, body, div, applet, object, iframe,
	h1, h2, h3, h4, h5, h6, p, blockquote, pre,
	a, abbr, acronym, address, big, cite, code,
	del, dfn, em, img, ins, kbd, q, s, samp,
	small, strike, strong, sub, sup, tt, var,
	b, u, i, center,
	dl, dt, dd, ol, ul, li,
	fieldset, form, label, legend,
	table, caption, tbody, tfoot, thead, tr, th, td,
	article, aside, canvas, details, embed,
	figure, figcaption, footer, header, hgroup,
	menu, nav, output, ruby, section, summary,
	time, mark, audio, video {
		font-size: 16px;
		letter-spacing: 1.28px;
	}
}

@media screen and (max-width:767px) {
	html, body, div, applet, object, iframe,
	h1, h2, h3, h4, h5, h6, p, blockquote, pre,
	a, abbr, acronym, address, big, cite, code,
	del, dfn, em, img, ins, kbd, q, s, samp,
	small, strike, strong, sub, sup, tt, var,
	b, u, i, center,
	dl, dt, dd, ol, ul, li,
	fieldset, form, label, legend,
	table, caption, tbody, tfoot, thead, tr, th, td,
	article, aside, canvas, details, embed,
	figure, figcaption, footer, header, hgroup,
	menu, nav, output, ruby, section, summary,
	time, mark, audio, video {
		font-size: 14px;
	}
}

/* ============================================================
   Typography classes
   ============================================================ */

@media screen and (min-width:768px) {
	.main_title              { font-size: 2rem; }
	.sub_title               { font-size: 1.2rem; }
	.more_size, .more_size p { font-size: 1.25rem; }
	.section_title           { font-size: 2rem; }
	.page_title              { font-size: 3rem; }
}

@media screen and (min-width:1200px) {
	.main_title { font-size: 4rem; }
	.sub_title  { font-size: 1.5rem; }
}

@media screen and (max-width:767px) {
	.main_title                              { font-size: 2.3rem; }
	.sub_title                               { font-size: 1.25rem; }
	.more_size, .more_size p                 { font-size: 1.2rem; }
	.section_title, .section_title_second   { font-size: 1.4rem; }
	.page_title                              { font-size: 1.5rem; }
}
