html{
	height:100%;
}

body {
	margin: 0;
	padding: 0;
	font-family: Arial, Helvetica, sans-serif;
	font-size: 16px;
	color: #000000;
	background: #eeeeee;
	font-family:'ヒラギノ角ゴ ProN W3','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
	-webkit-text-size-adjust:none;
}

h1, h2, h3 {
	margin: 0;
	padding: 0;
	font-weight: bold;
	color: #1E4912;
}

img {
	border: none;
}

a {
	color: #2E3192;
}

a:hover {
	border: none;
	text-decoration: none;
	color: #2E3192;
}

.clear { clear:both; }
.left{float:left;}

/* Header */


#topBar{
	width:100%;
	height:38px;
	color:#ffffff;
	font-size:14px;
	background: #6f8a5d url(images/familytree_header_background.png) repeat;
}
#topBar a{
	color:#ffffff;
}

#breadcrumbs{
	float:left;
	margin:0 0 0 30px;
	padding: 0;
	height:100%;
	vertical-align:middle;
	line-height:38px;
	list-style: none;
}

#breadcrumbs li{
	float: left;
	margin: 0;
	height:100%;
	vertical-align:middle;
}
#breadcrumbs a{
	/*text-decoration:none;*/
}

#topBarMenu{
	float:right;
	margin-right:30px;
	height:100%;
	vertical-align:middle;
	line-height:38px;
}

#header{
	background: #6f8a5d url(images/familytree_header_background.png) repeat;
	height:140px;
	width:100%;
}

#header_wrapper{
	width:960px;
	height:140px;
	margin:0 auto;
	position: relative;
}


/* Logo */

#logo {
	padding-left:10px;
	padding-top:10px;
}

#main{
	width:100%;
	min-width:960px;
	margin:0;
	background:#eeeeee;
}
#mainHeader{
	width:960px;
	height:60px;
	margin:0 auto;
}
#mainHeaderLogo{
	float:left;
	display:box;
	width:440px;
	height:50px;
	margin:5px;
}
#mainHeaderText{
	float:left;
	margin:5px;
	color:red;
}
#mainHeaderPMark{
	float:right;
	display:box;
	width:50px;
	height:50px;
	margin:5px;
}

#slider{
	height:350px;
}

#main_content{
	width:960px;
	margin: 10px auto;
}
#sub_content{
	width:960px;
	margin: 20px auto;
}
#page{
	width:600px;
	background:#ffffff;
	padding:10px;
	float:left;
}
.familyTreeButtonFrame{
	width:100%;
	text-align:center;
}
.familyTreeButton{

}
#columns{
	width:620px;
	float:left;
}
.column{
	width:31%;
	height:280px;
	margin-right:2%;
	margin-bottom:20px;
	position:relative;
	float:left;
	background:#ffffff;
}
.column_img_frame{
	width:100%;
	height:122px;
	margin:0;
	text-align: center;
	vertical-align: middle;
	overflow:hidden;

}
.column_img_frame img{
	position: relative;
	top: 50%;
    left: 50%;
    width: 100%;
    height: auto;
	-webkit-transform: translate(-50%,-50%);
	-ms-transform: translate(-50%,-50%);
	transform: translate(-50%,-50%);
}
.column h3{
	font-size:18px;
	margin:5px;
}
.column_text{
	margin:5px;
}
.column a{
	position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    text-indent:-999px;
}
.column_app{
	height:40px;
	margin:5px;
}
.app_icon{
	height:60px;
	width:60px;
}
.app_dl{
	height:30px;
}
.column_app a{
	position:static;
    text-indent:0px;
}
.center{
	display: block;
	margin: 5px auto;
}
.storeButton{
	height:30px;
}
.bannerBig{
	width:728px;
	margin:5px auto;
}
.whiteBack{
	width:100%;
	background:white;
}
.title{
	width:100%;
	text-align:center;
	color:#5f7d4c;
	font-size:24px;
}
.centerText{
	width:100%;
	text-align:center;
}
.buttonLoginRegist{
	width:326px;
	height:64px;
}
.buttonMenuWrapper{
	width:100%;
	margin-top:10px;
}
.buttonMenuHeader{
	width:100%;
	color:#5f7d4c;
	font-size:18px;
	background:#e7f0d0;
	border: 1px #959595 solid;
	border-collapse: collapse;
	box-sizing: border-box;
}
.buttonMenu{
	width:50%;
	height:130px;
	background:white;
	border: 1px #959595 solid;
	border-collapse: collapse;
	box-sizing: border-box;
	float:left;
	line-height:1.2em;
}
.buttonMenuImg{
	margin:5px;
	width:110px;
	height:110px;
	display:block;
	float:left;
}
.buttonMenuContents{
	float:right;
	width:185px;
	padding:5px 0 0 0;
}
.buttonMenuTitle{
	background:#448aca;
	width: fit-content;
	border: 1px #959595 solid;
	border-radius:8px;
	color:white;
	font-size:16px;
	padding:1px;
}


