@charset 'utf-8';


.sharebutton {
	margin-top: 10px;
	margin-bottom: 20px;
}

#document {
	padding: 0 20px;
}

.articleblock {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	padding: 20px 0;
	font-size: 1.6em;
	line-height: 2em;
}

body.safearea .articleblock {
	padding-left: env(safe-area-inset-left);
	padding-right: env(safe-area-inset-right);
}

.articleblock .blockheader + .movearticle {
	margin-top: -20px;
	margin-bottom: 20px;
	padding-top: 0;
}

.articletitle {
	margin: 0 0 30px 0;
}

.articlebody {
	margin: 0 !important;
	padding-bottom: 10px !important;
	border-bottom: 1px solid #ccc;
}

.articletitle h1 {
	width: calc(100% + 40px);
	margin: 0 -20px;
	margin-bottom: .5em;
	padding: 0 20px;
	padding-bottom: 1em;
	font-size: 1.4em;
	font-weight: 700;
	line-height: 1.5em;
}

#info .articletitle h1 {
	border-bottom: 1px solid #000;
}

#weblog .articletitle h1 {
	font-size: 1.6em;
}

.articletitle > div.enclosed {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
	margin-bottom: 20px;
	font-size: 12px;
	line-height: 1.6em;
}

.articletitle > div.enclosed .meta:nth-child(2) {
	margin-left: auto;
	margin-right: 0;
}

.articletitle > div.enclosed .meta:nth-child(2) .category {
	display: flex;
	align-items: flex-end;
}

.articletitle > div.enclosed .category span a {
	margin: .1em;
}

.articletitle > div.enclosed .category span a {
	display: inline-block;
	padding: .5em 1em;
	border: 2px solid #003f73;
	background: #fff;
	color: #003f73;
	font-size: 1.2em;
	text-align: center;
	text-decoration: none;
	line-height: 1;
	white-space: nowrap;
}

.articletitle > div.enclosed .category span a:hover,
.articletitle > div.enclosed .category span a.hover {
	background: #003f73;
	color: #fff;
}

.bumperimage {
	width: calc(100% + 40px);
	margin: 0 -20px;
	margin-bottom: 1.5em;
}

.bumperimage div {
	width: 100%;
}

.bumperimage div,
.bumperimage p {
	margin-bottom: 0 !important;
}

.bumperimage img {
	width: 100%;
	height: auto;
}

.frontispiece {
	display: flex;
	flex-direction: column;
}

.articlebody .btnarea p:not(:last-child) {
	margin-bottom: .5em;
}

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

	#document {
		padding: 0 30px;
	}

	.frontispiece {
		flex-direction: row;
	}
}

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

	.sharebutton {
		text-align: right;
	}

	.articleblock {
		padding: 20px 40px;
	}

	body.safearea .articleblock {
		padding-left: calc(env(safe-area-inset-left) + 40px);
		padding-right: calc(env(safe-area-inset-right) + 40px);
	}

	.articletitle h1 {
		width: calc(100% + 40px);
		margin: 0 -20px;
		margin-bottom: .5em;
		padding: 0 20px;
		padding-bottom: 1em;
		font-size: 2em;
		font-weight: 700;
		line-height: 1.5em;
	}
}

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

	body.safearea #container > .inner {
		padding-left: calc(env(safe-area-inset-left) + 40px);
		padding-right: calc(env(safe-area-inset-right) + 40px);
	}

	#document {
		padding: 0 50px;
	}

	body.safearea .articleblock {
		padding-left: 0;
		padding-right: 0;
	}

/* 
	body.safearea #columns .articleblock {
		padding-right: 40px;
	}
 */

	.articletitle h1 {
		width: calc(100% + 100px);
		margin: 0 -50px;
		margin-bottom: .5em;
		padding: 0 50px;
		padding-bottom: 1em;
		font-size: 2em;
		font-weight: 700;
		line-height: 1.5em;
	}

	.bumperimage {
		width: calc(100% + 100px);
		margin: 0 -50px;
	}
}



.articlelistbody {
	font-size: .65em;
}

.articlelist .item figure {
	padding-top: 66.66%;
}

#weblog .articlelist .item article {
	padding-top: 5%;
	padding-bottom: 5%;
}

.articlelist .item.hover figure img {
	transform: scale(1.3);
}

