@charset "shift_jis";
@import url("./css/commonstyles.css");
@import url("./css/tables.css");
body {
text-align:center;
color:#333;
font-size:14px;
line-height:140%;
font-family: 'Hiragino Kaku Gothic ProN', Meiryo, 'MS PGothic', Sans-serif;
margin:0;
padding:0;
}

#header {
	height: 106px;
	margin-bottom: 10px;
	background-image: url(img/header_bg.jpg);
	background-repeat: repeat-x;

}
#header #logo {
	display: block;
	height: 67px;
	width: 118px;
	float: left;
	margin-top: 7px;
	margin-right: 5px;
	margin-bottom: 5px;
	margin-left: 5px;
}

#headimage {
	margin-right: auto;
	margin-left: auto;
	width:100%;
	max-width:900px;

	background-image: url(./img/header.jpg);
}
#freedial {
	margin-right: auto;
	margin-left: auto;
	width:100%;
	max-width:450px;
}

#btn_estimate {
	margin-top: 10px;
	margin-bottom: 30px;

}

	
#index_read {
	background-color: #EEEEEE;
	padding: 5px;
	margin-bottom: 20px;

}
#lady_service {
	padding: 5px;
	margin-top: 10px;
	margin-bottom: 10px;


}

div,p,h1,h2,h3,h4,h5,h6 {
display:block;
text-align:left;
margin:0;
padding:0;
}

img {
max-width:100%;
}

.FloatEnd {
clear:both;
display:block;
height:1px;
}

a,a:visited {
color:#069;
}

a:hover {
color:red;
}

a img {
border:none;
text-decoration:none;
}

.txt-img img {
margin:0 10px 10px;
}

strong {
font-weight:700;
margin:0 0.2em;
padding:0;
}

em {
font-weight:400;
text-decoration:underline;
margin:0 0.2em;
padding:0;
}

ul,ol {
display:block;
_margin-left:0;
_margin-right:0;
}

ul {
	margin-top:10px;
	margin-bottom:10px;
	_margin-left:20px;
	_padding-left:20px;
	margin-left: 0px;
	margin-right: 10px;
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 20px;
}

ol {
list-style-type:decimal;
_margin-left:30px;
_padding-left:20px;
margin:10px 0;
}

*:first-child+html ol {
margin-left:30px;
padding-left:20px;
}

li {
	display:list-item;
	margin:0;
}

ul li {
list-style-type:none;
list-style-image:url(./img/li.gif);
}

p {
	width:auto;
	margin-top: 0;
	margin-right: auto;
	margin-left: auto;
}

#text1,#text2,#text3,#text4,#text5,#text6,#text7,#text8,#text9,#text10 {
	margin-bottom:25px;
	padding-top: 10px;
	padding-bottom: 10px;
	padding-right: 10px;
	padding-left: 10px;
}

#siteNavi {
font-size:11px;
line-height:1.5em;
margin-bottom:5px;
padding:5px;
}

#contents {
	_height:10px;
	padding-top:10px;
	padding-bottom:10px;

	width:100%;
	max-width:450px;
	margin-right: auto;
	margin-left: auto;
}

#menu:after,#contents:after {
height:1px;
overflow:hidden;
content:"";
display:block;
clear:both;
}

#footer {
	text-align:center;
	color:#666;
	line-height:20px;
	height:64px;
	background-repeat:repeat-x;
	background-position:left top;
	padding-top:15px;
	background-color: #EEEEEE;
}

#footer a {
color:#666;
text-decoration:none;
}

#footlink {
text-align:center;
padding-top:5px;
padding-bottom:5px;
color:#FFFFFF;
font-size:12px;
background-color:#F87310;
}

#footlink a {
color:#FFFFFF;
margin-right:5px;
margin-left:5px;
}

#space3,#space4,#space5,#space6 {
background-color:#FFF;
text-align:center;
padding-top:15px;
padding-bottom:15px;
}

#text2 h3,#text3 h3,#text4 h3,#text5 h3,#text6 h3,#text6 h3,#text7 h3,#text8 h3,#text9 h3,#text10 h3 {
position:relative;
left:-12px;
width:108%;
margin-top:15px;
margin-bottom:15px;
}