#sidebar_right{
	width:320px;
	float:right;
}
.sidebar_right_content{
	width:100%;
	background:#ffffff;
	padding:5px;
	margin-bottom:20px;
}
.sidebar_right_content h3{
	background:url("../images/familyTree/kamonIcon.png") no-repeat;
	padding-left:40px;
	height:32px;
	margin:10px 0;
}
.sidebar_right_banner_content{
	width:100%;
	padding:5px;
	text-align:center;
}
.graph_text{
	color:red;
	font-size:18px;
}
.graph{
	width:100%;
}
.premium_button{
	/*width:100%;*/
}
.sidebar_right_content img{
	display:block;
	margin:0 auto;
	width:80%;
}
.banner300{
	width:300px;
	display:block;
	margin:0 auto;
}
.ad300{
	width:300px;
	margin:0 auto;
}
.sidebar_right_content input[type="text"],input[type="password"]{
	width:100px;
}
.sidebar_other_button{
	display:block;
	margin:0 0 0 5px !important;
	width:84% !important;
}
.sidebar_main_button{
	display:block;
	margin:0 0 0 5px !important;
	width:192px !important;
}
#news_scroll{
	max-height:500px;
	overflow:scroll;
	font-size:12px;
}
.news_date{
	width:80px;
}

#form-form{
	margin:0 auto;
}

/* Footer */

#footer {
	background: #6f8a5d url(images/familytree_header_background.png) repeat;
	width:100%;
	height: 30px;
	margin: 0 auto;
	padding: 10px 0;
	color: #ffffff;
	text-align:center;
}

#footer p {
	margin: 0;
	line-height: normal;
	font-size: 12px;
	text-align: center;
}

#footer a {
	color: #ffffff;
	text-decoration: none;
	border: none;
}

#footer a:hover {
	text-decoration: underline;
	color: #ffffff;
}

#footer hr{
	border-width: 1px 0px 0px 0px;
   	border-style: dashed;
   	border-color: #B3B3B3;
   	height: 1px;
}

#footer .sslSeal{
	float:left;
	margin-right:20px;
}

#footer .privacySeal{
	float:right;
	margin-left:20px;
}

.pcNone{
	display:none;
}

#app_ad{
	display:none;
}

/* inquiry */


#content .entry {
	padding: 10px 40px 15px 20px;
	text-align: left;
	/*text-align: justify;*/
}

#content .box2 {
width: 504px; /* �{�b�N�X�̉��� */
background-color: transparent; /* ���e�̔w�i�F */
border: 1px #C6C6C6 solid; /* �g���i�����E�F�E�X�^�C���j */
margin-top:5px;
font-size:1.2em;
}

#content .box2 H4 {
background-color: #2D3541; /* ���o���̔w�i�F */
font-size: 12pt; /* ���o���̕����T�C�Y */
margin: 0; /* �X�y�[�X���폜 */
padding: 3px;
color: #FFFFFF;
border-bottom: 1px #C6C6C6 solid; /* ���o�����̘g���i�����E�F�E�X�^�C���j */
}

#content .box2 P {
margin: 0; /* �X�y�[�X���폜 */
padding: 3px;
}

/* Form */
/*
input[type="text"],input[type="password"] {
	border:solid 1px #ccc;
	padding:6px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border-radius: 3px;
	-moz-box-shadow: inset 1px 4px 9px -6px rgba(0,0,0,0.5);
	-webkit-box-shadow: inset 1px 4px 9px -6px rgba(0, 0, 0, 0.5);
	box-shadow: inset 1px 4px 9px -6px rgba(0,0,0,0.5);
}

input[type="submit"] {
	-moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.2);
	-webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.2);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.2);
	text-shadow: 0px -1px 1px rgba(255, 255, 255, 0.8);
	cursor:pointer;
	padding:8px;
}*/

