﻿@charset "utf-8";
html{font-size: 0.65em;-webkit-text-size-adjust: 100%;}
* {-webkit-touch-callout: none;-webkit-user-select: none;}
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {border: 0;font-family: inherit;font-style: inherit;font-weight: inherit;margin: 0;outline: 0;padding: 0;vertical-align: baseline;}
:focus {outline: 0;}
ol, ul {list-style: none;}
li {list-style-type: none;}
#contents li a{ display: block; }
table {border-collapse: separate;border-spacing: 0;}
caption, th, td {font-weight: normal;text-align: left;}
blockquote:before, blockquote:after,q:before, q:after {content: "";}
blockquote, q {quotes: "" "";}
img {border: 0;display:block;margin:1px auto;max-width: 100%;height: auto;}
a img:hover , span img:hover{
	opacity:0.7;
	-webkit-transition: 0.7s;
	-moz-transition: 0.7s;
	-o-transition: 0.7s;
	-ms-transition: 0.7s;
	transition: 0.7s;
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {display: block;}
.over:hover; {opacity:0.7;}

body {
	color: #444;
	font-family: 
	"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", 
	"メイリオ","ＭＳ Ｐゴシック", sans-serif;
	line-height: 1.5;
	margin: 0 auto;
	padding: 0 auto;
	vertical-align: baseline;
	-webkit-overflow-scrolling:touch;
	border: 0;
	background: transparent;
}

.webfont{font-family: 'Josefin Sans', sans-serif;}

body {background:#FFF url(images/bg_base.png) repeat 50% 50%;}

#main a{text-decoration:underline; color:#0044CC;}
#main a:hover{text-decoration: none; color:#0044CC;}
#main a:visited{text-decoration: underline; color: #503160; }

#sub a{text-decoration: none; color:#0044CC;}
#sub a:hover{text-decoration: underline; color:#0044CC;}
#sub a:visited{text-decoration: none; color: #503160;}

#sub .dic {
	text-decoration: none;
	color:#0044CC;
	cursor: pointer;
}
#sub .dic:hover{
	text-decoration: underline;
	color:#0044CC;
}
#main .dic {
	text-decoration: underline;
	color:#0044CC;
	cursor: pointer;
}
#main .dic:hover{
	text-decoration: none;
	color:#0044CC;
}

.center{
	text-align:center;
	margin: 0px auto;
}

.clear{clear:both;margin: 0 auto 50px auto;}

.imgR {
	float: none;
	margin: 5px;
	padding:5px;
}

.imgL {
	float: none;
	margin: 5px;
	padding:5px;
}

.top{
	width:100%;
	position:fixed;
	bottom:-40px;
	left:0px;
	-webkit-transition: 0.2s;
	-moz-transition: 0.2s;
	-o-transition: 0.2s;
	-ms-transition: 0.2s;
	transition: 0.2s;
	background:rgba(255,255,255,0.6);
}

.top:hover{
	position:fixed;
	bottom:-25px;
	left:0px;
}

/* clearfix */
.clearfix:after {content: "."; display: block; visibility: hidden; height: 0.1px; font-size: 0.1em; line-height: 0; clear: both;}
/* Hides from IE-mac \*/
* html .clearfix {height: 1%;}
.clearfix {display: block;}
/* End hide from IE-mac */

footer {
	clear: both;
	color: #333;
	margin: 30px auto 0px auto;
}

footer .copyright {
	font-size:15px;
	font-size:1.5rem;
	color: #666;
	text-align: center;
	padding: 25px;
	font-family: 'Josefin Sans', sans-serif;
}

.mainimage{margin:0px auto 25px auto;}

#contents {
	margin: 25px auto 0px auto;
	text-align: left;
}

#main {
	width: 98%;
	padding:1%;
	margin: 0px auto;
	overflow:hidden;
}

#main p{
	font-size:20px;
	font-size:2.0rem;
	padding: 10px 10px 10px 10px;
	margin:0px 0px 50px 0px;
}

