@charset 'utf-8';


#ir-info {
	width: 100%;
}

#ir-info > .inner {
	width: 100%;
	padding: 30px;
	padding-top: 0;
}

#ir-info .column p:not(:last-child) {
	margin-bottom: 1.5em;
}

@media only screen and (min-width: 481px) {

	#ir-info > .inner {
		padding-top: 30px;
	}
}


/* 
.datalists a[target="_blank"]:after {
	display: inline-block;
	content: '\f109';
	margin-left: .3em;
	font-family: 'uiicon';
	font-weight: normal !important;
	text-align: center;
}
 */


.datalists {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	margin-bottom: 1em;
	font-size: .85rem;
	line-height: 1.6;
}

.datalists .columns {
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: flex-start;
}

.datalists .column {
	width: 100%;
}

.datalists .columns:not(:last-child),
.datalists .column:not(:last-child) {
	margin-bottom: 3em;
}

.datalists h2 {
	margin-bottom: 1em;
	font-size: 1.2em;
	line-height: 1.4;
	border-bottom: 1px solid;
}

@media only screen and (min-width: 481px) {

	.datalists {
		font-size: 1rem;
	}
}

@media only screen and (min-width: 769px) {

	.datalists .columns {
		flex-direction: row;
	}

	.datalists .column {
		width: 50%;
		margin-bottom: 0 !important;
		padding: 0 20px
	}
}



.datalists .item {
	border-bottom: 1px solid #b2b2c1;
}

.datalists .item .enclosed {
	padding: .8em .5em;
}

.datalists .meta {
	margin: .3em 0;
	color: #808080;
	font-size: .9em;
	line-height: 1.4;
}

.datalists .title {
	font-size: 1.2em;
	line-height: 1.5;
}

.datalists .title .label {
	margin-right: .3em;
}

.datalists .title .label:after {
	display: inline-block;
	content: '\f109';
	margin-left: .3em;
	font-family: 'uiicon';
	font-weight: normal !important;
	text-align: center;
}

.datalists .title .fineinfo {
	display: inline-block;
	color: #808080;
	font-size: .7em;
	font-weight: 400;
}

.datalists .empty {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1em;
	border: 1px solid #ccc;
	color: #808080;
	font-size: .85em;
}

@media only screen and (min-width: 481px) {

	.datalists .item .enclosed {
		display: flex;
		flex-direction: row;
		align-items: flex-start;
		justify-content: flex-start;
	}

	.datalists .meta {
		width: 9em;
		margin: 0;
		white-space: nowrap;
	}

	.datalists .title {
		flex-grow: 1;
		width: calc(100% - (7em));
		margin: 0;
	}
}


.outlinetbl {
	display: block;
	width: 100%;
}

.outlinetbl:not(:last-child) {
	margin-bottom: 3em;
}

.outlinetbl th,
.outlinetbl td {
	text-align: left;
	vertical-align: top;
}

.outlinetbl th {
	display: inline-block;
	padding: 0 1em;
	border-bottom: 1px solid #b2b2c1;
	font-weight: 700;
	white-space: nowrap;
}

.outlinetbl td {
	display: block;
	padding-top: 1em;
	padding-left: 2em;
}

.outlinetbl tr {
	display: block;
	width: 100%;
	padding: 1em 0;
	border-bottom: 1px solid #b2b2c1;
}

.outlinetbl tbody {
	display: block;
	width: 100%;
}

.outlinetbl td ul {
	margin-left: 1.5em;
}

.outlinetbl td ul:not(:last-child) {
	margin-bottom: .3em;
}

.outlinetbl td li:not(:last-child) {
	margin-bottom: .3em;
}

.outlinetbl td .caution {
	margin-top: .5em;
	padding-left: 1em;
	color: #808080;
	font-size: .8em;
	line-height: 1.5;
	position: relative;
}

.outlinetbl td .caution::before {
	content: '※';
	position: absolute;
	top: 0;
	left: 0;
}

.outlinetbl td .addrgrid {
	display: table;
}

.outlinetbl td .addr {
	display: table-row;
}

.outlinetbl td .addr > span {
	display: table-cell;
	width: auto;
	vertical-align: top;
}

.outlinetbl td .addr > span.head {
	font-weight: 700;
	white-space: nowrap;
}

.outlinetbl td .addr > span span {
	display: inline-block;
}


.outlinetbl td .addr:not(:last-child) span {
	padding-bottom: .5em;
}

.outlinetbl a[target="_blank"]:after {
	display: inline-block;
	content: '\f109';
	margin-left: .3em;
	font-family: 'uiicon';
	font-weight: normal !important;
	text-align: center;
}

