﻿.pub_title {
	margin: 15px 0;
	padding: 0 30px;
	color: #FFF;
	font-size: 250%;
	line-height: 75px;
	background: #F60;
	background: -moz-linear-gradient(left, #F60 50%, #FFF 100%);
	background: -webkit-linear-gradient(left, #F60 50%, #FFF 100%);
	background: linear-gradient(to right, #F60 50%, #FFF 100%);
}
.pub_form {
	padding: 10px 30px;
	font-size: 125%;
	line-height: 1.75;
}
.pub_form > * {
	width: 97.5%;
	margin: 30px 0 0;
	position: relative;
}
.pub_form > *:first-child {
	margin: 0 0 -9px;
}
.pub_form table {
	font-size: 100%;
	border-collapse: collapse;
	border-spacing: 0;
	table-layout: auto;
}
.pub_form th,
.pub_form td {
	padding: 15px 15px 13px;
	vertical-align: middle;
	border: 1px #C3C3C3 solid;
}
.pub_form th > b, .pub_form th > i,
.pub_form td > b, .pub_form td > i {
	font-style: normal;
	font-weight: normal;
	display: block;
}
.pub_form .caption {
	margin: 0 -5px 15px;
	padding: 0 5px;
	text-align: left;
	border-bottom: 1px #999 dotted;
}
.pub_form .caption > * {
	color: #3F3F3F;
	font-size: 135%;
	font-style: normal;
}
.pub_form .caption > b {
	margin: 0 3px;
}
.pub_form .caption > i {
	color: #F30;
}

#pubIntro dt {
	margin: 0 -9px 9px;
	line-height: 1.5;
	border-left: 9px #F30 solid;
}
#pubIntro dt > * {
	padding: 0 9px;
	letter-spacing: 1px;
	display: block;
}
#pubIntro dt strong {
	color: #3F3F3F;
	font-size: 180%;
	border-bottom: 1px #666 dotted;
}
#pubIntro dt em {
	padding-top: 5px;
	font-size: 90%;
	font-style: normal;
}
#pubIntro dd {
	margin: 0 0 1px;
	padding: 3px 3px 0;
	font-size: 92.5%;
}
#pubIntro dd > a {
	text-decoration: underline;
}
#pubIntro dd .price {
	margin: 9px -1px 3px;
	padding: 1px 15px 0;
	color: #FFF;
	font-size: 102.5%;
	font-weight: bold;
	line-height: 36px;
	text-decoration: none;
	vertical-align: top;
	background-color: #094;
	border-bottom: 3px #073 solid;
	border-radius: 6px;
	display: inline-block;
}
#pubIntro dd .price b {
	width: 15px;
	height: 15px;
	margin: 0 5px 0 -1px;
	font-size: 0;
	vertical-align: middle;
	background-color: #FFF;
	border-radius: 50%;
	display: inline-block;
	position: relative;
}
#pubIntro dd .price b:before {
	content: '';
	width: 7px;
	height: 7px;
	background-color: transparent;
	border-top: 2px #094 solid;
	border-left: 2px #094 solid;
	box-sizing: border-box;
	transform: rotate(135deg);
	display: block;
	position: absolute;
	top: 4px;
	left: 3px;
}
#pubProcess dd.step {
	max-width: 100%;
	margin-top: -3px;
	overflow: hidden;
}
#pubProcess dd.step p {
	width: 45%;
	height: 75px;
	margin: 0 -1px -1px 0;
	padding: 10px 2.5%;
	font-size: 92.5%;
	line-height: 18px;
	border-right: 1px #CCC solid;
	border-bottom: 1px #CCC solid;
	float: left;
}
#pubProcess dd.step b {
	margin-left: 6px;
	color: #F33;
	font-size: 120%;
	font-weight: normal;
	line-height: 33px;
	display: inline-block;
}
#pubProcess dd.step i {
	margin-left: -3px;
	color: #E33;
	font-size: 135%;
	font-weight: bold;
	line-height: 33px;
	display: inline-block;
}
#pubProcess dd.notice {
	margin-top: 10px;
	background: #FFF;
	clear: both;
}
#pubProcess dd.notice p {
	padding: 9px 9px 9px 55px;
	color: #FFF;
	font-size: 95%;
	background: url('../img/pubNotice.png') #E00 no-repeat 15px 50%;
	background-size: 30px 30px;
	border-radius: 9px;
}
#pubProcess dd.notice b {
	color: #FF0;
	font-style: normal;
	font-weight: normal;
}

