@charset "utf-8";
/* CSS Document */

html {
	position: relative;
	min-height: 100%;
	height: 100%;
}

body {
	font-size: 14px;
	height: 100%;
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	position: relative;
	line-height: 1.5;
	/*letter-spacing: 0.12em;*/
	color: #000;
	-webkit-text-size-adjust: 100%;
}

img {
	width: 100%;
	max-width: 100%;
	vertical-align: bottom !important;
	height: auto;
	display:block;
}


a {
	text-decoration: none;
	color: #ff6fb0;
	/*color: #af0303;*/
}

a:hover{
	text-decoration: none;
	color: #ef468a;
}


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

*, *::before, *::after {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}

h1, h2, h3 ,h4{
	margin: 0;
	padding: 0;
}

ul, li, dl, dt, dd{
	margin: 0;
	padding: 0;
	font-weight:normal;
}

ul{
	list-style: none;
}

/*
ul.disc li{
	list-style-type: disc;
	padding-left: 1em;
    text-indent: -1em;
}
*/

ol{
	margin: 0 -1em;
}

.mt0{margin-top: 0;}
.mt10{margin-top: 10px;}
.mt15{margin-top: 15px;}
.mt20{margin-top: 20px;}
.mt25{margin-top: 25px;}
.mt30{margin-top: 30px;}
.mt35{margin-top: 35px;}
.mt40{margin-top: 40px;}

.mb0{margin-bottom: 0 !important;}
.mb5{margin-bottom: 5px;}
.mb10{margin-bottom: 10px;}
.mb15{margin-bottom: 15px;}
.mb20{margin-bottom: 20px;}
.mb25{margin-bottom: 25px;}
.mb30{margin-bottom: 30px;}
.mb35{margin-bottom: 35px;}
.mb40{margin-bottom: 40px;}
.mb1em{margin-bottom: 1em;}

.mr10{margin-right:10px;}
.mr15{margin-right:15px;}
.mr20{margin-right:20px;}

.ml10{margin-left:10px;}
.ml15{margin-left:15px;}
.ml20{margin-left:20px;}

.wd100{width: 100%;}

.txt_red{color: #d20000;}
.txt_maincolor{color: #ff6fb0;}
.txt_bold{font-weight:bold;}

.font12{font-size: 12px;}
.font14{font-size: 14px;}
.font16{font-size: 16px;}
.font18{font-size: 18px;}
.font24{font-size: 24px;}

.common_box{
	padding: 0 12px;
}

/*table**************************/
table {
  border-collapse: collapse;
  width: 100%;
}
table th,
table td {
  padding: 10px;
  border: 1px solid #ccc;
}
table th {
  background-color: #f8f8f8;
  text-align: center;
  width: 30%;
}

@media screen and (max-width: 768px) {
  table {
    border-top: 1px solid #ccc;
	margin: 0 16px;
	width: calc(100% - 32px);
  }
  table td {
    display: block;
    text-align: left;
  }
  table th {
    display: block;
    border-top: none;
    border-bottom: none;
    width: 100%;
  }
}

h2{
	background-color:#f8f8f8;
	color:#333;
	padding:15px 15px;
	font-size: 16px;
	font-weight: bold;
	margin-bottom: 25px;
	border-left: 4px solid #ff92b6;
}

@media screen and (max-width: 768px) {
	.sp_hidden{display: none!important;}
}

@media screen and (min-width: 768px) {
	.pc_hidden{display: none!important;}
}


@media screen and (min-width: 768px) {
	.contents{
		max-width: 960px;
		margin: 0 auto;
		/*padding: 0 10px;*/
	}
	
	.contents::after{
		content: ".";
		display: block;
		height: 0;
		clear: both;
		visibility: hidden;
	}
}



/*header ****************************/
.header_inner::after{
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}

@media screen and (min-width: 768px) {
header{
	max-width: 960px;
	margin: 10px auto 0;
	padding: 0 10px;
}

img.header_logo{
	max-width: 730px;
}

.header_left{
	float: left;
	padding: 20px 0px 15px 10px;
	width: 80%;
}

.header_left h1 span.main{
	font-size: 28px;
}
	
}

@media screen and (max-width: 768px) {
img.header_logo{
	max-width: 365px;
}

.header_inner{
	padding: 5px 0;
}
	
.header_left{
	float: left;
	padding: 5px 0px 5px 10px;
	width: 80%;
	max-height: 50px;
}

.header_left h1{
	padding: 0px 0 0px 5px;		
	white-space: nowrap;
}
	
.header_left h1 .sub{
	font-size: 11px;
	/*display: none;*/
}

.header_right{
	float: right;
	width: 20%;
	max-width: 80px;
}

.header_right #switchBtnArea {
	width: 100%;
	height: 50px;
	/*background: #3c3c3c;*/
	position: relative;
}

.header_right #switchBtnArea #switchBtn {
	top: 8px;
	right: 10px;
	width: 34px;
	height: 34px;
	display: block;
	background: #a7a7a7;
	position: absolute;
	border-radius: 5px;
}

.header_right #switchBtnArea #switchBtn span {
	left: 20%;
	width: 60%;
	height: 2px;
	display: block;
	position: absolute;
	background-color: #fff;
	border-radius: 5px;
	transition: all 0.2s linear;
}
.header_right #switchBtnArea #switchBtn span:nth-of-type(1) {
	top: 9px;
	-webkit-transform: rotate(0);
	transform: rotate(0);
}
.header_right #switchBtnArea #switchBtn span:nth-of-type(2) {
	top: 16px;
	-webkit-transform: scale(1);
	transform: scale(1);
}
.header_right #switchBtnArea #switchBtn span:nth-of-type(3) {
	bottom: 9px;
	-webkit-transform: rotate(0);
	transform: rotate(0);
}