@media only screen and (min-width: 769px) {

	.outlinetbl {
		display: table;
	}

	.outlinetbl th,
	.outlinetbl td {
		display: table-cell;
		padding: .8em 1em;
		border: none;
	}

	.outlinetbl th {
		width: 10em;
	}

	.outlinetbl tr {
		display: table-row;
		padding: 0;
	}

	.outlinetbl tbody {
		display: table-row-group;
	}
}


#ir-info .sentence.reference {
	padding-top: 1em;
	font-size: 1.6em;
	line-height: 1.8;
	text-align: center;
}

#ir-info .sentence.reference p {
	margin-bottom: 1em;
}

#ir-info .sentence.reference .badge {
	margin-bottom: 1em;
	text-align: center;
}

#ir-info .sentence.reference .badge .img {
	width: 100%;
	max-width: 400px;
	margin: 0 auto;
	margin-bottom: .5em;
}

#ir-info .sentence.reference .badge img {
	width: 100%;
	height: auto;
}

@media only screen and (min-width: 481px) {

	#ir-info > .inner {
		padding-top: 30px;
	}
}



#resultlist {
	width: 100%;
}

#resultlist > .inner {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	padding: 10px;
	font-size: .65rem;
}



.tabcontentframe .brick {
	margin: 0 auto;
	margin-bottom: 2em;
	font-size: 1.6em;
	line-height: 1.6;
	text-align: center;
}

.tabcontentframe .brick p:not(:last-child) {
	margin-bottom: 1.5em;
}

.tabcontentframe .cathead {
	display: flex;
	margin-bottom: 2em;
	padding-bottom: .5em;
	border-bottom: 1px solid;
	font-size: 2em;
}

.tabcontentframe .cathead .icon {
	display: block;
	width: 24px;
	height: 24px;
	margin-right: .3em;
}

.resultitemlist {
	width: 100%;
	font-size: 1em;
}

.resultitems {
	width: 100%;
}

.resultitems .item:not(:last-child) {
	margin-bottom: 5em;
}

.resultitems .item .schoollist:not(:last-child) {
	margin-bottom: 3em;
}

.resultitems .item .sectheader {
	margin-bottom: .5em;
	padding-bottom: .5em;
	border-bottom: 1px solid #ccc;
	font-size: 1.8em;
}

.resultitems .item .schoollist .listblockheader {
	margin-bottom: .5em;
	padding-bottom: .5em;
	border-bottom: 1px solid #ccc;
	font-size: 1.6em;
}

.resultitems .item .schoollist .groupheader {
	margin-bottom: .5em;
	padding-bottom: .5em;
	border-bottom: 1px solid #ccc;
	font-size: 1.4em;
}

.resultitems .item .schoollist .listheader {
	margin-bottom: .5em;
	padding-bottom: .5em;
	border-bottom: 1px solid #ccc;
	font-size: 1.4em;
	font-weight: normal;
}

.resultitems .item .schoollist .columns:not(:last-child) {
	margin-bottom: 1em;
}

.resultitems .item .schoollist .columns .form {
	margin-bottom: .5em;
	font-size: 1em;
	font-weight: 700;
}

.resultitems .item .schoollist .columns .form span {
	display: inline-block;
	padding: .2em .5em;
	background: rgba(233,69,83,.4);
	color: #fff;
}

.resultitems .item .schoollist .columns ul {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
}

.resultitems .item .schoollist .columns li {
/* 	width: 100%; */
	padding: .3em 1.5em;
	font-size: .85em;
}

.resultitems .item .schoollist .columns li span {
	display: inline-block;
}

.resultitems .item .schoollist .columns li.other {
	list-style: none;
	color: #808080;
}

.resultitems .item .schoollist .columns li.other:before {
	content: '...';
}

.resultitems .item .schoollist .columns li .label:before {
	display: inline-block;
	content: '\f118';
	margin-right: .3em;
	font-family: 'uiicon';
	font-weight: normal !important;
	text-align: center;
}

.resultitems .item .schoollist .columns li .label:after {
	display: inline-block;
	content: '\f109';
	margin-left: .3em;
	font-family: 'uiicon';
	font-weight: normal !important;
	text-align: center;
}


.resultitems .item .schoollist p {
	margin-left: .3em;
	font-size: 1.4em;
	color: #666;
}

.resultitems .item .schoollist p:not(:last-child) {
	margin-bottom: 2em;
	padding-bottom: .5em;
	border-bottom: 1px solid #ccc;
}

/* 
@media only screen and (min-width: 541px) {

	.resultitems .item .schoollist .columns li {
		width: calc(100% / 2);
	}
}

@media only screen and (min-width: 1001px) {

	.resultitems .item .schoollist .columns li {
		width: calc(100% / 3);
	}
}
 */



