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

* {
	margin: 0px;
	padding: 0px;
	outline: none;
}

img {
	vertical-align: bottom;
	border: none;
}

ul {
	list-style: none;
}

p {
	margin-bottom: 20px;
}

.margin10 {
	margin-top: 10px;
}

hr {
	margin: 5px 0px 5px 0px;
	color: #a5a5a5;
	border: none;
	border-top: solid 1px #cccccc;
}

.center_text {
	text-align: center;
}

.center_text input {
	padding: 3px 20px;
}

body {
	font-size: 13px;
	text-align: center;
	background-color: #FFF;
	line-height: 20px;
	color: #373737;
	font-family: "ヒラギノ丸ゴ Pro W4", "ヒラギノ丸ゴ Pro", "Hiragino Maru Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "HG丸ｺﾞｼｯｸM-PRO", "HGMaruGothicMPRO";
	-webkit-text-size-adjust: 100%;
}

/*----------------------------------------clearfix------------------------------------*/
.clearfix:after {
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
	overflow: hidden;
	font-size: 0.1em;
	line-height: 0;
}

.clearfix {
	display: inline-block;
}

/* Hides from IE-mac \*/
* html .clearfix {
	height: 1%;
}

.clearfix {
	display: block;
}

/*----------------------------------------clearfix------------------------------------*/
#header {
	width: 100%;
	border-bottom: solid 7px #60C7C2;
	margin-bottom: 20px;
}

#header_navi {
	width: 1004px;
	margin-right: auto;
	margin-left: auto;
}

.primary_navi {
	float: left;
	width: 801px;
}

.primary_navi li {
	float: left;
	width: 159px;
	text-align: center;
	font-size: 15px;
}

.primary_navi li:last-child {
	background-image: linear-gradient(to bottom, #dddddd, #dddddd 2px, transparent 2px, transparent 8px);
	background-size: 2px 8px;
	background-position: right top;
	background-repeat: repeat-y;
}

.primary_navi li a {
	display: table-cell;
	height: 71px;
	width: 159px;
	color: #333333;
	font-weight: normal;
	vertical-align: middle;
	text-decoration: none;
	line-height: 110%;
	margin: 0px;
	padding: 0px;
}

.primary_navi li a:hover {
	background-color: #eeeeee;
}

#header_navi #logo {
	float: right;
	width: 203px;
	text-align: right;
}

#wrapper {
	width: 1000px;
	margin: 0px auto;
	text-align: left;
}

#contents {
	width: 1000px;
	padding-bottom: 30px;
}

#lower_index h2.primary_title {
	border-radius: 10px 0 0 10px;
}

h2.primary_title_top {
	width: 100%;
	background-image: url(../img/primary_title_bg_top.jpg);
	background-repeat: no-repeat;
	height: 43px;
	font-size: 25px;
	color: #000000;
	margin-bottom: 20px;
	text-indent: 45px;
	font-weight: bold;
	line-height: 47px;
}

h2.primary_title {
	width: 100%;
	font-size: 20px;
	color: #FFFFFF;
	margin-bottom: 20px;
	text-indent: 17px;
	padding-top: 12px;
	padding-bottom: 10px;
	background-color: #60C7C2;
	font-weight: normal;
	letter-spacing: 5px;
}

#menu_content h2.primary_title {
	border-radius: 0 10px 10px 0;
}

#main_content h2.primary_title {
	border-radius: 10px 0 0 10px;
}

#left_content h2.primary_title {
	border-radius: 0 10px 10px 0;
}

dl.p_list {}

dl.p_list dt {
	font-weight: bold;
}

dl.p_list dd {
	text-indent: 20px;
	margin: 0px 0px 0px 10px;
	line-height: 30px;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
	border-bottom-color: #C03;
}


ul.side_navi {}