#searchbox {
text-align:center;
line-height:50px;
font-size:13px;
height:50px;
background-image:url(./img/search_bg.gif);
color:#FFF;
text-shadow:2px 2px 2px #333;
}

#searchbox input {
vertical-align:middle;
margin-right:2px;
margin-left:2px;
}

#searchbox form {
margin:0;
padding:0;
}

form input {
vertical-align:middle;
}

h1 {
	font-size:14px;
	line-height:14px;
	text-align:left;
	padding-top: 5px;
	padding-right: 5px;
	padding-bottom: 5px;
	padding-left: 5px;
	font-weight: normal;
	background-color: #EEE;
}

h3 {
	font-size:24px;
	line-height:32px;
	color:#333;
	display:block;
	text-indent: 5px;
}

h3.top_h3 {
	font-size:18px;
	line-height:22px;
	margin-top: 10px;
	margin-bottom: 10px;
	background-image: url(img/h4.gif);
	background-repeat: no-repeat;
	background-position: left top;
	text-indent: 12px;
}


#main h5 {
background-image:url(img/h5.gif);
background-position:left 2px;
background-repeat:no-repeat;
font-size:15px;
line-height:20px;
text-indent:20px;
margin-top:10px;
margin-bottom:3px;
}

#main h4 {
	background-image:url(./img/h4.gif);
	background-repeat:no-repeat;
	background-position:left center;
	font-size:18px;
	padding-left:12px;
	line-height:20px;
	margin-top: 6px;
	margin-bottom: 8px;
	display: block;
}
#main h4.top_h4 {
	background-image: none;
	text-indent: 0px;
	padding-left:0px;
}

#main h6 {
background-image:url(img/h6.gif);
background-repeat:no-repeat;
background-position:left center;
padding-left:20px;
font-size:15px;
line-height:20px;
margin-top:6px;
margin-bottom:6px;
}

#sitemaps {
padding:0 10px;
}

#sitemaps li {
list-style-type:none;
list-style-image:none;
}

#sitemaps .sbox1,#sitemaps .sbox2 {
width:47%;
margin-top:5px;
margin-bottom:5px;
padding:5px;
}

#sitemaps .sbox1 {
float:left;
clear:left;
}

#sitemaps .sbox2 {
float:right;
clear:right;
}

#sitemaps .l1 {
background-image:url(./img/sitemap_l1.jpg);
line-height:26px;
height:26px;
font-weight:700;
margin-bottom:5px;
margin-top:0;
background-repeat:no-repeat;
background-position:5px center;
padding-left:35px;
overflow:hidden;
}

#sitemaps .l2 {
background-image:url(img/sitemap_l2.jpg);
background-repeat:no-repeat;
background-position:left 4px;
line-height:20px;
text-indent:15px;
margin-left:22px;
margin-bottom:3px;
}

#sitemaps .l3 {
background-image:url(img/sitemap_l3.jpg);
background-repeat:no-repeat;
background-position:left 4px;
line-height:20px;
text-indent:15px;
margin-left:38px;
margin-bottom:3px;
}

#whatsnew {
border:1px solid #CCC;
background-image:url(img/whats_top.jpg);
background-repeat:no-repeat;
background-position:left top;
padding:45px 10px 10px;
}

#whatsnew li {
line-height:25px;
list-style-image:url(img/whats_li.jpg);
margin-right:10px;
margin-left:10px;
}

#categorylist {
margin-top:10px;
margin-bottom:10px;
padding:0;
}

#categorylist .cbox {
background-image:url(img/entrylist.gif);
background-repeat:repeat-x;
font-size:12px;
line-height:130%;
min-height:100px;
padding:15px 10px 10px;
}

#categorylist .title {
clear:none;
font-size:14px;
line-height:22px;
overflow:hidden;
margin:0 0 8px;
padding:0;
}

#categorylist .desc {
font-size:12px;
line-height:130%;
color:#505050;
padding:10px;
}

#categorylist .more {
text-align:right;
padding-right:10px;
padding-left:10px;
padding-bottom:5px;
}

#categorylist .bottom {
background-image:url(img/categorylist_bottom.jpg);
background-repeat:no-repeat;
background-position:center bottom;
}

#entrylist {
padding:10px;
}

#entrylist dl {
display:block;
padding:6px;
}

