@charset "utf-8";

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-style:normal;
	font-weight: normal;
	font-size: 14px;
	vertical-align: baseline;
	line-height:1.5;
}
body{
	width: 100%;
	font-family: 'Avenir','Helvetica Neue','Helvetica','Arial','Hiragino Sans','ヒラギノ角ゴシック',YuGothic,'Yu Gothic','メイリオ', Meiryo,'ＭＳ Ｐゴシック','MS PGothic' ;
}

h2, h3{
padding: 10px;
}
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

html{
    overflow-y: scroll;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

input, textarea{
	margin: 0;
	padding: 0;
}

ol, ul{
    list-style:none;
}

table{
    border-collapse: collapse; 
    border-spacing:0;
}

caption, th{
    text-align: left;
}

a:focus {
	outline:none;
}

.clearfix:after {
	content: "."; 
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

.clearfix {
	min-height: 1px;
}

* html .clearfix {
	height: 1px;
	/*\*//*/
	height: auto;
	overflow: hidden;
	/**/
}
p{
 -webkit-text-size-adjust: 200%;
 }

.both{
	clear:both;
}

.inline_block {  
	display: inline-block;  
	display: inline; 
}
body{
background: -webkit-gradient(linear, left top, left bottom, color-stop(0.95, #f5ebeb), color-stop(0.00, #ffe1df));
background: -webkit-linear-gradient(top, #ffe1df 0%, #f5ebeb 95%);
background: -moz-linear-gradient(top, #ffe1df 0%, #f5ebeb 95%);
background: -o-linear-gradient(top, #ffe1df 0%, #f5ebeb 95%);
background: -ms-linear-gradient(top, #ffe1df 0%, #f5ebeb 95%);
background: linear-gradient( #ffe1df 0%, #f5ebeb 95%);
font-size:16px;

}
/*ヘッダー関係*/

der h1 a{
color: #eb5959;
font-weight:800;
}
#header a{
color:#d97373;
font-weight:500;
}

.alpha a:hover img {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
}

.alpha img:hover{opacity: 0.6;
	transition: 0.6s ;
}

.fixed_btn
{
  position: fixed;
  bottom: 50px; 
  right: 10px;
  padding: 10px 30px;
  background: #A23C52;
  color: #FFFFFF;
  border: none;
  opacity: 0.9;
}

.fixed_btn a {
  text-decoration: none;
  color: #FFFFFF;
  font-size: 16px;
}

.fixed_btn a:hover {
  text-decoration: underline;
}

@media only screen and (min-width: 769px) {
    /*PC、タブレット　デバイスの横幅が769px以上の場合*/	
	.sp_only{
		display: none;
	}
			
	#header{
		height:200px;
		width: 100%;
	}
	
	#header_inner{
		height:145px;
		width:960px;
		margin:0 auto;
	}
	
	#info{
		float:right;
		margin:30px 50px 0 0;
		width:253px;
	}
	
	#logo{
		height:52px;
		width:350px;
		margin-top:40px;
		float:left;
	}
	
	#header #globalnavi{
		height:55px;
		background-color:#d97373;
		/*background-repeat:repeat-x; 不要？？ */
	}
	
	/*PCのスタイル*/
	globalnavi navi_back {
		margin-right: -16px;
	}
	globalnavi navi_back ul{
		display: flex;
		align-items: center;	
	}
	globalnavi navi_back ul li a{
		color: #fff;
		text-decoration: none;
		font-weight: bold;
		padding: 16px ;
	}
	
	/* ハンバーガーメニュー非表示　*/
	div.navToggle{
		display: none;
	}
	
	nav.globalMenuSp{
		display: none;
	}
			
	#navi_back{
	margin:0 auto;
	width:960px;
	}
	
	#navi_back li{
	margin:0 auto;
	float:left;
	height:55px;
	width:160px;
	}
}

@media only screen and (max-width: 768px) {
    /* スマホ　デバイスの横幅が768以下の場合 追加*/
	body{
		font-size: 10px;
		text-size-adjust: 100%;
	}
	.pc_only{
		display: none;
	}
	#header{
		width: 100%;
	
		overflow: hidden;
	}
	#header_inner{
		overflow: hidden;
		width:100%;
		margin-left:10px;
	}
	#info{
	width:60%;
	margin-top:20px;
	}
	#info img,#logo img{
		width:60%;
	}
	
	#logo{
	width:60%;
	margin-top:10px;
	}

	#globalnavi {
  		display:none;  /* PCメニュー非表示 */
 	}
	
	/* ハンバーガーメニュー　*/	
	nav.globalMenuSp {
		position: fixed;
		z-index: 2;
		top: 0;
		left: 0;
		background: #fff;
		color: #000;
		text-align: center;
		transform: translateY(-100%);
		transition: all 0.6s;
		width: 100%;
	}
	 
	nav.globalMenuSp ul {
		background: #f5ebeb;
		margin: 0 auto;
		padding: 0;
		width: 100%;
	}
	 
	nav.globalMenuSp ul li {
		font-size: 1.1em;
		list-style-type: none;
		padding: 0;
		width: 100%;
		border-bottom: 1px solid #eb5959;
	}
	 
	/* 最後はラインを描かない */
	nav.globalMenuSp ul li:last-child {
		padding-bottom: 0;
		border-bottom: none;
	}
	 
	nav.globalMenuSp ul li a {
		display: block;	
		color: #000;
		padding: 1em 0;
	}
	 
	/* このクラスを、jQueryで付与・削除する */
	nav.globalMenuSp.active {
		transform: translateY(0%);
	}
	
	div.navToggle {
		display: block;
		position: fixed;    /* bodyに対しての絶対位置指定 */
		right: 15px;
		top: 20px;
		width: 50px;
		height: 51px;
		cursor: pointer;
		z-index: 3;
		background-color: rgba(255,255,255,0.66);
		text-align: center;
	}
	 
	div.navToggle span {
		display: block;
		position: absolute;    /* .navToggleに対して */
		width: 33px;
		border-bottom: solid 3px #eb5959;
		-webkit-transition: .35s ease-in-out;
		-moz-transition: .35s ease-in-out;
		transition: .35s ease-in-out;
		left: 9px;
	}
	 
	div.navToggle span:nth-child(1) {
		top: 9px;
	}
	 
	div.navToggle span:nth-child(2) {
		top: 18px;
	}
	 
	div.navToggle span:nth-child(3) {
		top: 27px;
	}
	 
	div.navToggle span:nth-child(4) {
		border: none;
		color: #eb5959;
		font-size: 9px;
		font-weight: bold;
		top: 34px;
	}
	
	/* 最初のspanをマイナス45度に */
	div.navToggle.active span:nth-child(1) {
		top: 18px;
		left: 8px;
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}
	 
	/* 2番目と3番目のspanを45度に */
	div.navToggle.active span:nth-child(2),
	div.navToggle.active span:nth-child(3) {
		top: 18px;
		-webkit-transform: rotate(45deg);
		-moz-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	
	/* ハンバーガーメニュー終わり　*/	
	
}