ul.side_navi li {
	margin: 0;
	padding: 0;
	font-size: 15px;
	background-image: linear-gradient(to right, #dddddd, #dddddd 2px, transparent 2px, transparent 8px);
	background-size: 8px 2px;
	background-position: left bottom;
	background-repeat: repeat-x;
}

ul.side_navi li a {
	text-align: left;
	position: relative;
	padding: 8px 0 8px 8px;
	display: inline-block;
	width: calc(100% - 0.5em);
	text-decoration: none;
}

ul.side_navi li a:hover {
	text-decoration: none;
	background: #f0f0f0;
}

ul.side_navi li a:link {
	color: #434343;
	text-decoration: none;
}

ul.side_navi li a::after {
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0.4em;
	margin: auto;
	content: "";
	vertical-align: middle;
	width: 0.4em;
	height: 0.4em;
	border-top: 1.5px solid #dddddd;
	border-right: 1.5px solid #dddddd;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

ul.side_navi_mail {
	margin-bottom: 40px;
}

ul.side_navi_mail li {
	margin: 0px;
	padding: 0px;
	font-size: 15px;
}

ul.side_navi_mail li.list_none {
	width: 200px;
	margin: 0px 0px 0px 0px;
	padding: 0px;
	border-bottom: none;
	background: none;
}

ul.side_navi_mail li a.mail_bottom {
	background-image: url(../img/mail_bg.jpg);
	background-repeat: no-repeat;
	background-position: bottom;
	padding-bottom: 3px;
	width: 180px;
	display: block;
	margin: 0px;
}

ul.side_navi_loginname {
	margin-bottom: 30px;
}

ul.side_navi_loginname li {
	display: inline;
	margin-right: 15px;
	padding: 0 3px 7px 3px;
	font-size: 15px;
	margin-left: 15px;
	background-image: linear-gradient(to right, #dddddd, #dddddd 2px, transparent 2px, transparent 8px);
	background-size: 8px 2px;
	background-position: left bottom;
	background-repeat: repeat-x;
}

ul.n_list {}

ul.n_list li {
	margin: 0;
	padding: 0;
	font-size: 15px;
	background-image: linear-gradient(to right, #dddddd, #dddddd 2px, transparent 2px, transparent 8px);
	background-size: 8px 2px;
	background-position: left bottom;
	background-repeat: repeat-x;
}

ul.n_list li a {
	text-align: left;
	position: relative;
	padding: 8px 0 8px 8px;
	display: inline-block;
	width: calc(100% - 0.5em);
	text-decoration: none;
}

ul.n_list li a:hover {
	text-decoration: none;
	background: #f0f0f0;
}

ul.n_list li a:link {
	text-decoration: none;
}

ul.n_list li a::after {
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0.4em;
	margin: auto;
	content: "";
	vertical-align: middle;
	width: 0.4em;
	height: 0.4em;
	border-top: 1.5px solid #dddddd;
	border-right: 1.5px solid #dddddd;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

input[type="submit"]:not([class]) {
	margin: 10 auto;
	display: block;
	padding: 8px 23px;
	background: #328F8B;
	color: #ffffff;
	border: none;
	border-radius: 5px;
	font-size: 15px;
}

input[type="submit"]:not([class]):active{
	background: #73CEC9;
}

/**/

.flex-viewport{
	border-radius: 10px;
}

#left_content {
	width: 250px;
	float: left;
}

#main_content {
	width: 722px;
	float: right;
}

#main_content_inner {
	width: 692px;
	margin: 0px auto;
}

#main_content_index {
	width: 338px;
	float: right;
	margin-top: 12px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
}

#add_area {}

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

#mail_man {
	width: 329px;
	text-align: center;
	margin-bottom: 15px;
	background: #e0f0ff;
	border-radius: 10px;
	padding-top: 10px;
}

#mail_man a {
	display: block;
}

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

#mail_man img {
	padding-top: 10px;
	padding-bottom: 0px;
}

#mail_woman {
	width: 329px;
#	border: 4px solid #da4c6f;
	text-align: center;
	margin-bottom: 25px;
	background: #ffe0f0;
	border-radius: 10px;
	padding-top: 10px;
}

#mail_woman a {
	display: block;
}

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

#mail_woman img {
	padding-top: 10px;
	padding-bottom: 0px;
}

table.add_form {
	width: 100%;
	margin: 0px 0px 10px 0px;
	border-collapse: collapse;
	font-size: 13px;
	line-height: 20px;
	border-radius: 10px;
}

table.add_form th {
	padding: 10px;
	text-align: right;
	vertical-align: top;
	width: 28%;
	background-color: #CEEEEC;
	font-weight: normal;
	color: #3CAAA4;
	font-weight: bold;
}

table.add_form td {
	padding: 10px;
	text-align: left;
	width: 72%;
	background-color: #E5F6F5;
}

.contact_area {
	width: 100%;
}

.middle_area {
	width: 50%;
}

table.payment_form {
	width: 100%;
	margin: 0px 0px 10px 0px;
	border: none;
	border-collapse: collapse;
	font-size: 13px;
	line-height: 20px;
}

table.payment_form th {
	padding: 10px;
	text-align: right;
	width: 43%;
	background-color: #ffd0d0;
	border-bottom: solid 1px #ffffff;
	font-weight: normal;
	color: #e03030;
	font-weight: bold;
}