#main h1{
	font-size: 24px;
	font-size:2.4rem;
	background: url(images/h1.png) repeat-x 50% 100%;
	padding: 15px 0px 15px 0px;
	margin: 0px 0px 30px 0px;
	text-shadow: 1px 1px 1px #eee;
	font-weight: bold;
	letter-spacing:2.5px;
	text-align: center;
}

#main h2{
	font-size: 22px;
	font-size:2.2rem;
	background: url(images/h1.png) no-repeat 50% 100%;
	padding: 15px 0px 15px 0px;
	margin: 0px 0px 30px 0px;
	text-shadow: 1px 1px 1px #eee;
	font-weight: bold;
	letter-spacing:2.5px;
	text-align: center;
}

#main h3{
	font-size: 22px;
	font-size:2.2rem;
	border-bottom: dashed 2px #BBB;
	padding: 15px 0px 15px 0px;
	margin: 0px 0px 30px 0px;
	text-shadow: 1px 1px 1px #eee;
	font-weight: bold;
	letter-spacing:2.5px;
	text-align: center;
}

#main h3 span{
	display:block;
	font-weight: 100;
	font-family: 
	"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", 
	"メイリオ","ＭＳ Ｐゴシック", sans-serif;
	color:#544D4E;
}

#main h4{
	font-size: 22px;
	font-size:2.2rem;
	color:#555;
	padding: 15px 0px 15px 0px;
	margin: 0px 0px 30px 0px;
	text-shadow: 1px 1px 1px #eee;
	font-weight: 100;
	letter-spacing:2.5px;
}

.bg{
	padding:10px;
	margin:0px 0px 75px 0px;
	background:rgba(0,68,204,0.2);
	border-radius: 6px;
}

.bg_box{
	padding:10px;
	margin:0px 0px 75px 0px;
	border: dashed 2px #0044CC;
	border-radius: 6px;
}

#main ul{
	padding:10px;
	margin:0px 0px 50px 0px;
}

#main ul li{
	border-bottom: dashed 2px #CCC;
	padding:12px 0px 7px 5px;
	margin:0px 0px 10px 0px;
	font-size:20px;
	font-size:2.0rem;
	color:#555;
}

.button a, .button span{display:block;}

article{
	margin: 0 0 75px 0;
	padding: 1%;
	background:rgba(255,255,255,0.5);
	border-radius: 6px;
	overflow:hidden;
}

section{
	margin: 0 0 75px 0;
	padding: 1%;
	background:rgba(255,255,255,0.5);
	border-radius: 6px;
	overflow:hidden;
}

#sub {
	width: 98%;
	padding:1%;
	margin: 0 auto;
}

#sub h3{
	font-size:20px;
	font-size:2.0rem;
	font-weight: 100;
	text-align:left;
	padding: 15px 0px 15px 0px;
	color:#444;
	letter-spacing:1px;
	padding:10px;
	margin: 0px 0px 0px 0px;
	border-top-left-radius: 6px; 
	border-top-right-radius: 6px;
	-webkit-border-top-left-radius: 6px;
	-webkit-border-top-right-radius: 6px;
	-moz-border-radius-topleft: 6px;
	-moz-border-radius-topright: 6px;
}

.bottom{border-bottom: dashed 2px #BBB;}

#sub ul {
	margin: 0 0 50px 0;
	padding: 20px 5px 5px 5px;
}

#sub ul li span{display:block;}
#sub ul li span:hover{text-decoration: underline;}

#sub ul li {
	font-size:18px;
	font-size:1.8rem;
	position: relative;
	display: block;
	padding: 12px 0px 12px 50px;
	border-bottom: 1px dashed #AAA;
	text-decoration: none;
	color:#0044CC;
}

#fontSize{
	margin:0px 0px 0px 0px;
	color:#0044CC;
	cursor: pointer;
}

