@charset "UTF-8";

h1 {
	margin-top: 80px;
	}

p.catch {
	color: #ff0000;
	}

.topics {
	border: 2px solid #ff0000;
	box-shadow: 7px 9px 6px 1px rgba(243,25,25,0.5);
	}

.topics-ttl {
	background: #ff0000;
	}

.subttl {
	color: #ff0000;
	}

h3 {
	color: #ff0000;
	border-top: 2px solid #ff0000;
	border-bottom: 2px solid #ff0000;
	}

.topic-cont figure {
	margin-top: 25px;
	}

.topic-cont span.small {
	font-size: 80%;
	}

.topic-cont p.note {
	line-height: 1.4;
	margin: 1rem 0;
	}

.topic-cont p.note2 {
	line-height: 1.4;
	margin-top: 0.5rem;
	}

.topic-cont sup {
	font-size: 80%;
	vertical-align: top;
	position: relative;
	top: -0.2em;
	}

table {
	width: 810px;
	border-right: 1px solid #ccc;
	box-sizing: border-box;
	margin: 0 auto;
	}

table:first-of-type {
	margin-top: 50px;
	}

table:last-of-type {
	border-bottom: 1px solid #ccc;
	}

tr {
	vertical-align: top;
	}

th {
	font-size: 13px;
	line-height: 40px;
	text-align: center;
	white-space: nowrap;
	background: #eee;
	border-top: 1px solid #ccc;
	border-left: 1px solid #ccc;
	}

td {
	border-top: 1px solid #ccc;
	border-left: 1px solid #ccc;
	}

td.date {
	width: 100px;
	}

td.date p {
	white-space: nowrap;
	}

td.func {
	width: 152px;
	}

td.method {
	width: 278px;
	}

.research p {
	font-size: 13px;
	line-height: 23px;
	margin: 0;
	padding: 1rem;
	}

td.func p.quote {
	width: calc(152px - 2rem);
	font-size: 80%;
	word-wrap: break-word;
	}

/*------------ SP ------------*/
@media screen and (max-width: 640px) {

	h1 {
		margin-top: 10vw;
		}

	.topics {
		box-shadow: 2vw 2vw 1.6vw 0.3vw rgba(243,25,25,0.5);
		}

	.topic-cont figure {
		margin-top: 7.5vw;
		padding-bottom: 3.4vw;
		}

	.topic-cont span.small {
		font-size: 1.2rem;
		}

	h3 {
		border-top: 3px solid #ff0000;
		border-bottom: 3px solid #ff0000;
		}

	table {
		width: 86.2%;
		border-bottom: 2px solid #ccc;
		margin-top: 7.8vw;
		table-layout:fixed;
		}

	table:last-of-type {
		border-bottom: 2px solid #ccc;
		margin-bottom: 2vw;
		}

	.thead {
		display: none;
		}

	td {
		display: block;
		width: 100%;
		border-top: 2px solid #ccc;
		border-left: 2px solid #ccc;
		}

	td.date {
		width: 100%;
		}

	td.func {
		width: 100%;
		}

	td.method {
		width: 100%;
		}

	td:before {
		content: attr(data-label);
		display: block;
		font-size: 1.3rem;
		line-height: 2.8rem;
		font-weight: bold;
		text-align: left;
		white-space: nowrap;
		background: #eee;
		border-bottom: 2px solid #ccc;
		padding: 0 1rem;
		}

	.research p {
		font-size: 1.3rem;
		line-height: 2rem;
		}

	td.func p.quote {
		width: auto;
		font-size: 1.2rem;
		}

	}