html{
	height:100%;
}

body {
	margin: 0;
	padding: 0;
	font-family: Arial, Helvetica, sans-serif;
	font-size: 16px;
	color: #000000;
	/*background: #eeeeee;*/
	background: #ffffff;
	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;}

.image_full_width{
	width:98%;
}
.image_full_width_sp{
	width:98%;
}

/* Header */

#topBar{
	width:100%;
	color:#ffffff;
	background: #6f8a5d url(images/familytree_header_background.png) repeat;
}
#topBar a{
	color:#ffffff;
}

#breadcrumbs{
	float:left;
	margin:0 0 0 10px;
	padding: 0;
	height:100%;
	vertical-align:middle;
	font-size:14px;
	line-height:20px;
	list-style: none;
}

#breadcrumbs li{
	float: left;
	margin: 0;
}
#breadcrumbs a{
	/*text-decoration:none;*/
}

#topBarMenu{
	float:right;
	margin-right:10px;
	margin-bottom:10px;
	font-size:12px;
}
#header{
	background: #6f8a5d url(images/familytree_header_background.png) repeat;
	width:100%;
}

#header_wrapper{
	width:100%;
}

/* Logo */

#logo {
	padding-left:10px;
	padding-top:10px;
}
#spMainHeaderLogo,#spMainHeaderSample{
	width:320px;
	display:block;
	margin:0 auto;
}

#main{
	width:100%;
	margin:0;
	background:#eeeeee;
}
#mainHeader{
	width:100%;
	height:100px;
}
#mainHeaderLogo{
	float:left;
	width:90%;
	margin:5px;
}
#mainHeaderText,#spMainHeaderText{
	float:left;
	width:270px;
	min-height:50px;
	margin:5px;
	color:red;
	font-size:12px;
}
#mainHeaderPMark,#spMainHeaderPMark{
	float:right;
	display:block;
	width:50px;
	height:50px;
	margin:5px;
}

#slider{
	/*height:350px;*/
}

#main_content{
	width:98%;
	margin: 20px auto 10px auto;
}
#sub_content{
	width:100%;
	margin: 20px auto;
}
#page{
	/*width:100%;*/
	background:#ffffff;
	padding:10px;
	margin-bottom:10px;
}
.familyTreeButtonFrame{
	width:100%;
	text-align:center;
	margin-top:8px;
}
.familyTreeButton{
	width:300px;
}
#columns{
	width:100%;
	display: flex;
    flex-direction:column;
}
.column{
	width:100%;
	height:240px;
	margin-bottom:10px;
	background:#ffffff;
	position:relative;
}
.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;
}
#column1{
	order:6;
	-webkit-order:6;
}
#column2{
	order:7;
	-webkit-order:7;
}
#column3{
	order:8;
	-webkit-order:8;
}
#column4{
	order:3;
	-webkit-order:3;
}
#column5{
	order:4;
	-webkit-order:4;
}
#column6{
	order:5;
	-webkit-order:5;
}
#column7{
	order:1;
	-webkit-order:1;
}
#column8{
	order:9;
	-webkit-order:9;
}
#column9{
	order:2;
	-webkit-order:2;
}
.app_icon{
	height:60px;
	width:60px;
}
.app_dl{
	height:30px;
}
.app{
	margin:0 auto;
	width:220px;
}
.column_app a{
	position:static;
    text-indent:0px;
}
.center{
	display: block;
	margin: 5px auto;
}

.app_image{
	width:98%;
}
.bannerBig{
	width:98%;
	margin:5px auto;
}
.bannerBig img{
	width:100%;
}
.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:100%;
	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:98%;
}
.sidebar_right_content{
	width:100%;
	background:#ffffff;
	padding:5px;
	box-sizing: border-box;
	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:60%;
	display:block;
	margin:0 auto;
}
.premium_button{
	/*width:192px;*/
}
.sidebar_right_content img{
	display:block;
	margin:0 auto;
	width:80%;
}
#news_scroll{
	font-size:12px;
}
.news_date{
	width:80px;
}

#header_ad {
	margin:10px 0;
}

#header_links {
	font-size:14px;
	color: #FFFFFF;
	font-family:'ヒラギノ明朝 Pro W3','Hiragino Mincho Pro','ＭＳ 明朝',serif;
}

#header a {
	color: #FFFFFF;
	text-decoration: none;
}

#header a:hover {
	border: none;
	text-decoration: underline;
	color: #FFFFFF;
}

.menu{
	font-size:18px;
}

/* Content */

#content2{
	width:100%;
	padding: 0;
	display: flex;
  flex-direction: column;
  min-height: 100vh;
}

#content {
	width: 98%;
	margin: 10px auto;
}
#topButtons{
	width:100%;
}
.buttonsFrame{
	width:294px;
	margin:0 auto;
}
.topButton{
	width:90px;
	height:75px;
	margin:4px;
	display:block;
	float:left;
}

#formSp-form{
	margin:0 auto;
}

/* Footer */