#main #entrylist h4 {
color:#069;
background-image:url(./img/entlist_title.jpg);
background-repeat:no-repeat;
background-position:left bottom;
padding-left:30px;
margin:0 0 10px;
}

#entrylist dt {
font-weight:700;
font-size:14px;
background-image:url(./img/entlist.jpg);
background-repeat:no-repeat;
background-position:left center;
padding-left:15px;
line-height:20px;
}

#entrylist dd {
margin-left:15px;
margin-bottom:8px;
font-size:11px;
color:#757575;
line-height:120%;
}

.txt-border {
background-image:url(img/dott.gif);
line-height:22px;
font-size:13px;
background-position:0 5px;
margin:10px;
padding:0;
}

.txt-border p {
line-height:22px;
font-size:13px;
}

.txt-yellowback {
background-color:#FFF9DF;
border:2px solid #C00;
}

.txt-grayback {
border:1px solid #D9D9D9;
background-color:#E6E6E6;
}

.txt-colorback {
border:1px solid #FFB380;
background-color:#FFF2DF;
}

.hd {
color:#333;
text-decoration:none;
}

#main .txt-grayback,#main .txt-colorback,#main .txt-line {
margin-top:10px;
margin-bottom:10px;
padding:15px;
}



#searchresult {
padding:15px;
}

#searchresult dt {
background-image:url(img/entlist.jpg);
background-repeat:no-repeat;
background-position:left center;
margin-top:15px;
font-size:14px;
padding-left:16px;
}

#searchresult dd {
line-height:130%;
font-size:13px;
margin:0;
}

h2,h3,h4,.title,.menutitle,.rank1,.rank2,.rank3,.rank4,.rank5,.point,.point1,.point2,.point3,.point4,.point5 {
font-weight:700;
}

h1,h2,h3,h4,#categorylist .cbox:after {
clear:both;
}

form,dl,#sitemaps ul {
margin:0;
padding:0;
}

#categorylist h3,.menutitle {
line-height:26px;
background-image:url(img/headline_bg.gif);
height:26px;
font-size:14px;
color:#FFF;
text-align:center;
overflow:hidden;
text-shadow:2px 2px 2px #333;
}



.txt-line,#main .nmlbox {
border:2px solid #CCC;
}#linklist {
	padding: 10px;
}
#linklist dt {
	font-weight: bold;
	padding-left: 15px;
	background-image: url(img/entlist.jpg);
	background-repeat: no-repeat;
	background-position: left center;
}
#linklist dd {
	margin-left: 15px;
	font-size: 11px;
	margin-bottom: 8px;
	line-height: 130%;
}

#topmenu {
	background-image: url(img/topmenu-bg.jpg);
	background-repeat: repeat-x;
	background-position: left top;
    width: 100%;
	height: 42px;
	margin: 0 auto 0 auto;
	text-align: center;
	overflow: hidden;
}

#topmenu span {
    width: 100%;
	margin: 0 auto 0 auto;
	padding: 8px 20px 10px 20px;
	text-align: center;
	color: #FFF;
	line-height: 42px;
	font-weight: 800;
	border-left: solid 1px #f7c899;
}

#topmenu a {
	color: #FFF;
	text-decoration: none;
}

#topmenu span:last-child {
	border-right: solid 1px #f7c899;
}

/* fixImageStyles */
.img-center{text-align:center;max-width:100%;height:auto;}
.img-center img{max-width:100%;height:auto;}
span.img-center{display:block;}
table.rank-table td .img-center{
	text-align:left !important;
	margin-top: 1px;
	margin-left: 1px;
}

#tell {
	background-color: #EEEEEE;
	padding-top: 10px;
	padding-bottom: 5px;
	font-size: 12px;
	margin-top: 1px;
	margin-bottom: 1px;
}

