@charset "UTF-8";
@import "common.tb.css";

/* ---------------------------------------------------------
	CSS Document main
--------------------------------------------------------- */

#main {
	margin-bottom: 50px;
	position: relative;
}

#main h2 {
	padding: 25px 40px;
	background: #fff;
	text-align: right;
	font-weight: 500;
	font-size: 24px;
	color: #0054A7;
	transform: translateY(-50%);
	position: absolute;
	top: 50%;
	right: 50px;
}

#main h2 .en {
	display: block;
	margin-bottom: 5px;
	font-weight: 400;
	font-size: 11px;
	letter-spacing: 0.08em;
	color: #0054A7;
}

#main h2 .en:after {
	display: block;
	content: '';
	width: 30px;
	height: 2px;
	margin: 10px 0 0 auto;
	background: #4C87C1;
}

/* ---------------------------------------------------------
	CSS Document contact
--------------------------------------------------------- */

#estimate {
	margin: 0 30px 110px;
	text-align: left;
}

#estimate h2 {
	margin-bottom: 30px;
	text-align: left;
	font-weight: 500;
	font-size: 30px;
	line-height: 1.5;
}

#estimate h2:before {
	display: block;
	content: '';
	width: 60px;
	height: 2px;
	margin-bottom: 40px;
	background: #76BFF1;
}

#estimate p {
	margin-bottom: 4vw;
}

#estimate em {
	color: #CE0101;
}

#estimate dl {
	margin-bottom: 20px;
}
#estimate .errMsg {
	width: 100%;
	background: #ffdddd;
	color: #f00;
	font-weight: bold;
	padding: 1.2em;
	line-height: 1.6;
	border-radius: 0.3em;
	display: none;
	margin-bottom: 1em;
	letter-spacing: 0.1em;
}
#estimate .areaMsg {
	background: #333;
	color: #fff;
	padding: 0.6em 0.8em;
	line-height: 1;
	border-radius: 0.3em;
	display: inline-block;
	margin-bottom: 1em;
	letter-spacing: 0.1em;
	text-decoration: none;
	font-size: 0.9rem;
}

#estimate .w170 {
	max-width: 180px;
}

#estimate .w320 {
	max-width: 320px;
}

#estimate .w530 {
	max-width: 530px;
}

#estimate dt {
	font-weight: 500;
	line-height: 40px;
}

#estimate label {
	display: inline-block;
	vertical-align: middle;
	margin-right: 30px;
	line-height: 30px;
}

#estimate small {
	font-size: 12px;
}

#estimate input[type='tel'],
#estimate input[type='email'],
#estimate input[type='text'],
#estimate select,
#estimate textarea {
	width: 100%;
	padding: 0 0.8em;
	border-radius: 0;
	border: 0;
	background: #F2F2F2;
	box-shadow: none;
	letter-spacing: 0.05em;
}

#estimate select,
#estimate input[type='tel'],
#estimate input[type='email'],
#estimate input[type='text']{
	height: 50px;
}

#estimate input[type='tel'].calendar{
	background: #F2F2F2 url(../estimate/calendar.svg) no-repeat 95% / 16px auto;
}

#estimate input[type='radio'],
#estimate input[type='checkbox'] {
	vertical-align: -4px;
	width: 20px;
	height: 20px;
	margin: 0 0.5em 0 0;
	padding: 0;
}

#estimate textarea {
	vertical-align: top;
	padding: 0.8em;
}

#estimate .submit {
	display: flex;
	justify-content: space-between;
	margin-top: 40px;
}

#estimate .submit li {
	width: 48%;
}

#estimate .submit li.confirm {
	width: 260px;
	margin-left: auto;
}

#estimate .submit li.send {
	margin-left: 4%;
}

#estimate .submit button {
	vertical-align: top;
	width: 100%;
	height: 60px;
	border-radius: 0;
	background: #0054A7;
	text-align: left;
	font-weight: 500;
	font-size: 18px;
	letter-spacing: 0.05em;
	color: #fff;
	position: relative;
	z-index: 0;
	cursor: pointer;
	transition: .4s;
}

#estimate .submit button:before {
	background: #E60000;
}

#estimate .submit .confirm button:after {
	content: '';
	width: 0.4em;
	height: 0.4em;
	margin-top: -0.2em;
	border-top: solid 2px #fff;
	border-right: solid 2px #fff;
	transform: rotate(45deg);
	position: absolute;
	top: 50%;
	right: 1em;
}

#estimate .submit .confirm button {
	padding-left: 1.5em;
}

#estimate .submit button i {
	content: '';
	background: #0054A7;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: -2;
}

#estimate .submit .back button {
	background: #333;
}