.articlelist .category span a {
	display: inline-block;
	padding: .3em 1.2em;
	border: 2px solid #003f73;
	background: #fff;
	color: #000;
}

.articlelist .category span a:hover,
.articlelist .category span a.hover {
	background: #003f73;
	color: #fff;
}

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

	.articlelistbody {
		font-size: .75em;
	}

	#weblog .articlelistbody {
		font-size: .85em;
	}
}

.actionber {
	display: flex;
	font-size: 1rem;
}




.taglist {
	display: flex;
	flex-wrap: wrap;
	font-size: 1rem;
}

.taglist span {
	display: inline-block;
	margin-right: 1.5em;
	font-size: .8rem;
	font-weight: 700;
}

.taglist a {
	color: #204068;
	text-decoration: none;
}

.taglist a:hover,
.taglist a,hover {
	color: #597ca7;
}

.taglist.archive {
	padding: 20px;
	padding-top: 0;
}


.actionber .btnitem {
	margin: 2px;
	font-size: .8em;
}

.actionber .btnitem a {
	display: inline-block;
	padding: .3em 1em;
	background: #000;
	color: #fff;
	text-decoration: none;
}

.actionber .btnitem a:hover,
.actionber .btnitem a:hover {
	background: #666;
}

.actionber .btnitem a:before {
	margin-right: .5em;
	font-family: 'uiicon';
	font-weight: normal !important;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.actionber .btnitem a.print:before {
	content: '\f118';
}

.actionber .btnitem a.download:before {
	content: '\f107';
}


.map {
	position: relative;
	width: 100%;
	height: 0;
	padding-top: 75%;
}
 
.map iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}


.contactwidget .blockheader.deco .desc {
	color: #666;
	font-size: .8em;
	font-weight: 400;
}

.contactwidget .widgetblock p:not(.fonnumber) {
	margin: 0 !important;
}

.contactwidget .widgetblock p + .fonnumber {
	margin-top: 1em !important;
}

.contactwidget .call:not(:last-child) {
	margin-bottom: 2em;
}

.contactwidget .fonnumber > span {
	font-size: 1.4em;
}

.contactwidget .fonnumber a {
	display: inline-block;
	color: #000;
	text-decoration: none;
}

.contactwidget .fonnumber a:hover,
.contactwidget .fonnumber a.hover {
	color: #666;
}

.contactwidget .mail,
.contactwidget .website {
	overflow-wrap: anywhere;
	word-break: normal;
	line-break: strict;
}

.contactwidget .website a {
	display: inline;
}

.contactwidget a[target="_blank"]:after {
	content: '\f109';
	margin-left: .5em;
	font-family: 'uiicon';
	font-weight: normal !important;
	text-align: center;
/* 	line-height: 2; */
	vertical-align: top;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

#document .logotypeset {
	display: none;
}

@page {
    size: A4 portrait; 
    margin: auto;
    padding: 3em;
}

@media print {

	body {
		font-size: 6pt;
	}

	.articletitle div.enclosed {
		font-size: 6pt;
	}

	.breadcrumb,
	.movearticle,
	.sharebutton,
	.articletitle .actionber,
	.articletitle > div.enclosed .meta:nth-child(2),
	.articletitle .taglist span,
	.articlebody .btnarea,
	#upper,
	#navi_contents,
	#downloadbtnblock,
	#side .btnarea,
	#bottom > .inner,
	#copyright .textnavi {
		display: none !important;
	}

	#document .logotypeset {
		display: flex;
		align-items: flex-end;
		width: calc(100% + 40px);
		margin-top: -50px;
		margin-left: -20px;
		margin-right: -20px;
		margin-bottom: 20px;
		padding: 10px 20px;
		padding-top: 0;
		font-size: 10px;
		line-height: 1;
		border-bottom: 1px solid #666;
	}

	#document .logotypeset .logo_mark {
		width: 180px;
	}

	#document .logotypeset .pagurl {
		flex-grow: 1;
		padding-left: 20px;
		font-size: 5pt;
		text-align: right;
	}

	#document .logotypeset img {
		position: relative;
	}
}


.tblwrap table caption {
	display: none;
}

.tblwrap {
	overflow-x: scroll !important;
	position: relative;
}

.tblwrap table {
	width: 100%;
	min-width: 640px;
}