.header_right #switchBtnArea #switchBtn.btnClose span:nth-of-type(1) {
	top: 16px;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.header_right #switchBtnArea #switchBtn.btnClose span:nth-of-type(2) {
	-webkit-transform: scale(0);
	transform: scale(0);
}
.header_right #switchBtnArea #switchBtn.btnClose span:nth-of-type(3) {
	bottom: 16px;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
}

/*main_menu ****************************/
@media screen and (max-width: 768px) {
	nav#main_menu{
	   width:100%;
	   display: none;
	}

	#sp_nav{
		display: none;
		margin-bottom: 15px;
	}
	
	#sp_nav ul li a{
	   position: relative;
	   width:100%;
	   display:block;
	   background-color:#f8f8f8;
	   border-bottom:1px solid #e3e3e3;	
	   text-align: center;
	   padding: 12px 0;
	   color: #333
	}
	#sp_nav ul li:first-child{
		border-top: 1px solid #e3e3e3;
	}
}

@media screen and (min-width: 768px) {
	#sp_nav{
		display: none;
	}
	
	nav#main_menu{
		width: 100%;
		height: 50px;
		margin: 20px 0 40px;
	}
	
	nav#main_menu ul{
		max-width: 960px;
		height: 50px;
		margin: 0 auto;
		font-size: 0;
	}
	
	nav#main_menu ul li{
		font-size: 20px;
		line-height: 50px;
		height: 50px;
		display: inline-block;
		width: 33.33%;
		vertical-align: top;
		text-align: center;
		border-left: 1px solid #e3e3e3;
	}
	
	nav#main_menu ul li:nth-child(2){
		width: 33.34%;
	}
	
	nav#main_menu ul li a{
		color: #666;
		display: block;
	}
	
	nav#main_menu ul li:first-child a{
	}
	
	nav#main_menu ul li:last-child{
		border-right: 1px solid #e3e3e3;
	}
	
	nav#main_menu ul li a:hover{
		color:#ef468a;
	}
	
	nav#main_menu ul li a:after{
	left:50%;
	-webkit-transform:translateX(-50%);
			transform:translateX(-50%);
	}
	
	nav#main_menu ul li a,
	nav#main_menu ul li a:visited,
	nav#main_menu ul li a:hover,
	nav#main_menu ul li a:active{
	  -webkit-backface-visibility:hidden;
			  backface-visibility:hidden;
		position:relative;
	  transition:0.5s color ease;
		text-decoration:none;
	}
	
	nav#main_menu ul li a:after{
	  content: "";
	  transition:0.5s all ease;
	  -webkit-backface-visibility:hidden;
			  backface-visibility:hidden;
	  position:absolute;
	  bottom:-0.25em;
	  height:5px;
	  height:0.2rem;
	  width:0;
	  background:#ef468a;
	}
	
	nav#main_menu ul li a:hover:after{
	  width:100%;
	}
	
}


