@charset "utf-8";


/* common */
body .vm_clear_fix{ height:100%; }
body .vm_clear_fix:after{
	content:".";
	display:block;
	height:0;
	clear:both;
	visibility:hidden;
}
body #vm_column_index{
	width:960px;
	margin:0 auto;
  	padding:15px;
}
.textGray {
  color: #777;
}
/*++++++++++++++++++++++++++++++++++++++++++++
/*  Layout
++++++++++++++++++++++++++++++++++++++++++++*/

.contCenter {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 2rem;
    box-sizing: border-box;
}
/*++++++++++++++++++++++++++++++++++++++++++++
/*  Header　Layout
++++++++++++++++++++++++++++++++++++++++++++*/

header h1 {
    float: none;
    padding: .5rem 0 .7rem;
    font-weight: 700;
}

#headerArea {
    display: flex;
}

#headerArea>div img {
    width: 100%;
    height: auto;
}
/*++++++++++++++++++++++++++++++++++++++++++++
/*  header
++++++++++++++++++++++++++++++++++++++++++++*/

h1 {
  font-size: 1.2rem;
  line-height: 1;
}

.headerBtn01 {
  margin-left: auto;
}

.headerBtn02 {
	padding-left: 5px;
}
.headerBtn02 img {
	max-width: 222px;
	width: 100%;
	height: auto;
}
.headerBtn02 a {
	position: relative;
	overflow: hidden;
	display:block;
}
.headerBtn02 a::before {
    content: '';
    animation: brink 6.25s infinite;
    display: block;
    position: absolute;
    left: -100%;
    top: -40px;
    z-index: 2;
    width: 222px;
    height: 64px;
    transform: rotate(-60deg);
    background: linear-gradient(to bottom, rgba(255,255,255,0.0) 0%, rgba(255,255,255,0.8) 50%, rgba(255,255,255,0.0) 100%);
}
@media only screen and (min-width: 641px) {
	#headerArea .headerLogoBox img {
		max-width: 270px;
		width: 100%;
		height: auto;
	}
    #headerArea .headerBtn01 {
    }
    #headerArea .headerBtn02 {
    }
}
@media only screen and (max-width: 640px) {
    #headerArea {
        justify-content: center;
    }
    #headerArea .headerLogoBox {
        width: 100%;
        height: auto;
	padding: 5px 0 0 0;
    }
    #headerArea .headerLogoBox img {
        max-width: 180px;
	width: 100%;
        height: auto;
	text-align: center;
	margin: 0 auto;
    }
    #headerArea .headerBtn01 {
        display: none;
    }
    #headerArea .headerBtn02 {
        display: none;
    }
}

.footerTop {
    background: #026bb7;
}
.foot_fix {
    display: table;
    max-width: 666px;
    margin: 2px auto;
}
.foot_fix li{
    display: table-cell;
    padding: 0 2px;
}
@media only screen and (max-width: 640px) {
    .footerTop {
        background: #fff;
        border: solid 1px #026bb7;
    }
    .foot_fix.spNone {
        display: none;
    }
    .foot_fix li{
        border-right: solid 1px #026bb7;
    }
    .foot_fix li:last-child{
        border-right: none;
    }
}

/* space */
.vm_no_margin{ margin:0px !important; }
.vm_no_padding{ padding:0px !important; }
.vm_no_background{ background:none !important; }
.vm_margin_l_10{ margin-left:10px !important; }
.vm_margin_l_15{ margin-left:15px !important; }
.vm_margin_l_25{ margin-left:25px !important; }
.vm_margin_t_10{ margin-top:10px !important; }
.vm_margin_t_15{ margin-top:15px !important; }
.vm_margin_t_20{ margin-top:20px !important; }
.vm_margin_t_25{ margin-top:25px !important; }
.vm_margin_t_30{ margin-top:30px !important; }
.vm_margin_b_20{ margin-bottom:20px !important; }
.vm_margin_b_30{ margin-bottom:30px !important; }
.vm_margin_b_50{ margin-bottom:50px !important; }
.vm_padding_t_10{ padding-top:10px !important; }
.vm_padding_t_20{ padding-top:20px !important; }
.vm_padding_r_10{ padding-right:10px !important; }
.vm_padding_l_10{ padding-left:10px !important; }



h3 {
	background:#026bb7;
	width:100%;
    /*height: 45px;*/
    font-size: 1.4em;
    font-weight: bold;
    color: #fff;;
    /*padding-top: 10px;*/
    margin-bottom: 30px;
    padding: 10px;
    box-sizing:border-box;
    
}

/************************************** 【column index】 */
body #column_2 .vm_index{
	width:100%;
	background-color:#fff7dd;
	border:solid 1px #ffe89d;
}
/* 内容によりwidthの微調整が必要 */
body #column_2 .vm_index .in{
	width:93%;/* 変更箇所 */
	padding:20px;
}
body #column_2 .vm_index .in_left{
	width:118px;
	height:118px;
	float:left;
	position:relative;
	margin:3px 0;
	border:solid 1px #dedddd;
}
body #column_2 .vm_index .in_left img{
	clip:rect(1px,117px,117px,1px);
	position:absolute;
	top:0;
	left:0;
}
/* 内容によりwidthの微調整が必要 */
body #column_2 .vm_index .in_right{
	/*width:100%;/* 変更箇所 */
	float:right;
}
body #column_2 .vm_index .in .ttl_02{
	margin:0 0 15px 0;
	padding:10px 0 10px 22px;
	text-indent:-22px;
	line-height:130%;
	font-size:14px;
	color:#fff;
	text-align:left;
}
body #column_2 .vm_index .in .ttl_02 span{
	background:url("../img/arrow_01.png") left top no-repeat;
	padding:0 0 2px 22px;
	margin:0 0 0 20px;
}
/************************************** 【column index】 */








