* {
  margin: 0;
  padding: 0;
}

/* 全体的なリンク */

a:link,
a:visited,
a:hover,
a:active { text-decoration: underline; }

a:link { color: #0066FF; }
a:visited { color: #0066FF; }
a:hover { color: #F08200; }

/* -------------------------------------------------------------
   レイアウト指定 */

body {
	font-size: 15px;
	text-align: center;

	padding: 0;
	margin: 0;
	color: #333333;
}
#bg {
	background-image: url(img/top-bg.jpg);
	background-repeat: repeat-x;
	background-position: center top;
	width: 100%;
}
#bg2 {
	background-image: url(img/bg.jpg);
	background-repeat: repeat-x;
	background-position: center top;
	width: 100%;
}
#wrapper {
	text-align: left;
	margin: 0 auto;
	padding: 0;
	width: 800px;
}

#header {
	width: 800px;
	padding: 0px;
	margin-right: auto;
	margin-left: auto;
	height: 500px;
	background-image: url(img/top-header.png);
	background-repeat: no-repeat;
	background-position: center top;
	text-align: left;
}
#header_demo {
	width: 800px;
	padding: 0px;
	margin-right: auto;
	margin-left: auto;
	height: 500px;
	background-image: url(img/top-header2.png);
	background-repeat: no-repeat;
	background-position: center top;
	text-align: left;
}
#header2 {
	width: 800px;
	padding: 0px;
	margin-right: auto;
	margin-left: auto;

	background-repeat: no-repeat;
	background-position: center top;
	text-align: left;
	height: 104px;
}

#header-inner {
	float: right;
}
#header-inner ul li{
	list-style-type: none;
	float: left;
}
#container {
	width: 800px;
	background-image: url(img/menu-bg.gif);
	background-repeat: repeat-y;
	background-position: left;
}

#contents {
	width: 650px;
	float: right;
	padding-top: 20px;
	padding-bottom: 10px;
}
#contents ol{
	margin: 0px;
	padding: 0px 0px 0px 40px;
	list-style-type: decimal-leading-zero;
}
#contents ol li{
	margin: 0px;
	padding: 0px;
	line-height: 1.5em;
	font-size: 110%;
}
#contents ul{
	margin: 0px;
	padding: 0px 0px 0px 35px;
}
#contents ul li{
	margin: 0px;
	padding: 0px;
	line-height: 1.3em;
	font-size: 110%;
}
#contents dl{
	margin: 0px;
	padding: 10px 20px;
}
#contents dl dt{
	margin: 0px;
	padding: 20px 0px 10px;
	line-height: 1.5em;
	font-size: 85%;
	color: #000099;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
	border-bottom-color: #CCCCCC;
}
#contents dl dd{
	margin: 0px;
	padding: 10px 0px 20px 15px;
	line-height: 1.5em;
	font-size: 90%;
	border-bottom-width: 1px;
	border-bottom-style: dashed;
	border-bottom-color: #999999;
}
#contents2 {
	width: 650px;
	float: right;
	padding-top: 20px;
	padding-bottom: 10px;
	font-size: 90%;
}
#contents2 dl{
	margin: 0px;
	padding: 10px 20px;
}
#contents2 dl dt{
	margin: 0px;
	padding: 0px;
	line-height: 1.7em;
	font-size: 100%;
	color: #000099;
}
#contents2 dl dd{
	margin: 0px;
	padding: 0px 0px 10px;
	line-height: 1.5em;
	font-size: 90%;
}
#left-sidebar {
	width: 146px;
	float: left;
}

#right-sidebar {
	width: 200px;
	float: right;
	margin-left: 20px;
}
 



h1 {
	color: #333333;
	margin: 0px;
	padding: 0px;
}


.logo {
	font-size: 110%;
	font-weight: bold;
	text-align: center;
	float: left;
	margin-top: 10px;
	margin-left: 40px;
}

.logo a {
  text-decoration: none;
  color: #666666;
}

.logo a:hover {
  text-decoration: none;
  color: #EF8400;
}

/* ページの概要 */
.description {
  position: absolute;
  bottom: 10px;
  left: 20px;
}

/* -------------------------------------------------------------
   コンテンツ指定 */