h1{
color:#eb5959;
font-size:1em;
}


/*#info #sub_manu{
margin-top:10px;
}*/
#info #sub_manu #toiawase{
width:160px;
float:left;
margin:0 auto;
color:#000000;
}
#info #sub_manu #toiawase img{
margin-right:3px;
}

#info #sub_manu #access{
width:93px;
float:left;
margin:0 auto;
color:#000000;
}
#info #sub_manu #access img{
margin-right:3px;
vertical-align:text-bottom;
}

/*コンテンツ関係*/
@media only screen and (min-width: 769px) {
    /*PC、タブレット　デバイスの横幅が769px以上の場合*/	
	#TopicPath{
		width: 960px;
		margin:0 auto;
		overflow:hidden;
	}
}
@media only screen and (max-width: 768px) {
    /* スマホ　デバイスの横幅が768以下の場合*/
	#TopicPath{
		width: 100%;
		margin:0 auto;
		overflow:hidden;
	}
}
#TopicPath ul li {
    font-size: 85%;
    float: left;
}
	#TopicPath ul{
	overflow:hidden;
	padding:15px 10px;
    }

#TopicPath ul a{
    font-size:85%;
    float: left;
	background: url("/common/img/ico_topicpath.png") no-repeat scroll right 50% rgba(0, 0, 0, 0);
    margin: 0 10px 0 0;
    padding: 0 20px 0 0;
	color: #A23C52;
}
#subLead{
color: #29969b;
margin-bottom: 15px;
}
#subLead h1, #subLead h2, #subLead h3{
color: #29969b;
padding:10px;
}
#subLead h2{color: #29969b;
    font-size: 120%;
    margin-bottom: 8px;
}
#subLead p{
  line-height: 160%;
}