#pubPlan th {
	color: #666;
	font-size: 120%;
	line-height: 1.5;
	text-align: center;
	background: #F9F3E9;
}
#pubPlan th.tips {
	font-weight: normal;
	background: none;
	border: none;
}
#pubPlan th.empty {
	visibility: collapse;
}
#pubPlan th:first-child {
	width: 330px;
}
#pubPlan td {
	color: #333;
	font-size: 240%;
	line-height: 1.5;
	text-align: center;
	background: #FEFCFA;
}
#pubPlan td i {
	margin: -6px 0 6px;
	color: #666;
	font-size: 30%;
}

#pubMailer th {
	width: 210px;
	font-size: 92.5%;
	font-weight: normal;
	text-align: left;
	background: #E6E6E6;
}
#pubMailer td {
	width: auto;
	color: #333;
	font-size: 97.5%;
	text-align: left;
	background: #FEFEFE;
}
#pubMailer td.full {
	padding: 6px 3px;
	line-height: 1.5;
	text-align: center;
	background: none;
	border: none;
}
#pubMailer td.full input {
	margin: 12px 6px 6px;
	padding: 6px 12px;
	font-size: 97.5%;
	letter-spacing: 1px;
	display: inline-block;
}
#pubMailer input[type='text'],
#pubMailer select,
#pubMailer textarea {
	max-width: 630px;
	margin-top: -1px;
	padding: 3px;
	font-size: 90%;
	border: 1px #CCC solid;
}
#pubMailer input[type='text'] {
	width: 300px;
	height: 21px;
}
#pubMailer input[type='text'].long {
	width: 75%;
	max-width: 480px;
}
#pubMailer select {
	min-width: 180px;
	max-height: 30px;
}
#pubMailer textarea {
	width: 90%;
	height: 90px;
}
#pubMailer input[type='radio'] {
	margin: 0 3px;
	vertical-align: -1px;
}
#pubMailer input[id*='pubStatement'] {
	width: 47.5%;
	margin: 6px 6px 0 0;
}
#pubMailer label {
	margin: -3px 9px 6px -3px;
	line-height: 1.5;
	vertical-align: top;
	display: inline-block;
}
#pubMailer span {
	line-height: 1.5;
	display: none;
}
#pubMailer small {
	color: #F66;
	font-weight: bold;
}
#pubMailer .note {
	margin: -3px 3px 6px;
	color: #333;
	font-size: 95%;
	text-align: left;
}
#pubMailer .error,
#pubMailer .explain {
	font-size: 90%;
	line-height: 1.0;
}
#pubMailer .error {
	margin: 6px 0 0;
	color: #F33;
}
#pubMailer .full .error {
	margin-top: 9px;
	font-size: 135%;
	font-weight: bold;
	line-height: 1.5;
}
#pubMailer .explain {
	margin: 0 0 3px;
	color: #666;
}
#pubMailer .hide {
	display: none !important;
	visibility: hidden !important;
}
#pubMailer .add {
	margin-top: 6px;
	padding-left: 21px;
	font-size: 90%;
	line-height: 2.0;
	background: url('../../top/img/common/icon/icon_toggle-open.png') transparent no-repeat 0 50%;
	background-size: 18px 18px;
	display: block;
	float: right;
}

#pubAnchor {
	width: 100%;
	margin: 0;
	padding: 15px 0;
	text-align: center;
	background: rgba(255,255,255,0.75);
	display: none;
	position: fixed;
	z-index: 50;
	top: 0;
	left: 0;
}
#pubAnchor a {
	width: 980px;
	padding: 3px 0 1px;
	color: #FFF;
	font-size: 150%;
	line-height: 50px;
	letter-spacing: 1px;
	text-decoration: none;
	background: rgba(50,150,50,0.75);
	border-radius: 9px;
	display: inline-block;
}
#pubAnchor a:hover {
	background: rgba(50,150,50,1.0);
}