/* -- 見出し -- */
h2 {
	font-size: 110%;
	font-weight: bold;
	padding-left: 10px;
	color: #FFFFFF;
	padding-bottom: 5px;
	padding-top: 5px;
	margin: 0px;
	border-bottom: 1px solid #999999;
	background-color: #1D2289;
}
h3 {
	font-size: 110%;
	font-weight: normal;
	color: #FFFFFF;
	border-bottom: 1px solid #999999;
	background-color: #1D2289;
	padding: 0px 10px;
	line-height: 1.8em;
	margin-top: 1.5em;
	margin-bottom: 1.3em;
	margin-right: 0px;
	margin-left: 0px;
	border-right-width: 1px;
	border-left-width: 1px;
	border-right-style: solid;
	border-left-style: solid;
	border-right-color: #999999;
	border-left-color: #999999;
}
h4 {
	border-top-width: 3px;
	border-top-style: solid;
	border-top-color: #CCCCCC;
	padding-left: 5px;
	font-size: 130%;
	color: #333333;
	margin: 0px;
}
h5 {
	padding-left: 5px;
	font-size: 140%;
	color: #3333CC;
	margin-bottom: 1.2em;
	margin-top: 1.5em;
	font-weight: bold;
	border-left-width: 8px;
	border-left-style: solid;
	border-left-color: #3333CC;
	margin-left: 5px;
}
h6 {
	padding-left: 5px;
	font-size: 100%;
	color: #3333CC;
	font-weight: bold;
	border-left-width: 8px;
	border-left-style: solid;
	border-left-color: #3333CC;
	margin-left: 5px;
}
#contents p {
	line-height: 1.em;
	margin-bottom: 1em;
	margin-top: 1em;
	font-size: 110%;
	line-height: 1.5em;
}
#contents img {
	margin-bottom: 0px;
	margin-top: 0px;
}


/* -- サイドバータイトル -- */
.side-title { padding-bottom: 2px; }

/* -- リスト/サイドバーメニュー -- */
.localnavi {
	list-style-type: none;
	margin-bottom: 20px;
	margin-left: 0px;
	margin-right: 0px;
	margin-top: 5px;
}
.localnavi ul li {
	display: inline;
	list-style-type: circle;
	text-decoration: none;
}
.localnavi a {
	font-size: 80%;
	display: block;
	color: #FFFFFF;
	list-style-type: circle;
	text-decoration: none;
	padding: 10px 0px 10px 10px;
	background-image: url(img/point.gif);
	background-repeat: no-repeat;
	background-position: left center;
	font-weight: normal;
	line-height: normal;
}

.localnavi .now{
	background-color: #5B5B5B;
	color: #FFFFFF;
}

.localnavi a:hover {
	background-color: #5B5B5B;
	color: #FFFFFF;
}

#right-sidebar .localnavi li a {
  font-size: 90%;
  text-decoration: none;
  padding: 4px 4px;
  display: block;
  border: 1px outset #eee;
  background-color: #eee;
  color: #000;
}

#right-sidebar .localnavi li a:hover {
  text-decoration: none;
  border: 1px outset #363;
  background-color: #ccc;
  color: #f00;
}

#right-sidebar ul {
	margin: 0px;
}
#right-sidebar ul li{
	list-style-type: none;
	margin-bottom: 10px;
}
#right-sidebar a:link,
#right-sidebar a:visited {
	color: #333333;
	font-size: 100%;
	line-height: 1.5em;
	text-decoration: none;
}
#right-sidebar a:hover,
#right-sidebar a:active {
	color: #F08200;
	font-size: 100%;
	line-height: 1.5em;
	text-decoration:
}
.rosenews{
	border: 1px solid #CCCCCC;
}
#right-sidebar .rosenews .title{
	padding-top: 5px;
	padding-bottom: 2px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #999999;
	font-weight: bold;
	padding-left: 5px;
}
#right-sidebar .rosenews .linktitle{
	margin-top: 2px;
	margin-bottom: 5px;
	font-size: 12px;
	text-decoration: none;
	line-height: normal;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #E6E6E6;
	margin-right: 0px;
	margin-left: 0px;
	padding-right: 5px;
	padding-left: 5px;
}
.sidebar-dl {
	margin: 0;
}

.sidebar-dl dt {
  text-align: center;
  padding: 4px 0;
  background-color: #666;
  color: #fff;
}

.sidebar-dl dd {
	line-height: 1.5em;
	margin-bottom: 10px;
	padding: 40px 0px;
	border: 1px solid #999;
	margin-top: 0px;
	margin-right: 0px;
	margin-left: 0px;
	text-align: center;
	font-size: 70%;
}

/* -------------------------------------------------------------
   フッター */

