@charset "shift-jis";

/* ------------- Reset ----------------- */
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td {
	padding: 0;
	margin: 0;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
fieldset,img {
	border: 0;
}
address,caption,cite,code,dfn,em,strong,th,var {
	font-weight: normal;
	font-style: normal;
}
ol,ul {
	list-style: none;
}
caption,th {
	text-align: left;
}
h1,h2,h3,h4,h5,h6 {
	font-weight: normal;
	font-size: 100%;
}
q:before,q:after {
	content:'';
}
abbr,acronym {
	border: 0;
}

/* ------------- Common ----------------- */
.red {
	color: #f00;
}

.small {
	font-size: 80% !important;
}

.bold {
	font-weight: bold;
}

.clear {
	clear: both;
}

.text_right {
	text-align: right;
}

.padding_b {
	padding-bottom: 12px;
}

/* ------------- Link Style ----------------- */
a {
	color: #03c;
}

a:visited {
	color: #639;
	text-decoration: none;
}

a:hover {
	color: #f03;
	text-decoration: none;
}

a.info {
	font-weight: bold;
	color: red;
	text-decoration: underline;
}

a:hover.info {
	color: #666;
}

/* ------------- Wrapper ----------------- */
body {
	background: url(/img/body_bg.jpg) 0 0 repeat-x;
	color: #333;
}

#wrapper {
	width: 980px;
	margin: 0 auto;
	padding: 0;
}

/* ------------- Header ----------------- */
#header {
	height: 90px;
}

#header h1,
#header h2 {
	height: 16px;
	padding-top: 10px;
	font-size: 14px;
	color: #fff;
}

#site-logo {
	margin-top: 12px;
}

/* ------------- Menu ----------------- */
#menu {
	padding-top: 8px;
}

#menu li {
	float: left;
}

/* ------------- Contents ----------------- */
#contents {
	clear: left;
}

#contents p {
	padding-top: 6px;
	font-size: 90%;
	line-height: 1.2;
}

/* ------------- Main ----------------- */
#main {
	float: left;
	width: 730px;
	margin-bottom: 8px;
}

#main p {
	margin-bottom: 0.75em;
	line-height: 1.5;
}

p#path {
	font-size: 80%;
}

p#path span {
	font-weight: bold;
}

#main h1,
#main h2,
#main h3 {
	clear: both;
	padding-bottom: 2px;
}

.main_title {
	padding-bottom: 12px !important;
}

#top {
	clear: both;
}

p#noscript {
	padding: 8px 6px 6px 6px;
	border: 1px solid #ccc;
	color: #f30;
	background-color: #ffc;
	font-weight: bold;
	text-align: center;
}

/* ------------- TopMain ----------------- */
#top_main {
	position: relative;
	width: 978px;
	height: 318px;
	margin: 6px auto 6px auto;
	border: 1px solid #ccc;
	background: url(/img/main_bg.jpg) 0 0 no-repeat;
}

#lesson {
	margin-top: 130px;
	margin-left: 302px;
	width: 420px;
	height: 160px;
	background: url(/img/lesson.gif) 0 0 no-repeat;
	overflow: hidden;
}

#lesson p#title {
	padding: 15px 10px 0 20px;
	color: #fff;
	font-size: 14px;
	font-weight: bold;
	line-height: 1.0;
}

#lesson p#title a {
	vertical-align: top;
	color: #ff0;
	text-decoration: none;
	font-size: 13px;
	font-weight: normal;
}

#lesson p#title a:hover {
	color: #f00;
}

#lesson p#text {
	padding: 10px 10px 0 10px;
	font-size: 14px;
	line-height: 1.5;
}

#lesson p#lesson_link {
	padding: 8px 10px 6px 10px;
	text-align: right;
	font-size: 13px;
	line-height: 1.3;
}

#submenu {
	margin-top: -287px;
	margin-left: 739px;
}

/* ------------- NewsTicker ----------------- */
#ticker-wrapper {
	padding-bottom: 6px;
}

#newsticker {
	width: 780px;
	height: 30px;
	background: url(/img/news_bg.gif) 0 0 no-repeat;
	background-color: #f2f2f2;
	font-size: 14px;
	font-weight: bold;
	padding-left: 200px;
	overflow: hidden;
}

#newsticker a {
	text-decoration: none;
}

.newsticker-jcarousellite {
	width: 780px;
}

.newsticker-jcarousellite ul li {
	list-style: none;
	display: block;
	padding: 9px 6px 0 6px;
}

.newsticker-jcarousellite .info {
	width: 774px;
}

#top-banner {
	float: left;
	width: 726px;
}

.top-banner-list li {
	float: left;
	margin-right: 6px;
	margin-bottom: 6px;
}

.top-banner-list li.no-r-margin {
	margin-right: 0px;
}

/* ------------- Twitter ----------------- */
#twitter {
	float: right;
	width: 250px;
}

#tweet-widget {
	margin-top: 4px;
}

p#pager {
	clear: both;
	font-size: 100%;
	font-weight: bold;
	text-align: center;
}

p.page-top {
	clear: both;
	margin-top: 24px;
	font-size: 80% !important;
	text-align: right;
}



/* ------------- 共通パーツ ----------------- */
table#cfg_list,
table#cfg_video {
	margin-top: 8px;
	width: 100%;
}

table#cfg_list th,
table#cfg_video th {
	padding: 6px 5px 5px 5px;
	background-color: #ffc;
	border: 1px solid #ccc;
	font-weight: bold;
	font-size: 90%;
}

table#cfg_list td,
table#cfg_video td {
	width: 33%;
	padding: 5px;
	vertical-align: middle;
	border: 1px solid #ccc;
}