/*main ****************************/
main{
	margin-bottom: 50px;
}

@media screen and (min-width: 768px) {
	main{
	margin-right: 3%;
	width: 77%;
	float: left;
	}
}


/*aside****************************/
@media screen and (max-width: 768px) {
	aside{
	}

	aside .link_bnr_box{
		padding: 0 12px;
		margin: 0 auto 40px;
	}

	aside .link_bnr_box a{
		display: block;
		margin-bottom: 20px;
	}
	
	aside .side_talkn_box{
		display: none;
	}
}

@media screen and (min-width: 768px) {
	aside{
		float: left;
		width: 20%;
	}
	
	aside .link_bnr_box a{
		display: block;
		margin-bottom: 20px;
	}
	
	aside .side_talkn_box img{
		display: block;
		margin-bottom: 10px;
	}
	
	aside .side_talkn_box p{
		font-size: 12px;
	}
}

/*footer****************************/
@media screen and (max-width: 768px) {
	#page_top{
		text-align: center;
	}
	
	#page_top a{
		display: inline-block;
		width: 100%;
		background-color: #f8f8f8;
		text-align: center;
		padding: 15px 0;
		border-top: 1px solid #e3e3e3;
		border-bottom: 1px solid #e3e3e3;
		color: #333;
	}
}

@media screen and (min-width: 768px) {
	#page_top {
		position:fixed;
		bottom:0;
		margin-bottom: 40px;
		right:40px;
		font-size:48px;
		z-index: 999;
	}
	
	#page_top a {
		background: none repeat scroll 0 0 #ff6fb0;
		border-radius: 5px;
		color: #fff;
		display: block;
		font-family: FontAwesome;
		text-align: center;
		text-decoration: none;
		padding:  0px 16px;
	}
	
	#page_top a:hover {
		text-decoration:none;
		background:#ff6fb0;
		opacity: 0.7;
	}
}

footer {
	background-color: #ffc4d7;
	padding: 25px 0 25px;
}

footer .footer_menu{
	text-align: center;
	margin-bottom: 15px;
}

footer .copyright p{
	margin:0;
	font-size: 10px;
	text-align: center;
}

@media screen and (min-width: 768px) {
	footer{
	}
}

/*index****************************/
@media screen and (max-width: 768px) {
	.main_img{
		max-width: 960px;
		margin: 0 auto;
		margin-bottom: 15px;
	}
}

@media screen and (min-width: 768px) {
	.main_img{
		max-width: 960px;
		margin: 0 auto;
		margin-bottom: 30px;
	}
}


/*counselor****************************/
.counselor_box01{
	margin-bottom: 40px;
}

@media screen and (max-width: 768px) {
.counselor_box01{
	padding: 0 12px;
}
}

.counselor_box01 h3{
	font-size: 16px;
	font-weight:bold;
	color: #ff6fb0;
	margin-bottom: 15px;
	line-height: 1.2;
	
}

.counselor_box01 p{
	margin-bottom: 20px;
	line-height: 1.5;
}

/*counselor_box********************/
@media screen and (max-width: 768px) {
.counselor_box{
	
}

ul.counselor{
	margin-bottom: 30px;
}
	
ul.counselor li{
	border-bottom: 1px solid #e3e3e3;
}

ul.counselor li:first-child{
	border-top: 1px solid #e3e3e3;
}

ul.counselor li a{
	position: relative;
	display: block;
	padding: 16px 32px 22px 12px;
	color: #333;
}
	
ul.counselor li a::after {
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	right: 16px;
	width: 16px;
	height: 16px;
	margin: -4px 0 0 0;
	border-top: solid 2px #ff6fb0;
	border-right: solid 2px #ff6fb0;
	-webkit-transform: rotate(45deg);
			transform: rotate(45deg);
}

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

ul.counselor dt{
	width: 25%;
	float: left;
}

ul.counselor dd{
	margin-left: calc(25% + 12px);
	margin-left: -webkit-calc(25% + 12px);
	margin-right: 10px;
}

ul.counselor dd.name{
	font-size: 120%;
	font-weight: bold;
	margin-bottom: 2px;
}

ul.counselor dd.specialty{
	margin-bottom: 10px;
	font-size: 85%;
	color: #666;
}

ul.counselor dd.msg{
	margin-bottom: 14px;
	font-size: 90%;
	color: #333;
}


ul.counselor dd.price{
	text-align:right;
}

ul.counselor dd.price .price_inner{
	border: 1px solid #e3e3e3;
	border-radius: 5px;
	padding: 4px 6px;
}
}