.resultitems .item > .caution {
	font-size: 1.2em;
}




#resultlist > .inner > .tabcontentsblock {
	margin-bottom: 2em;
	padding-bottom: 1em;
	border-bottom: 1px solid;
}

#resultlist > .inner > .caution {
	font-size: 1.2em;
}

#resultlist > .inner > .caution:not(:last-child) {
	margin-bottom: 2em;
}

.tabcontentsection {
	width: 100%;
	height: auto;
	overflow: hidden;
	position: relative;
}

.tabcontentsection .tabcontentframe {
	width: 100%;
	opacity: 0;
	position: absolute;
	top: 0;
	left: 0;
}

.tabcontentsection .tabcontentframe.open {
	opacity: 1;
	position: relative;
	z-index: 10;
}

.contentstab {
	width: 100%;
	margin-bottom: 20px;
	text-align: left;
	border: 1px solid #6ccbd9;
	background: #c6f1f8;
}

#resultlist > .inner > .tabcontentsblock > .contentstab {
	padding: 1em;
}

.contentstab ul {
	list-style: none;
	display: flex;
/* 
	flex-wrap: nowrap;
	justify-content: space-around;
 */
	flex-wrap: wrap;
	padding: 0;
}

.contentstab li {
	padding: .5em 1em;
	font-size: 1.8em;
	font-weight: 700;
	line-height: 1;
	transition: .2s;
	cursor: pointer;
}

.contentstab li .cover > div {
	display: inline-block;
	color: #000;
	vertical-align: middle;
	text-decoration: none;
}

.contentstab li.open .cover > div,
.contentstab li.hover .cover > div {
	color: #00798b;
}

/*
.contentstab li {
	list-style: none;
	display: inline-block;
	width: 100%;
	height: 50px;
	padding: 0;
	font-size: 16px;
	vertical-align: top;
	transition: .2s;
	position: relative;
	cursor: pointer;
}

.contentstab li:not(:last-child) {
	padding-right: 1px;
}

.contentstab .cover {
	width: 100%;
	height: 100%;
	border: 1px solid rgba(47,85,151,1);
	background: rgba(47,85,151,.2);
	position: relative;
	transition: .2s;
}

.contentstab li.open .cover,
.contentstab li.hover .cover {
	background: rgba(47,85,151,1);
	color: #fff;
}

.contentstab li .label {
	display: block;
	margin: 0 auto;
	font-weight: 700;
	line-height: 1;
	font-feature-settings : 'palt';
}

.contentstab li .label span  {
	display: block;
	font-size: .85em;
}

.contentstab li.open:after {
	content: '';
	width: 0;
	height: 0;
	margin-left: -14px;
	border-style: solid;
	border-width: 14px 14px 0 14px;
	border-color: rgba(47,85,151,1) transparent transparent transparent;
	position: absolute;
	bottom: -14px;
	left: 50%;
}

.contentstab li .cover div {
	display: inline-block;
	vertical-align: middle;
}

.contentstab li .cover a {
	display: inline-block;
	color: #4c4c4c;
	vertical-align: middle;
	text-decoration: none;
}

.contentstab li.open .cover a,
.contentstab li.hover .cover a {
	color: #fff;
}

.contentstab li .cover:before {
	display: inline-block;
	content: '';
	height: 100%;
	vertical-align: middle;
}
*/
@media only screen and (min-width: 769px) {

	.contentstab li {
		font-size: 18px;
	}

	.contentstab li .label span {
		display: inline;
	}
}



.resultlist {

}

.resultitemlist .resultitemlist .contentstab {
	width: 100%;
	margin-bottom: 20px;
	padding-bottom: 10px;
	text-align: center;
}

.resultitemlist .contentstab ul {
	list-style: none;
	display: block;
	padding: 0;
	text-align: left;
}

.resultitemlist .contentstab li {
	list-style: none;
	display: inline-block;
	width: auto;
	height: auto;
	margin: 2px;
	font-size: 1.3em;
	vertical-align: top;
	transition: .2s;
	position: relative;
	cursor: pointer;
}

.resultitemlist .contentstab li:not(:last-child) {
	padding-right: 0;
}

.resultitemlist .contentstab .cover {
	width: auto;
	height: auto;
	padding: .5em 1em;
	border: 1px solid rgba(47,85,151,1);
	background: rgba(47,85,151,.2);
	font-weight: 700;
	position: relative;
	transition: .2s;
}

.resultitemlist .contentstab li.open .cover,
.resultitemlist .contentstab li.hover .cover {
	background: rgba(47,85,151,1);
	color: #fff;
}

