@charset "utf-8";
/*
Theme Name: 松本ステンドグラス Theme
Author: nobuki morimatsu
Author URI: http://mstained.sakura.ne.jp/
Description: 松本ステンドグラス テーマ
*/
html {
	font-size: 62.5%;
}
body {
	padding: 0;
	margin: 0;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 1.4em;
	letter-spacing: 0.02em;
	line-height: 2.0;
	color: #273200;
	background-color: #FFFFFF;
}
#wrap {
	background-color: #FFFFFF;
	width: 1060px;
	padding: 10px;
	margin: 0 auto;
}

header  {
	background-color: #000000;
	color: #FFFFFF;
	padding-bottom: 10px;
	width: 1020px;
	margin-left: auto;
	margin-right: auto;
}
#header_out {
	overflow:hidden;
	background-color: #000000;
	padding: 0;
	margin: 0;
}
header img {
	width: 70% ;
	height: auto ;
}

#visual  {
	background-color: #000000;
	color: #FFFFFF;
	margin-left: auto;
	margin-right: auto;
	width: 1020px;
	margin-bottom: 0px;
}
#visual img {
	width: 85% ;
	height: auto ;
}


#nav_out {
	background-color: #EFEFEF;
	overflow:hidden;
}
nav  {
	background-color: #EFEFEF;
	width: 980px;
	padding: 0;
	margin: 0 auto;
	height: 50px;
}
nav ul li  {
	float: left;
	display: block;
	font-size: 1.3em;
	margin-right: 40px;
	list-style-type: none;
	color: #222222;
}
nav ul li a {
	text-decoration: none;
	color: #3F3F3F;
}
nav ul li a:hover {
	color: #818181;
}




main {
	background-color: #FFFFFF;
	clear: both;
	width: 700px;
	float: left;
	margin-left: 40px;
}
aside {
	background-color: #EFEFEF;
	float: right;
	padding: 0;
	margin-right: 40px;
	margin-top: 20px;
	width: 250px;
	position: relative;
}

main .img600 { /*singleページの画像高さ700px制限*/
	display: block;
	max-height: 700px; 
	max-width: 700px; 
	object-fit: contain;
	margin-left: auto;
	
margin-right: auto;
}

main #carousel {
	margin-bottom: 20px;
	margin-top: 0px;
}
main #carousel ul {
	margin-left: 0px;
	padding-left: 0px;
}

main .preview  {
	width: 155px;
	float: left;
	margin-right: 10px;
	margin-bottom:20px;
	margin-left: 10px;
}
.preview img {
	width: 155px;
	height: 155px;
	object-fit: cover;
}
.nav_link{
	clear: both;
}


main article  {
	clear: both;
	color: #444444;
}
main article::after{
	clear: both;
}
main article h1 {
	font-size: 1.6em;
	border-bottom: 1px solid #999999;
}

main article h2 {
	font-size: 1.3em;
	background-color: #dddddd;
	text-indent: 8px;
	padding-top: 2px;
	padding-bottom: 2px;
}
main article h3 {
	font-size: 1.2em;
}
main article h4 {
	font-size: 1.1em;
	font-weight: bold;
}
main article p {
	font-size: 1.0em;
	line-height: 1.9em;
	margin: 0px 8px 0px;
}
article .preview p {
	font-size: 0.8em;
	line-height: 1.2em;
	margin-top: 1px;
	margin-bottom: 2px;
}




footer {
	background-color: #000000;
	color: #FFFFFF;
	clear: both;
	padding: 10px;
	float: left;
	width: 100%;
}
footer img {
	width: 50% ;
	height: auto ;
}
footer #footer_inner {
	width: 960px;
	margin-left: auto;
	margin-right: auto;
	}
footer #footer_address {
	width: 50%;
	float: left;
	}
footer #footer_address {
	width: 50%;
	float: left;
	}
#footer_nav1,#footer_nav2 {
	width: 20%;
	float: left;
}
footer #footer_nav1 a {
	color: #FFFFFF;
	text-decoration: none;
}
footer #footer_nav1 a:hover  {
}
footer #footer_nav2 a {
	color: #FFFFFF;
	text-decoration: none;
}
footer #footer_nav2 a:hover  {
}
footer #copy_rights  {
	text-align: center;
	font-size: 0.75em;
	width: 1020px;
	margin-left: auto;
	margin-right: auto;
	clear: both;
}