#contact-box {
	height: 35px;
	width: 320px;
	padding: 5px;
	margin-top: 0px;
	margin-right: auto;
	margin-bottom: 0px;
	margin-left: auto;
	color: #FFFFFF;
}
#contact-box .txtbox {
	float: left;
	width: 60px;
	font-size: 10px;
	height: 10px;
	display: block;
	clear: left;
	line-height: 10px;
	padding-top: 6px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
	margin-top: 5px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
}
#contact-box .dialbox {
	float: right;
	width: 144px;
	display: block;
	height: 15px;
	background-image: url(img/freedial.gif);
	background-repeat: no-repeat;
	background-position: 7px bottom;
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 32px;
	font-size: 19px;
	vertical-align: bottom;
	line-height: 19px;
	clear: right;
	margin-top: 5px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
}
#contact-box .dialbox a{
	color: #FFFFFF;
	text-decoration: none;

}
#contact-box .timebox {
	float: left;
	width: 240px;
	display: block;
	padding: 0px;
	clear: left;
	height: 15px;
	font-size: 10px;
	margin: 0px;
}
#contact-box #contact-box-left{
	height: 35px;
	width: 240px;
	margin: 0px;
	padding: 0px;
	clear: left;
	float: left;
}
#contact-box #contact-box-right{
	height: 35px;
	width: 80px;
	margin: 0px;
	padding: 0px;
	clear: right;
	float: right;
}

.red {
	color:#FF0000;
}
#ssl {
	width:330px;
	max-width:450px;
	display: block;
	height: 57px;
	margin-right: auto;
	margin-left: auto;
	margin-top: 30px;
	clear: both;
}
#ssl #ss_img_wrapper_130-66_flash_ja{
	display: block;
	width:133px;
	float: left;
	vertical-align: top;
}
#ssl_right {
  	display: inline-block;
  	vertical-align: top;
	float: right;
	width: 62%;
}

#tpoint{
	width:100%;max-width:450px;
	display: block;
	margin-right: auto;
	margin-left: auto;
	margin-top: 10px;
}

#tpoint img{
	vertical-align: top;
	margin-right: 5px;
}



.button::before,
.button::after {
  position: absolute;
  z-index: -1;
  display: block;
  content: '';
}
.button,
.button::before,
.button::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all .3s;
  transition: all .3s;
}

.button {
	display: inline-block;
	width: 100%;
	text-align: center;
	text-decoration: none;
	line-height: 52px;
	outline: none;
	position: relative;
	background-color: #1abc9c;
	border-radius: 4px;
	color: #fff;
	line-height: 52px;

  -webkit-transition: none;
	transition: none;
	box-shadow: 0 3px 0 #0e8c73;
	text-shadow: 0 1px 1px rgba(0, 0, 0, .3);
	font-size: 16px;
}
.button:hover {
  background-color: #31c8aa;
  box-shadow: 0 3px 0 #23a188;
}
.button:active {
  top: 3px;
  box-shadow: none;
}
.button:visited {
	color:#FFFFFF;
}


.button2::before,
.button2::after {
  position: absolute;
  z-index: -1;
  display: block;
  content: '';
}
.button2,
.button2::before,
.button2::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all .3s;
  transition: all .3s;
}

.button2 {
	display: inline-block;
	width: 100%;
	text-align: center;
	text-decoration: none;
	line-height: 35px;
	outline: none;
	position: relative;
	background-color: #1abc9c;
	border-radius: 4px;
	color: #fff;
	line-height: 35px;

  -webkit-transition: none;
	transition: none;
	box-shadow: 0 3px 0 #0e8c73;
	text-shadow: 0 1px 1px rgba(0, 0, 0, .3);
	font-size: 12px;
}
.button2:hover {

  background-color: #31c8aa;
  box-shadow: 0 3px 0 #23a188;
}
.button2:active {

  top: 3px;
  box-shadow: none;
}

.button2:visited {
	color:#FFFFFF;
}

nav.globalMenuSp {
    position: fixed;
    z-index: 2;
    top: 0;
    left: 0;
    background: #fff;
    color: #000;
    text-align: center;
    transform: translateY(-100%);
    transition: all 0.6s;
    width: 100%;
}

nav.globalMenuSp ul {
    background: #eee;
    margin: 0 auto;
    padding: 0;
    width: 100%;
}

nav.globalMenuSp ul li {
    font-size: 1.1em;
    list-style-type: none;
    padding: 0;
    width: 100%;
    border-bottom: 1px dotted #333;
}

/* 最後はラインを描かない */
nav.globalMenuSp ul li:last-child {
    padding-bottom: 0;
    border-bottom: none;
}

