@charset "utf-8";

/* ヘッダー
---------------------------------------- */
/* All
------------------------------ */
header {
	text-align: center;
}
h1::first-letter {
	color: rgb(226, 4, 27);
}
/* PC 640~
------------------------------ */
@media screen and (min-width: 640px){
	header {
		box-shadow: 0 1px 1px #333;
	}
}

/* セクション共通
---------------------------------------- */
/* All
------------------------------ */
section {
	margin: 0 auto;
}
h2 {
	margin-bottom: 15px;
}

/* 2カラムのセクション
---------------------------------------- */
/* All
------------------------------ */
/* aside */
aside h2 {
	font-size: 15px;
	text-align: center;
}
aside h3 {
	padding: 0 8px;
	margin-bottom: 0.5rem;
	border-left: 5px solid rgb(226, 4, 27);
	border-bottom: 1px solid rgb(226, 4, 27);
	font-size: 15px;
}
aside section {
	font-size: 14px;
	margin-bottom: 30px;
}
/* main */
#index main h2::before,
#index main h2::after {
	content: "―";
}
#index main h2 {
	text-align: center;
	border-bottom: 1px solid rgb(25, 68, 142);
}
#index main img {
	box-shadow: 1px 2px 2px gray;
	float: right;
	margin-left: 15px;
	width: 125px;
	height: 150px;
}
#index main p {
	margin-bottom: 16px;
	text-indent: 1em;
	font-size: 16px;
}
#index .signature {
	text-align: right;
	margin-top: 32px;
}
/* PC 640~
------------------------------ */
@media screen and (min-width: 640px){
	#index main section {
		max-width: 90%;
	}
	#index main img {
		width: 150px;
		height: 180px;
	}
	#index main p {
		line-height: 1.6;
	}
}

/* 1カラムのセクション
---------------------------------------- */
/* All
------------------------------ */
.inner > main h2 {
	font-size: 20px;
}

/* asideのdl
---------------------------------------- */
/* All
------------------------------ */
aside dt {
	float: left;
	width: 9em;
}
aside dd {
	padding-left: 9em;
	padding-bottom: 2px;
	border-bottom: dotted 1px #CCC;
}
aside dl + dl {
	margin-top: 5px;
}
/* PC 640~
------------------------------ */
@media screen and (min-width: 640px){
	aside dl + dl {
		margin-top: 8px;
	}
	aside dt {
		float: none;
	}
	aside dd {
		padding-left: 2em;
		margin-top: 2px;
	}
}

/* worksのh3、ul
---------------------------------------- */
/* All
------------------------------ */
#works strong {
	padding-left: 5px;
	padding-right: 5px;
}
#works h3 {
	font-size: 18px;
	padding: 0 8px;
	margin-bottom: 0.5em;
	border-left: 5px solid rgb(25, 68, 142);
	border-bottom: 1px solid rgb(25, 68, 142);
}
.work-list li {
	list-style-type: disc;
	line-height: 2;
	margin-left: 1.5em;
	border-bottom: 1px dotted rgb(25, 68, 142);
}

/* テーブル
---------------------------------------- */
/* All
------------------------------ */
table {
	border-collapse: collapse;
	width: 100%;
}
#office th {
	font-weight: normal;
	text-align: left;
}
#office th, #office td {
	padding: 10px;
}
#office tr {
	border-bottom: gray 1px dotted;
}
/* PC 640~
------------------------------ */
@media screen and (min-width: 640px){
	#office th, #office td {
		border: 1px gray solid;
		padding: 15px;
	}
	#office th {
		width: 150px;	/*旧160px*/
		color: #fff;
		background-color: rgb(25, 68, 142);
	}
}

/* policy
---------------------------------------- */
/* All
------------------------------ */
.policy h3 {
	text-align: center;
	padding: 3px 8px;
	margin-bottom: 0.8rem;
	background: rgba(25, 68, 142, 0.3);
}
span.br {
	display: inline-block;
}
.policy h4 {
	font-size: 18px;
	padding: 0 8px;
	margin-bottom: 0.8rem;
	border-left: 5px solid rgb(25, 68, 142);
	border-bottom: 1px solid rgb(25, 68, 142);
}
.policy h5,
.policy p.item {
	margin-top: 1rem;
}
.policy p,
.policy ul,
.policy dl {
	margin: 0.5rem 0;
}
.policy li {
	margin-bottom: 0.2rem;
	list-style-type: disc;
	margin-left: 1.5em;
}
ul.disc li {
	list-style-type: disc;
}
.decimal li {
	list-style-type: decimal;
}
.policy dd {
	margin-bottom: 0.5rem;
	margin-left: 2em;
}
.policy address {
	margin: 30px 5px;
	padding: 1em;
	border-top: 3px solid rgb(25, 68, 142);
	border-bottom: 3px solid rgb(25, 68, 142);
	background-color: ghostwhite;
}
/* PC 640~
------------------------------ */
@media screen and (min-width: 640px){
	.policy address {
		margin: 30px;
	}
	#add_space {
		margin-top: -128px;
		padding-top: 128px;
	}
}

/* 注意書き
---------------------------------------- */
.foot {
	margin-top: 1rem;
	border-top: #333 dotted 1px;
	padding-top: 0.4em;
}
ul.notes li::before {
	content: "※";
}
ul.notes li + li {
	margin-top: 0.2em;
}

/* フッター
---------------------------------------- */
/* All
------------------------------ */
footer {
	text-align: center;
	color: #aaa;
}