#so_result {
	padding: 5px;
	margin: 5px;
	border: 3px solid #666666;
	overflow: hidden;
}

#share {
	margin-top: 20px;
	margin-bottom: 20px;
	height: 70px;
	clear: both;
}




/* bt aside_nav */
.aside_nav {
	color: #2F2F2F;
	text-decoration: none;
	background-color: #CFCFCF;
	width: 230px;
	margin-bottom: 10px;
	padding-top: 10px;
	padding-left: 20px;
	padding-bottom: 10px;
	font-size: 1.2em;
}
aside .aside_nav a {
	text-decoration: none;
	color: #3E3E3E;
}
#wrap aside .aside_nav:hover {
	background-color: #E4E4E4;
	color: #CBCBCB;
}
/* bt bt_flow */
#flow_nav {
	margin-top: 18px;
	margin-bottom: 20px;
	overflow:hidden;
}
.bt_flow {
	color: #eeeeee;
	text-decoration: none;
	background-color: #333333;
	width: 248px;
	padding-top: 0.3em;
	padding-left: 0px;
	padding-bottom: 0.3em;
	float: left;
	padding-right: 0px;
	text-align: center;
	border: 1px solid #666666;
}
.bt_flow a {
	text-decoration: none;
	color: #eeeeee;
}
.bt_flow:hover {
	background-color: #666666;
}
/* bt bt_const */
.bt_const {
	color: #eeeeee;
	text-decoration: none;
	background-color: #333333;
	width: 138px;
	margin-bottom: 20px;
	padding-top: 0.3em;
	padding-left: 0px;
	padding-bottom: 0.3em;
	font-size: 1.2em;
	float: left;
	padding-right: 0px;
	margin-top: 18px;
	text-align: center;
	border: 1px solid #666666;
}
.bt_const a {
	text-decoration: none;
	color: #eeeeee;
}
.bt_const:hover {
	background-color: #666666;
}
/* bt aside_banner1 */
.aside_banner1 {
	color: #FFFFFF;
	text-decoration: none;
	background-color: #541c45;
	width: 250px;
	margin-bottom: 10px;
	padding-top: 10px;
	padding-left: 20px;
	padding-bottom: 10px;
	font-size: 1.2em;
}
aside .aside_banner1 a {
	text-decoration: none;
	color: #FFFFFF;
}
aside .aside_banner1:hover {
	background-color: #832E6C;
}
/* bt aside_banner2 */
.aside_banner2 {
	color: #FFFFFF;
	text-decoration: none;
	background-color: #1f827f;
	width: 250px;
	margin-bottom: 10px;
	padding-top: 10px;
	padding-left: 20px;
	padding-bottom: 10px;
	font-size: 1.2em;
}
aside .aside_banner2 a {
	text-decoration: none;
	color: #FFFFFF;
}
aside .aside_banner2:hover {
	background-color: #2BAFAB;
}
/* bt aside_banner3 */
.aside_banner3 {
	color: #FFFFFF;
	text-decoration: none;
	background-color: #71631A;
	width: 250px;
	margin-bottom: 10px;
	padding-top: 10px;
	padding-left: 20px;
	padding-bottom: 10px;
	font-size: 1.2em;
}
aside .aside_banner3 a {
	text-decoration: none;
	color: #FFFFFF;
}
aside .aside_banner3:hover {
	background-color: #AB9627;
}

main article #case_image {
	margin-bottom: 20px;
}
main article #case_image img {
	width: 800px;
	height: auto;
}
main article #case_data {
	padding-top: 0px;
}
article #case_data p {
	margin-top: 0px;
}
main article #genga_image img {
	width: 800px;
	height: auto;
}
main article #original_image {
	clear: both;
	padding-top: 10px;
}
main article #original_image img {
	width: 800px;
	height: auto;
}


table {
	border-collapse: collapse;
	width: 100%;
	margin-bottom: 20px;
}
th {
	width: 100px;
	background-color: #EEEEEE;
	color: #000000;
	font-weight: normal;
	text-align: left;
}
th,td {
	padding: 8px;
	border-right: 1px solid #999999;
	border-bottom: 1px solid #999999;
}
input,textarea {
	background-color: #eeeeee;/*問合せフォームテキストエリア*/
}
.float_left {
	float: left;
	margin-right: 20px;
	margin-bottom: 10px;
}
.float_clear   {
	clear: both;
}
.float_right   {
	float: right;
}
main #page_nav  {
	text-align: center;
	margin-top: 20px;
	margin-bottom: 20px;
	clear: both;
}
/* page top icon */
#pageTop {
	position: fixed;
	bottom: 40px;
	right: 40px;
	padding-top: 2px;
	font-size: 1.5em;
}
#pageTop a {
  display: block;
  z-index: 999;
  padding: 0px;
  border-radius: 40px;
  width: 45px;
  height: 45px;
  background-color: #333333;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  text-align: center;
}
#pageTop a:hover {
  text-decoration: none;
  opacity: 0.7;
}