.resultitemlist .contentstab li .label {
	display: block;
	margin: 0 auto;
	font-weight: 700;
	line-height: 1;
	font-feature-settings : 'palt';
}

.resultitemlist .contentstab li .label span  {
	display: block;
	font-size: .85em;
}

.resultitemlist .contentstab li.open:after {
	display: none;
}


.resultitemlist .contentstab li.open:after {
	display: none;
}


#resultsblock {
	width: 100%;
	position: relative;
}

#resultsblock > .inner {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 20px 10px;
	position: relative;
}

#resultsblock > .inner > .tabcontentsblock {
	margin-bottom: 2em;
	padding-bottom: 1em;
	border-bottom: 1px solid;
}

@media only screen and (min-width: 1001px) {

	#resultsblock > .inner {
		padding: 50px 20px;
	}
}


.tabcontentframe .catcaution {
	margin-bottom: 2em;
	font-size: 1.2em;
}

@media only screen and (min-width: 541px) {

	.tabcontentframe .catcaution {
		font-size: 1.3em;
		text-align: right;
	}

	.tabcontentframe .catcaution.caution p:before {
		margin-right: .2em;
		position: relative;
		top: auto;
		left: auto;
	}
}



#document {
	max-width: 1000px;
	margin: 0 auto;
	padding: 30px;
	padding-bottom: 10px;
	font-size: .65rem;
}

#document .columns {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: center;
	width: 100%;
	font-size: 1.4em;
}

/* 
#document .columns:not(:last-child) {
	margin-bottom: 2em;
}

#document .columns > div:nth-child(1) {
	width: 100%;
	margin-bottom: 2em;
}

#document .columns > div:nth-child(2) {
	width: 100%;
	padding: 0;
}
 */

#document .foto {
}

#document .header {
	text-align: center;
	line-height: 1.4;
}

#document .articletitle {
	margin-bottom: .7em;
}

#document .header h1 {
	font-size: 1em;
	font-weight: 400;
}

#document .header h1 span,
#document .header h1 small {
	display: block;
	padding-right: .3em;
}

#document .header h1 .position {
	font-size: .95em;
}

#document .header h1 .phonetic {
	font-size: .85em;
}

#document .header h1 .name {
	font-size: 1.6em;
	font-weight: 700;
}

#document .header h1 .position {
	display: block;
}

#document .header .tbl {
	margin-bottom: 2em;
}

#document .header .tbl .row:not(:last-child) {
	margin-bottom: .5em;
}

#document .header .row .head {
	color: #808080;
	font-size: .85em;
}

#document .header ul.specialized {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

#document .header ul.specialized li {
	display: inline-block;
	margin: 2px;
	padding: .3em .8em;
	background: #2f5597;
	color: #fff;
}

#document .foto figure {
	width: 60%;
	margin: 0 auto;
}

#document .foto figure > span {
	display: inline-block;
	overflow: hidden;
}

#document .foto figure img {
	width: 100%;
	height: auto;
}

#document .sentence p {
	font-size: 1em;
	line-height: 1.6;
	text-align: left;
}

@media only screen and (min-width: 541px) {

	#document .sharebutton {
		text-align: left;
	}

	#document .columns > div:nth-child(1) {
		width: 40%;
		margin: 0;
	}

	#document .columns > div:nth-child(2) {
		width: 60%;
		padding-left: 30px;
	}

	#document .header {
		text-align: left;
	}

	#document .header .tbl .row {
		display: flex;
		align-items: baseline;
		margin-bottom: 0 !important;
	}

	#document .header .tbl .row .head {
		padding-right: 1em;
		width: 5em;
		white-space: nowrap;
	}

	#document .header .tbl .row .spec {
		width: calc(100% - 5em);
	}

	#document .foto {
	}

	#document .header {
		text-align: left;
	}

	#document .header h1 span,
	#document .header h1 small {
		display: inline-block;
	}

	#document .header ul.specialized {
		justify-content: flex-start;
	}

	#document .foto figure {
		width: 100%;
		max-width: none;
	}

	#document .sentence .btnarea {
		text-align: left;
	}
}

@media only screen and (min-width: 801px) {

	#document .columns {
		font-size: 1.6em;
	}

	#document .columns > div:nth-child(2) {
		padding-left: 50px;
	}

	#document .header {
		font-size: 1.2em;
	}

	#document .header ul.specialized {
		font-size: .85em;
	}

	#document .sentence p {
		font-size: .85em;
	}
}


body.result.webpage .articleblock #document {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
	padding: 30px;
	padding-left: calc(env(safe-area-inset-left) + 30px);
	padding-right: calc(env(safe-area-inset-right) + 30px);
}

body.result.webpage .articleblock #document h1 {
	font-size: 2em;
	line-height: 1.5;
}

