@charset "utf-8";
html {
	overflow: auto;
}
body {
	overflow: hidden;
	width: 100%;
}
#wrapper {
	width: 1440px;
	margin: 0 auto;
	color: #4d4d4d;
}
/* #header
=========================================== */
#header {
	overflow: hidden;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 5;
	display: none;
	width: 100%;
	padding-bottom: 20px;
	background-color: #fff;
	border-bottom: 1px solid #d0e9ee;
}
#headerIn {
	width: 1040px;
	margin: 0 auto;
	padding: 20px 200px;
}
#header h1.img {
	float: left;
}
/* .contact
------------------------------------------- */
#header .contact {
	float: right;
}
#header .contact .contactIn {
	overflow: hidden;
	width: 455px;
	margin-top: 8px;
}
#header .contact .contactIn p.tel {
	float: left;
	width: 204px;
}
#header .contact .contactIn p.btn {
	float: right;
}
/* #mainImg
=========================================== */
#mainImg {
	width: 1440px;
	height: 700px;
	background-image: url(/invisalign/img/mainimg01.png);
	background-color: #d0e9ee;
	position: relative;
}
#mainImg .mainImgIn {
	position: absolute;
	top: 170px;
	left: 210px;
}
#mainImg .mainImgIn h2 {
	margin-top: 30px;
}
/* #about
=========================================== */
#about {
	width: 1038px;
	overflow: hidden;
	padding: 104px 0;
	margin: 0 auto;
}
#about .textGroup {
	float: left;
	width: 560px;
	margin-right: 30px;
}
#about .textGroup h1 {
	margin-bottom: 34px;
}
#about p.img {
	float: right;
}
#about .txt p {
	font-size: 15px;
	line-height: 1.8;
}
/* #merit
=========================================== */
#merit {
	overflow: hidden;
	margin-bottom: 22px;
}
#merit section {
	float: left;
}
/* .merit01
------------------------------------------- */
#merit section.merit01 {
	width: 840px;
	height: 511px;
	background-image: url(/invisalign/img/bg_merit01.jpg);
}
#merit section.merit01 h1 {
	padding: 70px 340px 0 160px;
	margin-bottom: 30px;
}
#merit section.merit01 p {
	width: 340px;
	padding-left: 160px;
	font-size: 13px;
	line-height: 1.85;
	color: #46a1b5;
	letter-spacing: 1px;
}
/* .merit02
------------------------------------------- */
#merit section.merit02 {
	width: 599px;
	height: 510px;
	background-color: #7cc9da;
	border-top: 1px solid #fff;
	border-left: 1px solid #fff;
}
#merit section.merit02 h1 {
	padding-top: 70px;
	padding-left: 62px;
	margin-bottom: 30px;
}
#merit section.merit02 p {
	width: 346px;
	padding-left: 62px;
	font-size: 13px;
	line-height: 1.85;
	color: #fff;
	letter-spacing: 1px;
}
/* .merit03
------------------------------------------- */
#merit section.merit03 {
	width: 600px;
	height: 511px;
	border-top: 1px solid #fff;
	background-color: #7cc9da;
}
#merit section.merit03 h1 {
	padding-top: 70px;
	padding-left:200px;
	margin-bottom: 30px;
}
#merit section.merit03 p {
	width: 340px;
	padding-left: 200px;
	font-size: 13px;
	line-height: 1.85;
	color: #fff;
	letter-spacing: 1px;
}
/* .merit04
------------------------------------------- */
#merit section.merit04 {
	width: 840px;
	height: 512px;
	background-image: url(/invisalign/img/bg_merit04.jpg);
}
#merit section.merit04 h1 {
	padding-top: 70px;
	padding-left: 62px;
	margin-bottom: 30px;
}
#merit section.merit04 p {
	width: 344px;
	padding-left: 62px;
	font-size: 13px;
	line-height: 1.85;
	color: #46a1b5;
	letter-spacing: 1px;
}
/* #see_3d
=========================================== */
#see_3d {
	padding: 86px 0 120px 0;
}
#see_3d .txt {
	padding: 0 86px 46px 86px;
	text-align: center;
}
#see_3d .txt h1,
#see_3d .txt h2 {
	margin-bottom: 25px;
}
#see_3d .txt p {
	font-size: 15px;
	line-height: 2;
}
#see_3d .imgGroup {
	overflow: hidden;
	width: 1040px;
	margin: 0 auto;
}
#see_3d .imgGroup p.img01 {
	float: left;
}
#see_3d .imgGroup p.img02 {
	float: right;
}
/* #comparison
=========================================== */
#comparison {
	position: relative;
	width: 1040px;
	margin-bottom: 116px;
	padding: 106px 200px 122px 200px;
	background-image: url(/invisalign/img/bg_comparison01.jpg);
}
#comparison .tit {
	padding-bottom: 62px;
	text-align: center;
}
#comparison .tit h1 {
	margin-bottom: 26px;
}
/* .comparisonIn
------------------------------------------- */
#comparison .comparisonIn {
	overflow: hidden;
}
#comparison .comparisonIn > div {
	float: left;
	width: 460px;
	padding: 30px;
}
#comparison .comparisonIn > div > div {
	border: 1px solid #d9d9d9;
	background-color: #fff;
	text-align: center;
	color: #231815;
}
#comparison .comparisonIn > div > div .img {
	padding-top: 38px;
}
#comparison .comparisonIn > div > div h3 {
	margin: 20px 0 15px 0;
	font-size: 24px;
}
#comparison .comparisonIn .comparisonIn02 > div h3 {
	margin: 27px 0 15px 0;
}
#comparison .comparisonIn > div > div .txt {
	margin-bottom: 45px;
	font-size: 15px;
}
/* .comparisonIn01
------------------------------------------- */
#comparison .comparisonIn .comparisonIn01 {
	background-color: #bedfe9;
}
#comparison .comparisonIn .comparisonIn01 > div .listGroup01 {
	background-color: #fff;
	background-image: url(/invisalign/img/bg_comparison02.jpg);
}
#comparison .comparisonIn .comparisonIn01 > div .listGroup01 li {
	padding: 20px 0;
	color: #46a1b5;
	font-size: 19px;
	border-top: dotted 1px #d9d9d9;
	border-bottom: dotted 1px #d9d9d9;
}
/* .comparisonIn02
------------------------------------------- */
#comparison .comparisonIn .comparisonIn02 {
	background-color: #fff;
}
#comparison .comparisonIn .comparisonIn02 > div .listGroup02 li {
	padding: 20px 0;
	color: #231815;
	font-size: 19px;
	font-weight: normal;
	border-top: dotted 1px #d9d9d9;
	border-bottom: dotted 1px #d9d9d9;
}
/* .comparisonList
------------------------------------------- */
#comparison .comparisonList {
	position: absolute;
	top: 651px;
	left: 628px;
	background-color: transparent;
	text-align: center;
}
#comparison .comparisonList li {
	width: 178px;
	background-color: #59b4c8;
	margin-bottom: 12px;
	padding: 17px 0;
	color: #fff;
	font-weight: bold;
	font-size: 15px;
}
/* #flow
=========================================== */
#flow {
	margin-bottom: 120px;
}
#flow .tit {
	text-align: center;
	margin-bottom: 54px;
}
#flow ol li {
	overflow: hidden;
	width: 1040px;
	margin-bottom: 20px;
	padding: 0 200px;
}
#flow ol li.last {
	margin-bottom: 0;
}
#flow ol li p.img,
#flow ol li section {
	float: left;
}
#flow ol li section h1,
#flow ol li section p {
	margin-left: 43px;
	text-align: left;
}
#flow ol li section h1 {
	padding: 48px 0 26px;
	font-size: 24px;
	font-weight: bold;
	color: #46a1b5;
}
#flow ol li section p {
	font-size: 15px;
	line-height: 2;
}
/* #msg
=========================================== */
#msg {
	width: 100%;
	padding: 0 900%;
	margin: 0 -900%;
	background-image: url(/invisalign/img/bg_01.jpg);

}
#msg .msgIn {
	position: relative;
	width: 1040px;
	margin-bottom: 117px;
	padding: 102px 200px;
}
#msg .msgIn > p.img {
	position: absolute;
	top: 117px;
	right: 200px;
}
#msg .msgIn h1 {
	margin-bottom: 56px;
}
#msg .txtGroup p {
	width: 625px;
	font-size: 15px;
	line-height: 2;
	letter-spacing: 1px;
}
#msg .txtGroup p.img {
	margin-top: 32px;
	text-align: right;
}
/* #guide
=========================================== */
#guide h1 {
	margin-bottom: 66px;
	text-align: center;
}
#guide .guideIn {
	overflow: hidden;
	width: 1040px;
	margin: 0 auto 90px auto;
}
/* .guideIn01
------------------------------------------- */
#guide .guideIn .guideIn01 {
	float: left;
	padding-top: 1px;
}
#guide .guideIn .guideIn01 dl {
	width: 490px;
	padding: 10px 0;
	border-bottom: 1px dotted #cbcacf;
}
#guide .guideIn .guideIn01 dl.first {
	padding-top: 0;
}
#guide .guideIn .guideIn01 dl.last {
	padding-bottom: 0;
	border-bottom: 0;
}
#guide .guideIn .guideIn01 dt,
#guide .guideIn .guideIn01 dd {
	display: inline-block;
	padding: 17px 0;
	font-size: 13px;
	line-height: 1.1;
}
#guide .guideIn .guideIn01 dt {
	width: 100px;
	background-color: #59b4c8;
	color: #fff;
	text-align: center;
}
#guide .guideIn .guideIn01 dd {
	padding-left: 30px;
}
#guide .guideIn .guideIn01 table {
	width: 490px;
	margin-top: 26px;
	border: 1px solid #cbcacf;
}
#guide .guideIn .guideIn01 .consultationHours th,
#guide .guideIn .guideIn01 .consultationHours td {
	text-align: center;
	vertical-align: middle;
	border: 1px solid #cbcacf;
}
#guide .guideIn .guideIn01 .consultationHours th,
#guide .guideIn .guideIn01 .consultationHours thead td {
	padding: 17px 15px;
	background-color: #f8f6f6;
	font-size: 14px;
	font-weight: bold;
}
/* .guideIn01
------------------------------------------- */
#guide .guideIn .guideIn02 {
	float: right;
}
/* .map
------------------------------------------- */
#guide .map {
	width: 1040px;
	height: 342px;
	margin: 0 auto;
}
#guide p.access {
	width: 1040px;
	margin-top: 10px;
	padding: 0 200px;
	text-align: left;
}
#guide p.access strong {
	font-weight: bold;
}
#guide > p.img {
	margin-top: 86px;
}
/* #contact
=========================================== */
#contact {
	width: 100%;
	padding: 0 900%;
	margin: 0 -900%;
	background-image: url(/invisalign/img/bg_02.jpg);
}
#contact .contactIn {
	width: 1440px;
	padding: 94px 0 64px 0;
	background-color: #59b4c8;
}
#contact .contactIn h1 {
	margin-bottom: 78px;
	text-align: center;
}
#contact .contactIn form {
	position: relative;
	width: 1040px;
	margin: 0 auto;
	border: 30px solid #f8f6f6;
	border-top: 60px solid #f8f6f6;
}
#contact .contactIn form:before {
	position: absolute;
	content: url(/invisalign/img/img_form02.png);
	top: -38px;
	right: 372px;
}
#contact .contactIn form .formIn {
	padding: 47px;
	background-color: #fff;
}
#contact .contactIn form .formIn .introduction {
	margin-bottom: 34px;
}
#contact .contactIn form .formIn .introduction p {
	font-size: 15px;
	line-height: 2;
}
#contact .contactIn form table {
	margin-bottom: 44px;
}
#contact .contactIn form table tr {
	border-top: 1px dotted #cbcacf;
}
#contact .contactIn form table tr.last {
	border-bottom: 1px dotted #cbcacf;
}
#contact .contactIn form table tr th {
	display: inline-block;
	width: 220px;
	font-size: 15px;
	padding: 52px 0 38px 15px;
}
#contact .contactIn form table tr th.must {
	background-image: url(/invisalign/img/img_form03.jpg);
	background-repeat: no-repeat;
	background-position: right 44px;
}
#contact .contactIn form table tr td {
	width: 680px;
	padding: 42px 0;
	padding-left: 30px;
	vertical-align: middle;
}
#contact .contactIn form table strong.error {
	line-height: 34px;
}
#contact .contactIn form table input {
	height: 34px;
	padding: 0;
	background-color: #faf9f6;
	border: 1px solid #d6d4c9;
}
#contact .contactIn form table input[id="name"],
#contact .contactIn form table input[id="kana"],
#contact .contactIn form table input[id="tel"] {
	width: 318px;
}
#contact .contactIn form table input[id="postcode"] {
	width: 108px;
}
#contact .contactIn form table input[id="address"] {
	width: 578px;
}
#contact .contactIn form table input[id="mail"] {
	width: 488px;
}
#contact .contactIn form table textarea[id="msg"] {
	width: 588px;
}
#contact .contactIn form table select {
	height: 36px;
	margin: 0 0 17px 30px;
	padding: 4px;
	background-color: #faf9f6;
	border: 1px solid #d6d4c9;
}
#contact .contactIn form table textarea {
	max-width: 660px;
	min-width: 660px;
	background-color: #faf9f6;
	border: 1px solid #d6d4c9;
}
#contact .contactIn form table div.input_wrap {
	display: inline-block;
	position: relative;
}
#contact .contactIn form table div.input_wrap .popupMust {
	position: absolute;
	top: -30px;
	padding: 5px;
	background-color: #f6a7a7;
	border-radius: 4px;
	color: #fff;
}
#contact .contactIn form table div.input_wrap .popupMust:after {
	position: absolute;
	display: block;
	bottom: -10px;
	left: 30px;
	content: "";
	width: 0;
	height: 0;
	border: 5px solid #f6a7a7;
	border-right-color: transparent;
	border-bottom-color: transparent;
	border-left-color: transparent;
	z-index: 5;
}
#contact .contactIn form table div.input_wrap input[name="address"] {
	margin-bottom: 17px;
}
#contact .contactIn form p.send {
	text-align: center;
}
#contact .contactIn form center a {
	display: inline-block;
}
#footer {
	position: relative;
	width: 100%;
	padding: 0 900% 65px 900%;
	margin: 0 -900%;
	background-image: url(/invisalign/img/bg_02.jpg);
	text-align: center;
}
#footer small {
	color: #fff;
	font-size: 13px;
}
#footer p.pageTop {
	position: relative;
}
#footer p.pageTop a {
	display: inline-block;
	position: absolute;
	width: 36px;
	height: 24px;
	top: -20px;
	right: 0;
	background-image: url(/invisalign/img/ico_footer01.png);
	background-repeat: no-repeat;
	background-position: 0 bottom;
	text-indent: -99999px;
}
#footer p.pageTop a:hover {
	background-position: 0 3px;
}