/* SNS */
#share ul{
	height: auto;
	padding-left: 0px;
}
#share li{
	font-size: 10px;
	float: left;
	text-align: center;
	margin-right: 1%;
	margin-bottom: 8px;
	border-radius: 3px;
	list-style: none;
}
#share li.share-twitter{
	background:#55acee;
	box-shadow:0 2px #2795e9;
}
#share li.share-twitter:hover{
	background:#83c3f3;
}
#share li.share-facebook{
	background:#3b5998;
	box-shadow:0 2px #2d4373;
}
#share li.share-facebook:hover{
	background:#4c70ba;
}
#share li.share-line{
	background:#00C300;
	box-shadow:0 2px #009d00;
}
#share li.share-line:hover{
	background:#2bd92b;
}
#share a{
	display:block;
	height:18px;
	padding:0px 8px 5px 8px;
	color:#ffffff;
	text-decoration:none;
}
#share a:hover{
	text-decoration:none;
	color:#ffffff;
}
#works_nav {
	border-top: 1px solid #666666;
	border-bottom: 1px solid #666666;
	margin-top: 20px;
	margin-bottom: 20px;
	padding-top: 10px;
	padding-bottom: 10px;
}
#works_nav p a {
	color: #333333;
	text-decoration: none;
}
#works_nav p a:hover {
	color: #999999;
}
#works_nav p {
	margin-bottom: 0px;
	margin-top: 0px;
	text-align: center;
}
.center {
	text-align: center;
}
main article blockquote {
	background-color: #EEEEEE;
	margin-top: 30px;
	padding-top: 10px;
	padding-right: 14px;
	padding-bottom: 10px;
	padding-left: 14px;
	margin-bottom: 30px;
	display: block;
	border-radius: 4px;
	text-align: justify;
}
article blockquote p {
	line-height: 1.8em;
	margin-top: 0px;
	margin-bottom: 0px;
}
#pageTop a .pageTopIcon {
	font-size: 5%;
}
/* Topic Button */
.square_btn {
	display: block;
	padding: 0.3em 1em;
	text-decoration: none;
	color: #333333;
	border: 1px solid #1D3F55;
	border-radius: 3px;
	transition: .4s;
	margin-top: 2em;
	margin-bottom: 2em;
}

.square_btn:hover {
	background-color: #333333;
	color: white;
}

/* Topic Button2 */
.square_btn2 {
	display: block;
	padding: 0.3em 1em;
	text-decoration: none;
	color: #333333;
	border: 1px solid #1D3F55;
	border-radius: 3px;
	transition: .4s;
	margin-top: 2em;
	margin-bottom: 2em;
	background-color: #DEE7FB;
}

.square_btn2:hover {
	background-color: #333333;
	color: white;
}

.attention {
	background-color: #EFEFEF;
	padding: 0.5em;
	margin-top: 10px;
	margin-bottom: 10px;
	border: 1px dotted #9F9D9D;
	border-radius: 6px;
	color: #000000;
	font-weight: bold;
	font-size: 1.1em;
}
.attention p {
	padding: 0;
	margin: 0;
}
.note li {
	margin-bottom: 10px;
	line-height: 1.8em;

}

.note {
	background-color: #EFEFEF;
	padding: 0.5em;
	margin-top: 10px;
	margin-bottom: 20px;
	border: 1px solid #9F9D9D;
	border-radius: 6px;
	color: #000000;
}
.so_design {
	margin: 5px 5px 30px 5px;
	padding: 5px;
	float: left;
	border: 1px solid #DDDDDD;
}
.so_type {
	margin: 5px 5px 30px 5px;
	padding: 5px;
	float: left;
	border: 1px solid #DDDDDD;
}
.so_result_item {
	margin: 10px;
	padding-top: 10px;
	padding-right: 20px;
	padding-left: 20px;
	padding-bottom: 10px;
	float: left;
	border: 1px solid #BBBBBB;
	color: #000000;
	font-weight: bold;
	font-size: 1.2em;
}
.so_size {
	margin: 5px 5px 30px 5px;
	padding: 5px;
	border: 1px solid #EEEEEE;
}