/************************************** 【theme index】 */
body #vm_column_index .ttl_01{
	color:#fff;
	font-size:14px;
	padding:10px;
	margin:0 0 30px 0;
	text-align:left;
	background:#e6b867;
}
body #vm_column_index .txt_01{
	font-size:14px;
	line-height:170%;
	padding:0 15px 0 15px;
	margin:0 0 30px 0;
}
body #vm_column_index .ttl_sub{
	font-size:12px;
	line-height:150%;
	display:block;
	color:#ce9a45;
	margin:0 0 10px 0;
	padding:0 0 5px 0;
	border-bottom:solid 1px #ce9a45;
}
body #column_2{
	margin:0 0 50px 0;
}
body #column_2 .center{
	margin:30px auto 0 auto;
}
body #column_2 .left{
	width:48%;
	float:left;
	border:solid 1px #A7A7A7;
	min-height:14em;
}
body #column_2 .right{
	width:48%;
	float:right;
	border:solid 1px #A7A7A7;
	min-height:14em;
}




/* 内容によりwidthの微調整が必要 */
body #column_2 .in{
	/*width:99%;/* 変更箇所 */
	padding:15px;
}




body #column_2 .in_left{
	width:118px;
	height:118px;
	float:left;
	position:relative;
	margin:3px 0;
	border:solid 1px #dedddd;
}
body #column_2 .in_left img{
	/*clip:rect(1px,187px,117px,1px);
	position:absolute;
	top:0;
	left:0;*/
}




/* 内容によりwidthの微調整が必要 */
body #column_2 .in_right{
	width:301px;/* 変更箇所 */
	float:right;
}





body #column_2 .in .ttl_02_bg{
	background-color:#026bb7;
}
body #column_2 .in .ttl_02{
	margin:0 0 10px 0;
	padding:10px;
	text-indent:-22px;
	line-height:130%;
	font-size:14px;
	color:#fff;
	text-align:center;
}

body #column_2 .in .ttl_02 a:link		{ color:#fff; text-decoration:none; }
body #column_2 .in .ttl_02 a:visited	{ color:#fff; text-decoration:none; }
body #column_2 .in .ttl_02 a:hover		{ color:#fff; text-decoration:underline; }
body #column_2 .in .ttl_02 a:active		{ text-decoration:none; }

body #column_2 .in .ttl_02 span{
	background:url("../img/arrow_01.png") left top no-repeat;
	padding:0 0 2px 22px;
}
body #column_2 .in_right p{
	margin:3px 0 0 0;
	padding:0;
	line-height:150%;
	font-size:12px;
}
body #column_2 .in_right .more a{
	font-weight:bold;
}
body #column_2 .in_right p a:link		{ color:#ed3f17; text-decoration:none; }
body #column_2 .in_right p a:visited		{ color:#ed3f17; text-decoration:none; }
body #column_2 .in_right p a:hover		{ color:#000000; text-decoration:underline; }
body #column_2 .in_right p a:active		{ text-decoration:none; }
/************************************** 【theme index】 */





/************************************** 【theme01 ～ xx】 */
#vm_column_index .p_info h3{
	background:none;
	font-size: 1.4em;
	font-weight: normal;
	line-height: 51px;
	padding: 0 0 0 0px;
	color: #82795a;
	border-bottom:solid #026bb7 3px;
}

.ctr{
	display:block;
	margin:15px auto;
}
.floatR{
	float:right;
	margin-left:20px;
}

body #vm_pagelink{
	padding:30px 30px 38px 30px;
	border:solid 2px #026bb7;
	background:#FFF url("../img/bg.png") left top repeat;
}
body #vm_pagelink ul{
	margin:0;
	padding:0;
	list-style-type:none;
	line-height:150%;
	font-size:12px;
}
body #vm_pagelink ul li{
	margin:0 0 0 0;
	padding:8px 0 8px 22px;
	text-indent:-22px;
	border-bottom:1px #A7A7A7 dotted;
	font-weight: bold;
}
body #vm_pagelink ul li a:link		{ color:#285E9C; text-decoration:none; font-weight: bold;}
body #vm_pagelink ul li a:visited	{ color:#285E9C; text-decoration:none; font-weight: bold;}
body #vm_pagelink ul li a:hover		{ color:#285E9C; text-decoration:underline; font-weight: bold;}
body #vm_pagelink ul li a:active	{ text-decoration:none; }


body #vm_pagelink ul li span{
	background:url("../img/arrow_01.png") left top no-repeat;
	padding:0 0 2px 22px;
}



@media screen and (max-width:780px){


body #vm_column_index{
	width:100%;
	margin:0 auto;
  	padding:0;
}


body #column_2 .in_left{
	width:118px;
	height:118px;
	float:none;
	position:relative;
	margin:3px auto;
	border:solid 1px #dedddd;
	
}
body #column_2 .in_left img{
	/*clip:rect(1px,187px,117px,1px);
	position:absolute;
	top:0;
	left:0;*/
}




/* 内容によりwidthの微調整が必要 */
body #column_2 .in_right{
	width:100%;/* 変更箇所 */
	float:none;
}


/* 内容によりwidthの微調整が必要 */
body #column_2{
	padding: 0 10px;
}

.p_info{
	padding: 0 10px;
}

.p_info img{
	width: 100%;
}


}