/* ---------------------------------------------------------
	CSS Document estimate_confirm
--------------------------------------------------------- */

#estimate_confirm {
	margin-bottom: 110px;
	padding: 0 50px;
	background: url(../top/balloon.svg) no-repeat -30px bottom;
	text-align: left;
	position: relative;
	z-index: 0;
}

#estimate_confirm:before {
	content: '';
	width: 230px;
	height: 250px;
	background: url(../top/balloon_03.svg) no-repeat 0 0;
	position: absolute;
	bottom: -40px;
	left: -60px;
	z-index: -1;
}

#estimate_confirm h2 {
	margin-bottom: 30px;
	text-align: left;
	font-weight: 500;
	font-size: 30px;
	line-height: 1.5;
}

#estimate_confirm h2:before {
	display: block;
	content: '';
	width: 60px;
	height: 2px;
	margin-bottom: 40px;
	background: #76BFF1;
}

#estimate_confirm p {
	margin-bottom: 30px;
}

#estimate_confirm em {
	color: #CE0101;
}

#estimate_confirm dl {
	display: flex;
	margin-bottom: 10px;
}

#estimate_confirm dt {
	width: 13.5em;
	padding: 10px 0;
	font-weight: 500;
	white-space: nowrap;
}

#estimate_confirm dd {
	flex: 1;
	padding: 10px 0 10px 1em;
	border-left: solid 1px #eee;
}

#estimate_confirm .submit {
	display: flex;
	justify-content: flex-end;
	margin-top: 40px;
}

#estimate_confirm .submit li {
	margin-left: 15px;
}

#estimate_confirm .submit button {
	vertical-align: top;
	width: 100%;
	height: 60px;
	border-radius: 0;
	background: transparent;
	text-align: left;
	font-weight: 500;
	font-size: 18px;
	letter-spacing: 0.05em;
	color: #fff;
	position: relative;
	z-index: 0;
	cursor: pointer;
	transition: .4s;
}

#estimate_confirm .submit button:before {
	background: #E60000;
}

#estimate_confirm .submit button i {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: -2;
}

#estimate_confirm .submit .back button {
	width: 140px;
	padding-right: 1.5em;
	text-align: right;
}

#estimate_confirm .submit .back button i {
	background: #848484;
}

#estimate_confirm .submit .back button:after {
	content: '';
	width: 0.4em;
	height: 0.4em;
	margin-top: -0.2em;
	border-left: solid 2px #fff;
	border-bottom: solid 2px #fff;
	transform: rotate(45deg);
	position: absolute;
	top: 50%;
	left: 1em;
}

#estimate_confirm .submit .send button {
	width: 260px;
	padding-left: 1.5em;
}

#estimate_confirm .submit .send button i {
	background: #0054A7;
}

#estimate_confirm .submit .send button:after {
	content: '';
	width: 0.4em;
	height: 0.4em;
	margin-top: -0.2em;
	border-top: solid 2px #fff;
	border-right: solid 2px #fff;
	transform: rotate(45deg);
	position: absolute;
	top: 50%;
	right: 1em;
}



#outline {
	margin: 0 30px 120px;
	text-align: left;
}

#outline h2 {
	margin-bottom: 30px;
	text-align: left;
	font-weight: 500;
	font-size: 30px;
	line-height: 1.5;
}

#outline h2:before {
	display: block;
	content: '';
	width: 60px;
	height: 2px;
	margin-bottom: 40px;
	background: #76BFF1;
}

#outline .table {
	width: 100%;
	display: table;
	line-height: 1.6;
}

#outline .table dl {
	display: table-row;
	border-bottom: solid 1px #eee;
}

#outline .table dt {
	display: table-cell;
	vertical-align: top;
	width: 30%;
	padding: 15px 20px;
	background: #FBFBFB;
}

#outline .table dd {
	display: table-cell;
	vertical-align: middle;
	padding: 15px 20px;
}

#outline .tel {
	text-decoration: none;
	color: #333;
}

#outline .table dd table {
	width: 100%;
	font-size: 14px;
	line-height: 1.5;
}

#outline .table dd th {
	border: solid 1px #eee;
	background: #FBFBFB;
	padding: 5px 1em;
	text-align: left;
	font-weight: 400;
}

#outline .table dd .th th {
	padding: 5px;
	background: #EDFAFC;
	text-align: center;
}

#outline .table dd td {
	padding: 5px;
	border: solid 1px #eee;
	text-align: center;
}

#outline .table dd .td th,
#outline .table dd .td td {
	background: #F0F8E1;
}

#estimate input.additional-input {
	height:30px;
	display:inline-block;
	width:3em;
	position: relative;
	top: 2px;
	margin: 0 0.3em;
}