/* 実績のボタン */
#works_li {
	text-indent: 0px;
	padding: 0;
	margin: 0;
}
#works_li li  {
	display: block;
	width: 42%;
	height: 4em;
	margin: 0 10px 20px 10px;
	padding: 10px 10px 0 10px;
	float: left;
	border-radius: 8px;
	border: 1px solid #EEEEEE;
	font-size: 1.2em;
	list-style-position: inside;
	list-style-image: none;
	list-style-type: none;
}
#works_li li:hover {
	opacity:0.7;
}
#works_li a li{
	text-decoration: none;
	color: #FFFFFF;
	background-size: cover;
}
#works_li a li.private {
	background-image: url(/images/bt_house.jpg)!important;
}
#works_li a li.public {
	background-image: url(/images/bt_public.jpg);
}
#works_li a li.temple {
	background-image: url(/images/bt_religion.jpg);
}
#works_li a li.church {
	background-image: url(/images/bt_church.jpg);
}
#works_li a li.education {
	background-image: url(/images/bt_education.jpg);
}
#works_li a li.commerce {
	background-image: url(/images/bt_commerce.jpg);
}
#works_li a li.restoration {
	background-image: url(/images/bt_culture.jpg);
}


/* tag_cloud */

#tag_cloud ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
#tag_cloud ul li {
  display: inline-block;
  margin: 0 .3em .3em 0;
  padding: 0;
}
#tag_cloud ul li a {
  display: inline-block;
  max-width: 100px;
  height: 28px;
  line-height: 28px;
  padding: 0 1em;
  background-color: #fff;
  border: 1px solid #aaa;
  border-radius: 3px;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  color: #333;
  font-size: 13px;
  text-decoration: none;
  -webkit-transition: .2s;
  transition: .2s;
}
#tag_cloud ul li a:hover {
  background-color: #3498db;
  border: 1px solid #3498db;
  color: #fff;
}

/* searchform */
  .search_form {
      margin: 10px;
  }
  #searchform2 {
      position: relative;
  }
  #keywords2  {
      width: 240px;
      height: 25px;
      background: #fff;
      border: 1px;
      padding: 4px;
      color: #f00;
  }
  #searchBtn2 {
      position: absolute;
      top: 0;
      _top: 1px;
      left: 250px;
  }
  *:first-child + html #searchBtn2    {
      top: 1px;
  }

/* tab */

.tab{
	overflow: hidden;
}
main article ul {
	padding: 0;
	margin: 0;
	list-style-type: none;
	list-style-image: none;
}
article .tab li {

}

.tab li{
	background: #ccc;
	padding: 5px 25px;
	float: left;
	margin-right: 1px;
	list-style-image: none;
	list-style-type: none;
}
.tab li.select{
	background: #eee;
	list-style-image: none;
}
.content li{
	background: #eee;
	padding: 20px;
	list-style-type: none;
}
.hide {display:none;}
.blog_article {
	clear: both;
	float: none;
	margin-top: 0px;
	margin-bottom: 20px;
}


/* btn_submit */
p.btn_submit input{
  display       : inline-block;
  font-size     : 1.2em;        /* 文字サイズ */
  text-align    : center;      /* 文字位置   */
  cursor        : pointer;     /* カーソル   */
  padding       : 12px 27px;   /* 余白       */
  background    : #cccccc;     /* 背景色     */
  color         : #000000;     /* 文字色     */
  line-height   : 1em;         /* 1行の高さ  */
  transition    : .3s;         /* なめらか変化 */
  border        : 2px solid #eeeeee;    /* 枠の指定 */
}
p.btn_submit input:hover {
  color         : #000000;
  background    : #ffffff;
}
p.btn_submit {
	padding-bottom: 3em;
}

/* drawer menu */
#nav-drawer {
  display:none;
}