#fontSizeTop{
	margin:0px 0px 0px 0px;
	color:#0044CC;
	cursor: pointer;
}

.icon{background: url(images/icon.png) no-repeat 0% 50%;}

#sub .small{background: url(images/icon.png) no-repeat 0% 50%;}
#sub .middle{background: url(images/icon.png) no-repeat 0% 50%;}
#sub .large{background: url(images/icon.png) no-repeat 0% 50%;}

.icon_ranking1{background: url(images/icon_ranking1.png) no-repeat 0% 50%;}
.icon_ranking2{background: url(images/icon_ranking2.png) no-repeat 0% 50%;}
.icon_ranking3{background: url(images/icon_ranking3.png) no-repeat 0% 50%;}
.menu{background:#FFF;box-shadow: 0px 0px 1px #CCC;}

#sub .menu_sub, #sub .menu_yubi{background:rgba(0,68,204,0.8);color:#FFF;}

.clear{clear:both;}

.midashi {
	font-size: 24px;
	font-size: 2.4rem;
	font-weight: bold;
	margin:0px auto 0px auto;
	padding:5px 15px 5px 15px;
	color:#444;
	text-shadow: 1px 1px 1px #CCC;
	font-family: 'Josefin Sans', sans-serif;
	text-align:center;
}

.comment{
	font-size: 14px;
	font-size: 1.4rem;
	font-weight: 100;
	margin:0px auto 0px auto;
	padding:0px 15px 15px 15px;
	color:#666;
	text-align:center;
}

.main-nav {
	display: block;
	margin-bottom:15px;
}

nav ol {display: none;visibility:hidden;}

.main-nav li a, .main-nav li span{
	color:#555;
	font-size:16px;
	font-size:1.6rem;
	margin:0px 5px 0px 5px;
	display: block;
	padding: 10px;
	text-decoration: none;
	cursor: pointer;
	text-align:center;
}

.main-nav li a:hover, .main-nav li span:hover{opacity:0.6;}
.main-nav li:first-child{padding:0px 0px 0px 5px;}

.img_flex{
	display: block;
	margin:15px 0px;
}

.flex{
	display: block;
	margin:50px auto;
}

.flex div{
	margin:5px;
	padding:15px;
	border-radius: 6px;
	background:rgba(255,255,255,0.7);
}

.more {
	font-size: 20px;
	font-size: 2.0rem;
	position: relative;
	display: block;
	padding: 15px 25px;
	background:rgba(0,68,204,0.8);
	text-align: center;
	text-decoration: none;
	border-radius: 10px;
	margin:25px auto;
}
#main .more a, #main .more span, #main .more a:hover, #main .more span:hover {color: #FFF;display: block;}
.more::after {
	position: absolute;
	top: 50%;
	right: .2em;
	content: '';
	margin-top: -5px;
	border: 7px solid transparent;
	border-top-width: 5px;
	border-bottom-width: 5px;
	border-left-color: #FFF;
	transition: all .2s;
}
.more:hover::after {
	right: -.05em;
}

#container{cursor: pointer;}

.em{
	font-size: 20px;
	font-size: 2.0rem;
	background: linear-gradient(transparent 40%, #ffffcc 40%);
}

.red{color:red;}

.accordion input {display: none;}
.accordion label {
	margin: 15px;
	position: relative;
	text-align:center;
	display: block;
	padding:5px 0px 5px 0px;
	cursor: pointer;
}
.accordion div {
	background: rgba(255,255,255,0.9);
	position: relative;
	height: 0;
	overflow: hidden;
	transition: height .2s ease-in-out;
}
.accordion input:checked ~ div {
	height: 850px;
	background: rgba(255,255,255,0.9);
}

.check{
	font-size: 20px;
	font-size:2.0rem;
	color:#444;
	text-shadow: 1px 1px 1px #CCC;
	padding: 7px 0px 7px 0px;
	margin: 50px auto 50px auto;
	font-weight: 100;
	background:none;
}