@media screen and (min-width: 768px) {
.counselor_box{
	
}

ul.counselor{
	font-size: 0;
	margin-bottom: 30px;
}

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

ul.counselor li{
	display:inline-block;
	width: 33.33%;
	margin: 20px 0;
	vertical-align: top;
	font-size: 14px;
}

ul.counselor li:nth-child(3n-1){
	width: 33.34%;
}

ul.counselor li:nth-child(3n){
}

ul.counselor li a{
	color: #333;
	text-decoration: none;
}

ul.counselor li a:hover dt img{
	filter:alpha(opacity=60);
	-moz-opacity: 0.6;
	opacity: 0.6;
}
	
ul.counselor li a:hover{
	text-decoration: none;
}

ul.counselor dt{
	width: 60%;
	margin: 0 auto 16px;
}

ul.counselor dt img{
}

ul.counselor dd{
	width: 80%;
	margin: 0 auto;
}

ul.counselor dd.name{
	font-size: 120%;
	font-weight: bold;
	margin-bottom: 4px;
	text-align:center;
}

ul.counselor dd.specialty{
	margin-bottom: 12px;
	font-size: 85%;
	color: #666;
	text-align:center;
}

ul.counselor dd.msg{
	margin-bottom: 16px;
	font-size: 90%;
	color: #333;
}


ul.counselor dd.price{
	text-align:right;
}

ul.counselor dd.price .price_inner{
	border: 1px solid #e3e3e3;
	border-radius: 5px;
	padding: 4px 4px;
}
}

.counselor_list_box h3{
	font-size: 16px;
	font-weight:bold;
	color: #ff6fb0;
	margin-bottom: 15px;
	line-height: 1.2;
	width: 100%;
	border-bottom: 1px solid #e3e3e3; 
	padding-bottom: 8px;
}

@media screen and (max-width: 768px) {	
	.counselor_list_box h3{
		border: none;
		padding: 0 12px;
	}
}

/*guide**************************/
.guide_box li{
	margin-bottom: 30px;
}

.guide_box li dt{
	font-size: 16px;
	font-weight:bold;
	color: #ff6fb0;
	margin-bottom: 10px;
}

@media screen and (min-width: 768px) {
	.guide_box{
	}
}

@media screen and (max-width: 768px) {
	.guide_box{
		padding: 0 12px;
		margin-bottom: 30px;
		}


	.guide_box dt{
		font-size: 14px;
	}
}


/*payment**************************/
.payment_common_box h3{
	font-size: 16px;
	font-weight:bold;
	color: #ff6fb0;
	margin-bottom: 15px;
	line-height: 1.2;
}

.payment_common_box p{
	margin-bottom: 20px;
	line-height: 1.5;
}

.payment_common_box ul li{
	margin-bottom: 5px;
	/*
	text-indent: 1em;
	padding-left: 1em;
	*/
}

.payment_common_box table{
	margin: 0;
	width: 100%;
	margin-bottom: 20px;
}

.payment_common_box dt{
	font-size: 15px;
	font-weight: bold;
	margin-bottom: 15px;
}

.payment_common_box dd{
	font-weight: bold;
	margin-bottom: 20px;
}

.payment_common_box h4{
	font-size: 15px;
	font-weight:bold;
	color: #333;
	margin-bottom: 10px;
	line-height: 1.2;
}

@media screen and (min-width: 768px) {
	.payment_common_box{
	margin-bottom: 30px;
	}
}

@media screen and (max-width: 768px) {
	.payment_common_box{
		padding: 0 12px;
		margin-bottom: 30px;
		}


	.payment_common_box dt{
		font-size: 14px;
	}

	.payment_common_box h4{
		font-size: 14px;
	}
}
/*tokushoho**************************/






/*parts**************************/
/*
p.counselor_btn{
	text-align: center;
}

p.counselor_btn a{
	display: inline-block;
	padding: 1.2em 40px;
	border: 1px solid #ff6fb0;
	color: #ff6fb0;
	font-weight: bold;
}
*/
.b{
	font-weight:bold;
}