/* red */

.red{
	color:red;
}


span.required {
	color: red;
}

/* familyTree */

#design .unselected{
	border:1px #888888 solid;
	margin:4px;
}

#design .selected{
	margin:1px;
	border:2px #FCEE21 solid;
	padding:2px;
}

#design .design {

}

#design .bgcolor{
	width:20px;
	height:20px;
	float:left;
}

#design .bgdesign{
	width:20px;
	height:20px;
	float:left;
}

#design .paper{
	width:20px;
	height:20px;
	float:left;
}

#bgcolor0{
	background:#ffffff;
}
#bgcolor1{
	background:#808080;
}
#bgcolor2{
	background:#CEBE2C;
}
#bgcolor3{
	background:#5B8E55;
}
#bgcolor4{
	background:#3B6AE0;
}
#bgcolor5{
	background:#ED4B43;
}
#bgdesign0{
	background:url("../images/familyTree/bgdesign0.png");
}
#bgdesign1{
	background:url("../images/familyTree/bgdesign1.png");
}
#bgdesign2{
	background:url("../images/familyTree/bgdesign2.png");
}
#bgdesign3{
	background:url("../images/familyTree/bgdesign3.png");
}
#paper0{
	background:#FFFFFF;
}
#paper1{
	background:url("../images/familyTree/paper1.png");
}
#paper2{
	background:url("../images/familyTree/paper2.png");
}
#paper3{
	background:url("../images/familyTree/paper3.png");
}

#familyTreeFrame{
	width:100%;
	height:100%;
	position: relative;
	background:#ffffff;
}
#familyTreeName{
	top:10px;
	left:40%;
	padding: 2px 10px;
	font-size:36px;
	line-height: 40px;
	background:#E5E5E5;
	position:absolute;
	z-index:100;
}
#familyTreeArea{
	top:60px;
	left:0px;
	bottom:0px;
	right:0px;
	overflow:scroll;
	background:#ffffff;	/*�f�t�H���g��*/
	position:absolute;
}
#familyTreeRollTop{
	top:0px;
	left:0px;
	right:0px;
	height:60px;
	visibility:hidden;
	position:absolute;
}
#familyTreeRollLeft{
	top:0px;
	bottom:0px;
	left:0px;
	width:60px;
	visibility:hidden;
	position:absolute;
}

#tabs{
	float:left;
}
#sideAd{
	width:300px;
	height:100%;
	margin:0;
}

#side_menu{
	overflow:scroll;
}

#receiveMessageDiv{
	display:none;
	position:absolute;
	bottom:18px;
	right:18px;
}

#receiveMessageImg{
	width:83px;
	height:61px;
}

.proButton{
	font-size:14px;
	background:#2196F3;
	border: solid 1px #673AB7;
  	border-radius: 10px;
  	padding:3px;
}

	/*
	*	HELPER CLASSES
	*/
	.container {
		/* used for elements that should not have padding or scrollbars */
		padding:	0;
		overflow:	hidden;
	}
	.hidden {
		/* used to HIDE layout-panes until Layout initializes */
		display:	none;
	}

	/*
	 *	TAB CLASSES - STRUCTURAL, REQUIRED
	 */
	DIV#tabs { /* page-wrapper - used ONLY to 'wrap' tabButtons and tabPanels */
		position:	static	!important; /* overide UI Theme - prevent from becoming a positional wrapper */
		}
		UL#tabButtons ,
		DIV#tabPanels {
			margin:		0 !important; /* layout-panes should never have margins */
		}
		DIV#tabPanels {}
			DIV#tabs-1.tabPanel { /* container for tabLayout */
				height:		100%; /* need to 'fill' the tabPanels - layout container must have 'height' */
				/* padding:	0;    DO NOT set top- or bottom-padding because height=100% */
			}

.personsTimeLine:nth-child(even){
	background:#EEEEEE;
}
.personsTimeLine:nth-child(odd){
	background:#DDDDDD;
}

.popover {
	position: absolute;
	display: none;
	max-width: 300px;
	background-color: #ffe;
	border: 1px solid #666;
	border-radius: 3px;
	box-shadow: 0 5px 10px rgba(0,0,0,.2);
	-webkit-box-shadow: 0 5px 10px rgba(0,0,0,.2);
}

.popover .popover-content {
	padding: 10px;
}