#footer {
	font-size: 90%;
	line-height: 1.5em;
	width: 800px;
	margin-right: auto;
	margin-left: auto;
	padding-top: 5px;
	padding-bottom: 5px;
	text-align: right;
}
#footer a:link,
#footer a:visited {
	color: #333333;
	font-size: 100%;
	line-height: 1.5em;
	text-decoration: underline;
}
#footer a:hover,
#footer a:active {
	color: #F08200;
	font-size: 100%;
	line-height: 1.5em;
	text-decoration:
}
#footerbg {
	width:100%;
	min-width:1000px;
	background-image: url(img/bg-header.jpg);
	background-repeat: repeat-x;
	background-position: center top;
	border-top-width: 1px;
	border-top-style: solid;
	border-top-color: #CCCCCC;
} 
#footer p {
  text-align: center;
  padding-top: 20px;
  color: #333333;
}
hr {
	clear: both;
	color: #FFFFFF;
	border: #FFFFFF;
}
.news {
	padding: 0px;
	margin: 10px 10px 0px;
	border: 1px solid #999999;
}
.news img{
	border: none;

}
.news p {
}
#contents .news ul {
	margin-left: 20px;
	margin-top: 10px;
	margin-right: 20px;
	margin-bottom: 10px;
}
#contents .news ul li {
	line-height: 1.5em;
	font-size: 90%;
}
.news_rose {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #CCCCCC;
	padding: 20px 0px;
	margin: 0px;
}
.news_rose_title{
	font-weight: bold;
	color: #171717;
	margin-right: 10px;
	font-family: "Courier New", Courier, mono;
}
.main-banner {
	width: 780px;
	margin-bottom: 10px;
}
.main-banner img {
	margin: 0px 0px 10px;
}
.main-banner img{
	border: 2px solid #CCCCCC;
}
.main-banner img:hover{
	border: 2px solid #FFACFF;
}
#top-main {
	width: 780px;
}
#top-main img{
	margin-right: 10px;

}
#top-main ul {
	margin: 20px 0px 30px;
}
#top-main ul li{
	width: 780px;
	list-style-type: none;
	font-size: 90%;
	margin: 0px 0px 10px;
	padding: 0px;
}
#rss {
	width: 780px;
}
#rss img{
	margin-right: 10px;

}
#rss ul {
	margin: 20px 0px 30px;
}
#rss ul li{
	width: 780px;
	list-style-type: none;
	font-size: 90%;
	margin: 0px 0px 10px;
	padding: 0px;
}
.tb {
	margin: 0px auto;
	line-height: 1.3em;
	text-align: center;
	clear: both;
	font-size: 80%;
	width: 95%;
}
.tb tr{
	margin: 0px;
	padding: 0px;

}
.tb tr th{
	padding-top: 5px;
	padding-bottom: 5px;
	padding-right: 5px;
	padding-left: 5px;
	color: #333333;
	background-color: #F5F5F5;
}
.tb tr td{
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #CCCCCC;
	padding: 3px;
}
.tb .title{
	font-size: 150%;
	font-weight: bold;
}
.tb .subtitle{
	font-size: 90%;
}
.tb2 {
	margin: 0px auto;
	line-height: 1.3em;
	text-align: center;
	clear: both;
	font-size: 85%;
	width: 90%;
}
.tb2 tr{
	margin: 0px;
	padding: 0px;

}
.tb2 tr th{
	padding-top: 5px;
	padding-bottom: 5px;
	padding-right: 5px;
	padding-left: 5px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #CCCCCC;
	text-align: left;
}
.tb2 tr td{
	padding: 5px;
}
.news-post {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #CCCCCC;
	padding-top: 10px;
	padding-bottom: 20px;
}
.news-post p{
	padding-top: 5px;
	padding-bottom: 5px;
}
.news-post img{
	padding: 0px;
	margin: 0px;
	display: block;
	border: 3px solid #CCCCCC;
}
.news-post-tb{
	padding: 10px;
	margin: 0px;
	border: 1px solid #CCCCCC;
	font-size: 90%;
	background-color: #F2F2F2;
}
.post-img-preview {
	margin-top: 20px;
	margin-bottom: 20px;
	width: 100%;
}
.contents-p {
	margin-left: 15px;
	margin-right: 15px;
	line-height: 1.7em;
}
.contents-mainfont {
	color: #D7001B;
}
.contents-tyuui {
	color: #FF4646;
	font-size: 80%;
}
.link {
	background-color: #FFFF66;
	padding: 10px;
	margin: 0px;
	border: 3px solid #EBEBEB;
}
#faq {
	border: 1px solid #CCCCCC;
	padding: 5px;
	margin: 20px;
}
#faq ol{
	line-height: normal;
	margin: 0px 10px;
	padding: 0px;
}
#faq ol li{
	border-bottom-width: 1px;
	border-bottom-style: dashed;
	border-bottom-color: #CCCCCC;
	list-style-position: inside;
	line-height: 1.5em;
	font-size: 80%;
	margin: 0px;
	padding-top: 10px;
	padding-bottom: 10px;
}