/* ========================================== */
/* 768px以下用（タブレット／スマートフォン用）の記述 */
@media screen and (max-width: 768px) {

	#wrap {
		width: auto ;
		padding: 0;
		margin: 0;
		overflow: hidden ;
	}

	/* start drawer */
	#nav-drawer {
	  display:block;
	  position: relative;
		padding: 10px;
		color: #fff;
	}
	/*チェックボックス等非表示*/
	.nav-unshown {
	  display:none;
	}
	/*space of icon*/
	#nav-open {
	  display: inline-block;
	  width: 30px;
	  height: 22px;
	  vertical-align: middle;
	}
	/*drawer icon*/
	#nav-open span, #nav-open span:before, #nav-open span:after {
	  position: absolute;
	  height: 3px;/*線の太さ*/
	  width: 25px;/*長さ*/
	  border-radius: 3px;
	  background: #fff;
	  display: block;
	  content: '';
	  cursor: pointer;
	}
	#nav-open span:before {
	  bottom: -8px;
	}
	#nav-open span:after {
	  bottom: -16px;
	}
	/*閉じるカバー*/
	#nav-close {
	  display: none;
	  position: fixed;
	  z-index: 99;
	  top: 0;
	  left: 0;
	  width: 100%;
	  height: 100%;
	  background: black;
	  opacity: 0;
	  transition: .3s ease-in-out;
	}
	/*中身*/
	#nav-content {
	  overflow: auto;
	  position: fixed;
	  top: 0;
	  left: 0;
	  z-index: 9999;/*最前面*/
	  width: 70%;/*閉じるカバー右側隙間*/
	  max-width: 330px;/*最大幅*/
	  height: 100%;
	  background-color:rgba(200,200,200,0.8);
	  transition: .3s ease-in-out;
	  -webkit-transform: translateX(-105%);
	  transform: translateX(-105%);/*左に隠す*/
	}
	#nav-content ul {
		margin: 0px;
		padding: 0px;
		}
	#nav-content ul li {
		background-color: #fff;
		border: solid 1px #ccc;
		list-style-type: none;
		padding: 10px;
	  }
	#nav-content a {
		  color: #333;
		  text-decoration: none;
	  }
	/*チェックで表示*/
	#nav-input:checked ~ #nav-close {
	  display: block;/*カバー表示*/
	  opacity: .5;
	}
	#nav-input:checked ~ #nav-content {
	  -webkit-transform: translateX(0%);
	  transform: translateX(0%);/*中身表示（右スライド）*/
	  box-shadow: 6px 0 25px rgba(0,0,0,.15);
	}
	/* end drawer */


	header {
		width: 90%;
	}
	header img {
		width: 100%;
		height: auto;
	}
	#visual {
		width: 90%;
	}
	#visual img {
		width: 100%;
		height: auto;
	}

	#nav_out {
		display:none;
	}


	main {
		clear: both;
		width: auto;
		float: none;
		margin: 0;
		padding: 3em;
	}
	main article {
	}
	main article img {
		width:auto;
		height:auto;
		max-width:100%;
		max-height:100%;
	}
	h1,h2 {
		clear: both;
	}
	#const_nav{
		padding-bottom: 2em;
	}
	.bt_const {
		width: 85%;
		margin: 0px;
		padding: 0.7em;
		float: none;
	}



	main #carousel {
		width: auto;
	}
	main #carousel img {
		width: 100% ;
		height: auto ;
	}
	#carousel .single-item{
		max-width: 100%;
	}

	main .preview  {
		width: 130px;
    height: 130px;
    float: left;
    margin: 10px;
	}
	main .preview img  {
		width: 95%;
		height: 95%;
		object-fit: cover;
	}
	main .preview p {
		display:none;
	}

	main article #case_image {
		width: 100%;
	}
	main article #case_image img,
	main article #genga_image img,
	main article #original_image img {
		min-width: 100% ;
		height: auto ;
	}
	main article #case_data {
		width: 100%;
	}


	aside {
		overflow: auto;
		clear:both;
		float: none;
		width: auto;
		margin: 0;
		padding: 3em;
	}
	.aside_nav,
	.aside_banner1,
	.aside_banner2,
	.aside_banner3
	 {
		width: 85%;
		float:left;
	}
	.aside_banner1 {
		clear:both;
	}

	aside iframe {
		width: auto !important;
	}

	aside .search_form{
		margin: 2em;
	}

	/* SNS */
	#share li{
		font-size:14px;
		width:74px;
	}


	footer {
		margin: 0px;
		padding: 1em 3em 2em;
		clear: both;
		width: 100%;
	}
	footer #footer_inner {
		width: 100%;
		margin: 0px;
		padding: 0px;
	}
	footer #footer_address {
		width: 100%;
		margin: 0px;
		padding: 0px;
	}
	footer #footer_address p {
		font-size: 0.6em;
		clear: both;
	}
	footer #footer_address iframe {
		width: 88%;
		margin-left:0px;
	}

	footer #footer_nav1,
	footer #footer_nav2{
		width: 50%;
	}

	footer #copy_rights  {
		width: 100%;
		height: 250px;
		text-align: left;
	}
	footer #copy_rights img  {
		width: 80%;
	}

}
/* ▲ここまで 768px以下用（タブレット／スマートフォン用）の記述 */