table#cfg_list td img {
	float: left;
	margin-right: 6px;
}

table#cfg_list td p {
	margin: 0;
	line-height: 1.2;
	font-size: 80%;
}

table#cfg_video td .youtube {
	float: left;
	width: 250px;
}

table#cfg_video td .youtube_txt {
	float: left;
	width: 460px;
}

table#cfg_video td p {
	margin: 0;
	padding: 0;
	line-height: 1.5;
	font-size: 90%;
}

table#cfg_video td p.video_title {
	height: 100px;
	padding-left: 106px;
	background: url(/game/img/m_02.gif) 0 0 no-repeat;
}




/* ------------- Right_menu ----------------- */
#right_menu {
	float: right;
	width: 240px;
	margin-bottom: 12px;
}

#right_menu_title {
	margin-top: 6px;
}

#right_menu li {
	background-color: #f2f2f2;
	border-left: 1px solid #ccc;
	border-right: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	font-size: 80%;
}

#right_menu li#on {
	padding: 10px 8px;
	background-color: #8e1540;
	color: #fff;
	font-size: 80%;
	font-weight: bold;
}

#right_menu li#sub_on {
	margin-left: 6px;
	padding: 10px 8px 10px 16px;
	background: url(/img/r_menu_arrow02.gif) 8px 14px no-repeat;
	background-color: #8e1540;
	color: #fff;
	font-size: 80%;
	font-weight: bold;
}

#right_menu li a {
	padding: 10px 8px;
	display: block;
	color: #333;
	text-decoration: none;
}

#right_menu li a:hover {
	color: #fff;
	background-color: #8e1540;
}

#right_menu li.sub a {
	padding-left: 18px;
	background: url(/img/r_menu_arrow01.gif) 10px 14px no-repeat;
}

#right_menu li.sub a:hover {
	background: url(/img/r_menu_arrow02.gif) 10px 14px no-repeat;
	background-color: #8e1540;
}

#right_menu_banner {
	text-align: center;
}

#right_menu_banner img {
	margin-top: 10px;
}

/* ------------- top_info 告知ページ用リンク ----------------- */
p#top_info {
	width: 980px;
	margin: 0 auto 12px auto;
	padding: 8px 0 6px 0;
	border: 1px solid #666;
	background-color: #ffc;
	text-align: center;
	font-size: 14px;
}

/* ------------- info_main ----------------- */
#info_main {
	width: 756px;
	margin: 12px auto 8px auto;
	padding: 12px;
	border: 1px solid #ccc;
}

#info_main p#date {
	padding-top: 0;
	font-size: 90%;
	line-height: 1;
}

#info_main h1 {
	margin-top: 6px;
	padding: 2px 0 0 6px;
	border-left: 5px solid #62126b;
	font-size: 125%;
	font-weight: bold;
}

#info_main h2 {
	margin-top: 18px;
	margin-left: 1.0em;
	text-indent: -1.0em;
	font-size: 100%;
	font-weight: bold;
	line-height: 1.3;
}

#info_main p {
	margin-top: 1em;
	font-size: 90%;
	line-height: 1.5;
}

p.info_back {
	font-size: 80%;
	text-align: center;
}

/* ------------- キャンペーンバナー等 ----------------- */
#camp_bnr {
	padding-bottom: 6px;
	text-align: center;
}

/* ------------- Shop_link ----------------- */
#shop_link {
	width: 100%;
	border: 1px solid #e5e5e5;
}

#shop_link td {
	width: 50%;
	padding: 8px;
	vertical-align: top;
	font-size: 80%;
}

#shop_link td p {
	margin-bottom: 0;
	line-height: 1.2;
}

#shop_link td img {
	float: left;
	margin-right: 8px;
}

#shop_link td span {
	display: block;
	padding-top: 6px;
	text-align: right;
}

#shop_link td.r_line {
	border-right: 1px solid #e5e5e5;
}

/* ------------- Not_Found ----------------- */
#notfound {
	padding-top: 60px;
	padding-bottom: 60px;
	text-align: center;
}

p#notfound-txt {
	margin-top: 18px;
	line-height: 1.3;
	font-size: 24px;
	font-weight: bold;
}

/* ------------- Footer ----------------- */
#footer {
	clear: both;
}

#footer table {
	width: 100%;
}

#footer table td {
	width: 20%;
	padding: 8px;
	border-right: 1px solid #e3e3e3;
	font-size: 74%;
	vertical-align: top;
}

#footer table td#no-line {
	border-right: none;
}

#footer h3 {
	font-size: 110%;
	font-weight: bold;
	color: #333;
}

#footer li {
	margin-top: 6px;
	padding-left: 8px;
	background: url(/img/footer_dot.gif) 0 7px no-repeat;
	line-height: 1.2;
}

#footer p {
	padding: 8px 0;
	border-top: 1px solid #e3e3e3;
	font-size: 74%;
	text-align: center;
	color: #333;
}

/* ------------- Top Message ----------------- */
p.top_message {
	margin-bottom: 6px;
	padding: 6px 12px;
	border: 1px solid #ccc;
	font-size: 90%;
	font-weight: bold;
	line-height: 1.4;
}

p#conspiracy {
	margin-bottom: 6px;
	padding: 6px 12px 6px 92px;
	border: 1px solid #ccc;
	font-size: 90%;
	font-weight: bold;
	line-height: 1.4;
	background: url(/img/conspiracy.gif) 10px -10px no-repeat;
}

#top_info {
	margin-bottom: 6px;
	padding: 8px;
	border: 1px solid #ccc;
	font-size: 90%;
	line-height: 1.4;
}

#top_info p#title{
	padding-bottom: 4px;
	font-weight: bold;
	font-size: 110%;
}