nav.globalMenuSp ul li a {
	display: block;
	color: #000;
	text-align: left;
	text-indent: 25px;
	background-image: url(img/menu_arrow.png);
	background-repeat: no-repeat;
	background-position: 5px center;
	padding-top: 0.8em;
	padding-right: 0;
	padding-bottom: 0.8em;
	padding-left: 0;
}

/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
    transform: translateY(0%);
}


.navToggle {
    display: block;
    position: fixed;
    right: 13px;
    top: 25px;
    width: 42px;
    height: 51px;
    cursor: pointer;
    z-index: 3;
    background: #FFF;
    text-align: center;
	opacity: 0.9;
}

.navToggle span {
    display: block;
    position: absolute;    /* .navToggleに対して */
    width: 30px;
    border-bottom: solid 3px #555;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
    left: 6px;
}

.navToggle span:nth-child(1) {
    top: 9px;
}

.navToggle span:nth-child(2) {
    top: 18px;
}

.navToggle span:nth-child(3) {
    top: 27px;
}

.navToggle span:nth-child(4) {
    border: none;
    color: #555;
    font-size: 9px;
    font-weight: bold;
    top: 34px;
}


/* 最初のspanをマイナス45度に */
.navToggle.active span:nth-child(1) {
    top: 18px;
    left: 6px;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

/* 2番目と3番目のspanを45度に */
.navToggle.active span:nth-child(2),
.navToggle.active span:nth-child(3) {
    top: 18px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
}



#menu {

}
#menu h4 {
	text-align:left;
	overflow:hidden;
	font-size: 16px;
	line-height: 32px;
	text-indent: 5px;
	background-color: #F87310;
	color: #FFFFFF;
}
.menubox {
	border-top-width: 3px;
	border-bottom-width: 3px;
	border-top-style: solid;
	border-bottom-style: solid;
	border-top-color: #eee;
	border-bottom-color: #eee;
}
.top_menubox {
	background-color: #eee;
	border: 3px solid #eee;

}

#menu ul,#rmenu ul {
list-style-type:none;
list-style-image:none;
margin:0;
padding:0;
}


#menu li,#rmenu li {
	list-style-type:none;
	list-style-image:none;
	display:block;
	_display:inline;
	height:48px;
	line-height:48px;
	background-color: #FFFFFF;
	padding-right: 0;
	padding-bottom: 0px;
	padding-left: 0;
	border: 3px solid #eee;
}

#menu li a {
height:48px;
line-height:48px;
display:block;
font-size:12px;
text-decoration:none;
background-repeat:no-repeat;
background-position:3px center;
padding-right:6px;
padding-left:18px;
color:#333;
background-image:url(./img/menu_arrow.png);
overflow:hidden;
margin:5;
}

#menu li a:hover {
background-color:#FAE7D3;
}



.topmenu ul {
list-style-type:none;
list-style-image:none;
margin:0;
padding:0;
}


.topmenu li {
	list-style-type:none;
	list-style-image:none;
	display:block;
	_display:inline;
	height:48px;
	line-height:48px;
	background-color: #FFFFFF;
	padding-right: 0;
	padding-bottom: 0px;
	padding-left: 0;
	border: 3px solid #eee;
	width: 48%;
	float: left;
}

.topmenu li a {
	height:48px;
	line-height:48px;
	display:block;
	font-size:12px;
	text-decoration:none;
	background-repeat:no-repeat;
	background-position:3px center;
	padding-right:6px;
	padding-left:18px;
	color:#333;
	background-image:url(./img/menu_arrow.png);
	overflow:hidden;
	margin:5;

}

.topmenu li a:hover {
background-color:#FAE7D3;
}

p img {
	float: left;
	margin-right: 10px;
	margin-bottom: 10px;
}


.listmenu ul {
list-style-type:none;
list-style-image:none;
margin:0;
padding:0;
}


.listmenu li {
	list-style-type:none;
	list-style-image:none;
	display:block;
	_display:inline;
	height:32px;
	line-height:32px;
	padding-right: 0;
	padding-bottom: 0px;
	padding-left: 0;
}

.listmenu li a {
height:32px;
line-height:32px;
display:block;
background-repeat:no-repeat;
background-position:3px center;
padding-right:6px;
padding-left:18px;
background-image:url(./img/menu_arrow.png);
overflow:hidden;
margin:5;
}