table.payment_form td {
	padding: 10px;
	text-align: left;
	width: 57%;
	border-bottom: 1px solid #ffffff;
	background-color: #ffe8e8;
}

a.back {
	width: 145px;
	height: 33px;
	display: block;
	float: right;
}

#footer {
	width: 100%;
	text-align: center;
	color: #ffffff;
	background: #60C7C2;
	float: left;
}

#footer p {
	padding: 10px 0px 10px 0px;
}

/* ライン風表示 */
/* 送信 */
.talk_bg {
	background-image: url(../img/talk_s_head.gif);
	background-repeat: no-repeat;
	background-position: left top;
	padding-top: 25px;
	width: 430px;
	margin-left: 100px;
}

.talk_bottom {
	background-image: url(../img/talk_s_bottom.gif);
	background-repeat: no-repeat;
	background-position: left bottom;
	width: 405px;
	padding-bottom: 15px;
	color: #000000;
	margin: 0px;
}

.talk_middle {
	background-image: url(../img/talk_s_rp.gif);
	background-repeat: repeat-y;
	background-position: left top;
	margin: 0px;
	padding-bottom: 15px;
}

.talk_middle p {
	padding-right: 15px;
	padding-left: 15px;
}

.talk_middle h3.sub {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #000000;
	margin-right: 15px;
	margin-left: 15px;
	margin-bottom: 10px;
	font-weight: normal;
}

.talk_middle div {
	padding-right: 15px;
	padding-left: 15px;
}

.date {
	margin-bottom: 5px;
	font-size: 90%;
}

/* 受信 */
.talk_bg2 {
	background-image: url(../img/talk_j_head.gif);
	background-repeat: no-repeat;
	background-position: left top;
	padding-top: 25px;
	width: 430px;
}

.talk_bottom2 {
	background-image: url(../img/talk_j_bottom.gif);
	background-repeat: no-repeat;
	background-position: 22px bottom;
	width: 430px;
	padding-bottom: 15px;
	color: #000000;
	margin: 0px;
}

.talk_middle2 {
	background-image: url(../img/talk_j_rp.gif);
	background-repeat: repeat-y;
	background-position: 23px top;
	margin: 0px;
	padding-bottom: 15px;
}

.talk_middle2 p {
	padding-right: 15px;
	padding-left: 35px;
}

.talk_middle2 h3.sub {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #000000;
	margin-right: 15px;
	margin-left: 35px;
	margin-bottom: 10px;
	font-weight: normal;
}

.talk_middle2 div {
	padding-right: 15px;
	padding-left: 35px;
}

.date2 {
	margin-bottom: 5px;
	font-size: 90%;
}

#login>img {
	border-radius: 10px 10px 0 0;
}

#logininfo {
	width: 1000px;
	margin-top: 0px;
	margin-right: auto;
	margin-bottom: 30px;
	margin-left: auto;
}

#logininfo #login {
	width: 490px;
	float: left;
}

#logininfo #login #login_inner {
	padding-top: 13px;
	padding-right: 17px;
	padding-bottom: 13px;
	padding-left: 17px;
	background: #f0f0f0;
	border-radius: 0 10px 10px 10px;
}

#logininfo #login_area {
	width: 225px;
	float: left;
}

#logininfo #login_area input {
	margin-top: 3px;
	margin-bottom: 5px;
}

#logininfo #login_area p {
	color: #F00;
	font-size: 10px;
	margin-bottom: 0px;
}

#logininfo #login_button {
	width: 212px;
	float: right;
	margin-top: 25px;
	text-align: center;
}

#logininfo #login_button input {
	margin-bottom: 15px
}

#logininfo #auth_inner, #logininfo #sms_inner {
	border: none !important;
}

#mobile_area>img {
	border-radius: 10px 10px 0 0;
}

#logininfo #mobile_area {
	width: 490px;
	float: right;
}

#logininfo #mobile_inner {
	padding-top: 11px;
	padding-right: 18px;
	padding-bottom: 11px;
	padding-left: 18px;
	background: #f0f0f0;
	border-radius: 0 10px 10px 10px;
}

#logininfo #mobile_inner #qr {
	width: 150px;
	float: left;
	margin-bottom: 0px;
}

#logininfo #mobile_inner #qr img {
	padding: 15px;
	background: #ffffff;
}

#logininfo #mobile_inner #qrtext {
	width: 300px;
	float: right;
	margin-bottom: 0px;
	font-size: 15px;
	line-height: 160%;
	margin-top: 10px;
}

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

ul.error li {
	color: #F00;
}

/* 写真の高画質化対応 */
img.user_photo {
	max-width: 240px;
	max-height: 320px;
}