@media only screen and (min-width: 769px) {
    /*PC、タブレット　デバイスの横幅が769px以上の場合*/	
	
	/* ↓レイアウト全体領域 */
	#container{
		width:960px;
		margin:0 auto;
		padding-bottom: 2em;
		background-color:#FFFFFF;
		overflow:hidden;
	}
	.page_top a{
		float:right;
		color:#A23C52;
		margin:3em 3em 0 0;
	}
	#main_area{
		width:700px;
		float:left;
	}
	.main_banner_sp{
		display:none;
	}
}

@media only screen and (max-width: 768px) {
    /* スマホ　デバイスの横幅が768以下の場合*/
	#header{
		background-color: #ffe1df;
	}
	/*メインビジュアル*/
	.bx-wrapper{
		/* display: none;*/
	}

   	/* ↓レイアウト全体領域 */
   	#container {
	    width: 100%;
	   	max-width: 100%;
		padding-bottom: 2em;
		background-color:#FFFFFF;
	   	overflow: hidden;
	   	display: block;
   	}
   	/* ▼メインカラムの装飾 */
   	#main_area {
	   	width: 100%;
	   	float:none;
	   	overflow: hidden;
   	}
	#main_area img{
   		img: 100%
	}
	.main_banner{
		display: none;
	}
	.main_banner_sp{
		margin-top: 10px;
	}
}	
	


/*フッター*/
#footer{
background-color:#cd9294;
clear:both;
width: 100%;
overflow: hidden;
max-width: 100%;
}
#footer a{
color: #fff;
text-decoration: none;
font-size:15px;
}   

/*サイドエリア*/
@media only screen and (min-width: 769px) {
    /*PC、タブレット　デバイスの横幅が769px以上の場合*/	
	#side_area{
	width:230px;
	float:right;
	}
	.banner{
	margin:10px 0;
	}
}

@media only screen and (max-width: 768px) {
    /* スマホ　デバイスの横幅が768以下の場合*/
    #side_area {
      width: 100%;
		overflow: hidden;
    }
	#side_area .banner img{
		width: 100%;
	}
	.banner{
	margin:10px 0;
	overflow: hidden;
	}
	.banner a{
		display: block;
	}
}


/* リンク */
@media only screen and (min-width: 769px) {
    /*PC、タブレット　デバイスの横幅が769px以上の場合*/	
	#footer {
	margin:0 auto;
	width:960px;
	height:160px;
	}
	
	/* リンク */
	#footer #footer_inner{
	margin:0 auto;
	width:960px;
	height:160px;
	}
	#footer #footer_inner li{
	color:#fff;
	display:block;
	width:160px;
	float:left;
	text-align:center;
	margin:20px 0;
	font-size:14px;
	-webkit-text-size-adjust: 130%;
	}
	#footer #footer_inner .footer_text1{
	float:left;
	width:960px;
	margin-top:15px;
	}
	#footer #footer_inner .footer_text2{
	float:left;
	width:960px;
	}
	#footer_end{
	background-color:#dda1a7;
	}
	#footer_end p{
	color:#FFF;
	width:900px;
	margin:0 auto;
	font-size:14px;
	}
}

@media only screen and (max-width: 768px) {
    /* スマホ　デバイスの横幅が768以下の場合、フッターメニューは非表示*/
	#footer_inner {
		display: none;
	}
	#footer_end{
	width: 100%;
	background-color:#dda1a7;
		overflow: hidden;
	}
	#footer_end p{
	color:#FFF;
	font-size:7px;
	}
	

}ƒ