/* ========================================== */
/* 480px以下用（スマートフォン用）の記述 */
@media screen and (max-width: 480px) {

	header,
	#visual {
		width: 100%;
	}
	main {
		padding: 2em;
	}

	main .preview  {
		width: 47%;
    height: 47%;
    float: left;
    margin: 3px;
	}

	aside {
		padding: 2em;
	}
	aside iframe {
		margin-left: -1.3em;
	}

	footer {
		padding: 0px;
	}
	footer #footer_address iframe {
	    margin-left: -1em;
	}
	footer #copy_rights  {
		height: auto;
	}



}
/* ▲ここまで 480px以下用（スマートフォン用）の記述 */

/* 電話発信ボタン用のCSS */
	#footer_address p a {
	font-style: normal;
	color: #FFFFFF;
	text-decoration: none;
	}


/*▼ここから カスタムCSS▼ */

/* 実績テーブル */
.history {
width: 100%;
}
.history th,
.history td {
border: 1px solid #ccc;
padding: 20px;
}
 
.history th {
	width: 75px;
	line-height: 1.5;
	font-weight: bold;
	background-color: #eeeeee; 
}
 
@media screen and (max-width: 767px) {
.history td,
.history th {display:block;}
.history th {
	width:auto;
	padding: 5px;
}
	.history td{border: none}
}

.year{
   font-weight: normal;
	font-size: 0.9em;
	letter-spacing: 0.06em;
}

/* 施工データテーブル */
.sdata {
width: 100%;
}
.sdata th,
.sdata td {
	border: 1px solid #ccc;
}
 
.sdata th {
	text-align:center ; 
	font-weight: bold;
	background-color: #eeeeee; 
}
.sdata td {
	padding-left: 20px;	
}

@media screen and (max-width: 767px) {
.sdata th,
.sdata td {
	font-size: 0.8em;
}
}



/* バッジ */
.blue-badge, .green-badge, .repair-badge {
  padding: 3px 6px;
  margin-right: 8px;
  margin-left: 1px;
  font-size: 75%;
  color: white;
  border-radius: 6px;
  box-shadow: 0 0 3px #ddd;
  white-space: nowrap;
}

.blue-badge {
  background-color: #4682B4; /*青*/
}

.green-badge {
  background-color: #228B22; /*緑*/
}

.repair-badge {
 background-color: #B22222; /*赤*/
}

/* 矢印アイコン */
.arrow{
position: relative;
display: inline-block;
padding: 0 0 0 16px;
color: #000;
vertical-align: middle;
text-decoration: none;
font-size: 15px;
}
.arrow::before,
.arrow::after{
position: absolute;
top: 0;
bottom: 0;
left: 0;
margin: auto;
content: "";
vertical-align: middle;
}

.sample4-3::before{
width: 12px;
height: 12px;
-webkit-border-radius: 25%;
border-radius: 25%;
background: #F00;/*赤*/
}
.sample4-3::after{
left: 5px;
box-sizing: border-box;
width: 3px;
height: 3px;
border: 3px solid transparent;
border-left: 3px solid #fff;
}

/*ロールオーバーリスト  */

.list-links {
  width: 100%;
}

.list-links > li {
  position: relative;
  border-bottom: 1px solid #e7e7e7;
}

.list-links > li a {
	background: #ffffff;
  display: block;
  position: relative;
  padding: 15px 30px 15px 30px; /* 左右にアイコン分を考慮した余白を指定 */
  font-weight: normal;
}

.list-links > li :hover{
  background: #B0C4DE;
}

/*フォントスムージング */
.antialiased {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/*コンタクトフォーム */
.contact table {
   border-collapse: collapse; /* 隣り合うセルの線を結合 */
   border: 2px solid blue;    /* 外側は青色の実線2px */
}
.contact td {
   border: 1px solid blue;    /* 内側は青色の実線1px */
}