.popover .arrow {
	border-style: solid;
	border-color: transparent;
	border-top-color: #666;
	border-width: 11px;
	border-bottom-width: 0;
	bottom: -11px;
	color: #333;
	height: 0;
	margin-left: -11px;
	position: absolute;
	width: 0;
}

.popover .arrow:after {
	content: " ";
	bottom: 1px;
	margin-left: -10px;
	border-color: transparent;
	border-style: solid;
	border-width: 10px;
	border-bottom-width: 0;
	border-top-color: #ffe;
	position: absolute;
	display: block;
	width: 0;
	height: 0;

}

.tip {
	text-decoration: underline;
	font-weight: bold;
	cursor: pointer;
}

.image_full_width{
	width:100%;
}

.is-hide{
 display:none;
}
.loading{
  position:fixed;
  top:0;
  right:0;
  bottom:0;
  left:0;
  background:rgba(0,0,0,.5);
}
.loading::before{
  content:"";
  display:block;
  position:fixed;
  left:50%;
  top:50%;
  width:50px;
  height:50px;
  border-radius:5px;
  margin-top:-15px;
  margin-left:-15px;
  background:white;
}
.loading::after{
  content:"";
  display:block;
  position:fixed;
  left:50%;
  top:50%;
  width:32px;
  height:32px;
  border-radius:20px;
  margin-top:-10px;
  margin-left:-10px;
  border:4px solid #60ABB9;
  border-right:4px solid white;
  animation: rotate 1s infinite linear;
}
.loadingSearch{
  position:fixed;
  top:0;
  right:0;
  bottom:0;
  left:0;
  background:rgba(0,0,0,.5);
}
.loadingSearch::before{
  content:"";
  display:block;
  position:fixed;
  left:50%;
  top:10%;
  width:50px;
  height:50px;
  border-radius:5px;
  margin-top:-15px;
  margin-left:-15px;
  background:white;
}
.loadingSearch::after{
  content:"";
  display:block;
  position:fixed;
  left:50%;
  top:10%;
  width:32px;
  height:32px;
  border-radius:20px;
  margin-top:-10px;
  margin-left:-10px;
  border:4px solid #60ABB9;
  border-right:4px solid white;
  animation: rotate 1s infinite linear;
}
@keyframes rotate {
  0%    { transform: rotate(0deg); }
  100%  { transform: rotate(360deg); }
}


#twitter-widgetoon-0,#twitter-widgetoon-1,#twitter-widgetoon-2,#twitter-widgetoon-3,#twitter-widgetoon-4,#twitter-widgetoon-5,#twitter-widgetoon-6,#twitter-widgetoon-7,#twitter-widgetoon-8,#twitter-widgetoon-9,#twitter-widgetoon-10 {
  height:20px!important;
}

.insta_btn2{/*ボタンの下地*/
  color: #FFF;/*文字・アイコン色*/
  border-radius: 4px;/*角丸に*/
  position: relative;
  display: inline-block;
  height: 20px;/*高さ*/
  width: 90px;/*幅*/
  text-align: center;/*中身を中央寄せ*/
  font-size: 11px;/*文字のサイズ*/
  line-height: 20px;/*高さと合わせる*/
  /*vertical-align: middle;*//*垂直中央寄せ*/
  background: -webkit-linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;
  background: linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;/*グラデーション①*/
  overflow: hidden;/*はみ出た部分を隠す*/
  text-decoration:none;/*下線は消す*/
}

.insta_btn2:before{/*グラデーション②*/
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;/*全体を覆う*/
  height: 100%;/*全体を覆う*/
  background: -webkit-linear-gradient(15deg, #ffdb2c, rgb(249, 118, 76) 25%, rgba(255, 77, 64, 0) 50%) no-repeat;
  background: linear-gradient(15deg, #ffdb2c, rgb(249, 118, 76) 25%, rgba(255, 77, 64, 0) 50%) no-repeat;
}

.insta_btn2 .fa-instagram{/*アイコン*/
  font-size: 16px;/*アイコンサイズ*/
  position: relative;
  /*top: 4px;アイコン位置の微調整*/
  vertical-align: middle;
}

.insta_btn2 span {/*テキスト*/
  display:inline-block;
  position: relative;
  transition: .5s
}

.customer{
	background:#ffffff;
	width:97%;
}

.customerList{
	height:60px;
	width:120px;
	margin:5px 5px 15px 5px;
	text-align:center;
	float:left;
}