#footer {
	background: #6f8a5d url(images/familytree_header_background.png) repeat;
	width:100%;
	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: #1E4912;
	text-decoration: none;
	border: none;
}

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

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

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

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

#footerButton{
	height:50px;
}

#footerAd{
	width:100%;
	height:50px;
	margin:0 auto;
}

/* 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;
}*/
input, textarea {
	font-size: initial;
}

/* red */

.red{
	color:red;
}


span.required {
	color: red;
}



.spNone{
	display:none;
}

#app_ad{
	width:100%;
	height:50px;
	position: relative;
	background: #FFFFFF url(images/background.jpg) repeat;
}
.app_ad_img{
	position: absolute;
    top: 1px;
    left: 10px;
}
.app_ad_message{
	position: absolute;
    top: 3px;
    left: 60px;
    bottom: 3px;
    right: 190px;
    font-size:10px;
    line-height:12px;
}
.app_ad_banner{
	position: absolute;
    top: 3px;
    right: 35px;
}
.app_ad_banner_img{
	/*height:22px;*/
}
.close-meerkat{
	position: absolute;
    top: 2px;
    right: 5px;
    display:none;
}

#app_ad_space{
	width:100%;
	height:50px;
}


/* 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");
}

#familyTreeWrapper{

}
#familyTreeButtons1{
	height:94px;
}
#familyTreeButtons2{
	height:20px;
	border-bottom:solid 2px #4b4b4b;
	vertical-align:bottom;
}
#familyTreeButtons2 li{
	float:left;
	list-style-type: none;
}

#familyTreeButtons2 a{
	border-top:solid 2px #4b4b4b;
	border-left:solid 2px #4b4b4b;
	border-right:solid 2px #4b4b4b;
	padding:5px 10px;
}

#familyTreeFrame{
	width:100%;
	height:100%;
	position: relative;
	background:#ffffff;
	overflow:auto;
}
#familyTreeName{
	top:0px;
	left:40%;
	padding: 1px 10px;
	font-size:16px;
	line-height: 18px;
	background:#E5E5E5;
	position:absolute;
	z-index:100;
}
#familyTreeArea{
	/*top:60px;
	left:60px;
	bottom:60px;
	right:60px;*/
	/*overflow:scroll;
  	-webkit-overflow-scrolling: auto;
	overflow-scrolling: auto;*/
	background:#ffffff;	/*�f�t�H���g��*/
	/*position:absolute;*/
}
#familyTreeRollTop{
	top:0px;
	left:0px;
	right:0px;
	height:20px;
	visibility:hidden;
	position:absolute;
}
#familyTreeRollRight{
	top:0px;
	bottom:0px;
	right:0px;
	width:0px;
	visibility:hidden;
	position:absolute;
}
#familyTreeRollBottom{
	bottom:0px;
	left:0px;
	right:0px;
	height:0px;
	visibility:hidden;
	position:absolute;
}
#familyTreeRollLeft{
	top:0px;
	bottom:0px;
	left:0px;
	width:20px;
	visibility:hidden;
	position:absolute;
}
#familyTreeRollCoreTop{
	top:20px;
	left:20px;
	width:20px;
	height:15px;
	background:#8C6239;
	visibility:hidden;
	position:absolute;
}
#familyTreeRollCoreBottom{
	bottom:20px;
	left:20px;
	width:20px;
	height:15px;
	background:#8C6239;
	visibility:hidden;
	position:absolute;
}

.btn-flat-border1 {
  display: inline-block;
  padding: 0.3em 0.5em;
  text-decoration: none;
  color: #4b4b4b !important;
  border: solid 2px #4b4b4b !important;
  border-radius: 15px !important;
  transition: .4s;
}

.btn-flat-border2 {
  display: inline-block;
  padding: 0.3em 0.5em;
  text-decoration: none;
  color: #54a333 !important;
  border: solid 2px #54a333 !important;
  border-radius: 15px !important;
  transition: .4s;
}

.btn-flat-border3 {
  display: inline-block;
  padding: 0.3em 0.5em;
  text-decoration: none;
  color: #2eb8e6 !important;
  border: solid 2px #2eb8e6 !important;
  border-radius: 15px !important;
  transition: .4s;
}

.btn-flat-border4 {
  display: inline-block;
  padding: 0.3em 0.5em;
  text-decoration: none;
  color: #ff0000 !important;
  border: solid 2px #ff0000 !important;
  border-radius: 15px !important;
  transition: .4s;
}

.btn-zoom{
	display: inline-block;
  padding: 0.3em 0.5em;
  text-decoration: none;
  color: #f48122 !important;
  border: solid 2px #f48122 !important;
}

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

#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;
}

#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;
}

#sns{
	margin-bottom:10px;
	padding:0 5px;
	box-sizing: border-box;
}

#description{
	padding:0 5px;
	box-sizing: border-box;
}

.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;
	order:10;
	-webkit-order:10;
}

.customerList{
	height:70px;
	width:130px;
	margin:5px 5px 15px 5px;
	text-align:center;
	float:left;
}
.customerList img{
	max-height:40px;
}

.ad300{
	width:300px;
	margin:0 auto;
}