@charset "utf-8";

/* ---------------------------------------------
	cmn_style.css

	index
	1 - Base font
	2 - font style
	3 - text color
	4 - clearfix
	5 - float
	6 - preset width
	5 - preset margin
	6 - inline align
	7 - block align
	8 - tools
	9 - JavaScript Class
--------------------------------------------- */


html { overflow-y: scroll;}


/* ---------------------------------------------
	1 - Base font
--------------------------------------------- */
body {
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height: 1.8;/* ←行間指定 */
	/* 以下は魔法の指定。これも入れてね。 */
	-webkit-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	-o-text-size-adjust: 100%;
	text-size-adjust: 100%;
}

/* ie7 */
*:first-child+html body {
	font-size: 75%;
}

/* ie5 - ie6 */
* html body {
	font-size:75%;
}

.sumafont {
	-webkit-text-size-adjust: 150%;
	-moz-text-size-adjust: 150%;
	-ms-text-size-adjust: 150%;
	-o-text-size-adjust: 150%;
	text-size-adjust: 150%;
}


/* ---------------------------------------------
	2 - font style
--------------------------------------------- */

.fNormal  { font-weight: normal;}
.fBold   { font-weight: bold;}
.fItalic { font-style: italic;}

.fSSS { font-size: 70%;}
.fSS  { font-size: 78%;} /* base 12px =  8px */
.fS   { font-size: 85%;} /* base 12px = 10px */
.fM   { font-size: 100%;}
.fL   { font-size: 115%;}/* base 12px = 14px */
.fLL  { font-size: 130%;}/* base 12px = 16px */
.fLLL { font-size: 143%;}/* base 12px = 18px */
sup {
	font-size: 78%;
	vertical-align: top;
}
sub {
	font-size: 78%;
	vertical-align: baseline;
}

/* ---------------------------------------------
	3 - text color
--------------------------------------------- */
.txtColor1 { color: #007f4b;}
.txtColor2 { color: #06C;}
.txtColor3 { color: #F00}
.txtColor4 {}
.txtColor5 {}

.fRed {
	color: #cc0000;
}
.fGray {
	color: #999999;
}

a {
	color: #336699;
	text-decoration: none;
	outline: none;
}
a:hover {
	text-decoration: underline;
}


/* ---------------------------------------------
	preset margin 
--------------------------------------------- */
.mt00 { margin-top:  0   !important;}
.mt05 { margin-top:  5px !important;}
.mt10 { margin-top: 10px !important;}
.mt12 { margin-top: 12px !important;}
.mt15 { margin-top: 15px !important;}
.mt20 { margin-top: 20px !important;}
.mt25 { margin-top: 25px !important;}
.mt30 { margin-top: 30px !important;}
.mt35 { margin-top: 35px !important;}
.mt40 { margin-top: 40px !important;}
.mt45 { margin-top: 45px !important;}
.mt50 { margin-top: 50px !important;}

.mr00 { margin-right:  0   !important;}
.mr05 { margin-right:  5px !important;}
.mr10 { margin-right: 10px !important;}
.mr12 { margin-right: 12px !important;}
.mr15 { margin-right: 15px !important;}
.mr20 { margin-right: 20px !important;}
.mr25 { margin-right: 25px !important;}
.mr30 { margin-right: 30px !important;}
.mr35 { margin-right: 35px !important;}
.mr40 { margin-right: 40px !important;}
.mr45 { margin-right: 45px !important;}
.mr50 { margin-right: 50px !important;}

.mb00 { margin-bottom:  0   !important;}
.mb05 { margin-bottom:  5px !important;}
.mb10 { margin-bottom: 10px !important;}
.mb12 { margin-bottom: 12px !important;}
.mb15 { margin-bottom: 15px !important;}
.mb20 { margin-bottom: 20px !important;}
.mb25 { margin-bottom: 25px !important;}
.mb30 { margin-bottom: 30px !important;}
.mb35 { margin-bottom: 35px !important;}
.mb40 { margin-bottom: 40px !important;}
.mb45 { margin-bottom: 45px !important;}
.mb50 { margin-bottom: 50px !important;}

.ml00 { margin-left:  0   !important;}
.ml05 { margin-left:  5px !important;}
.ml10 { margin-left: 10px !important;}
.ml12 { margin-left: 12px !important;}
.ml15 { margin-left: 15px !important;}
.ml20 { margin-left: 20px !important;}
.ml25 { margin-left: 25px !important;}
.ml30 { margin-left: 30px !important;}
.ml30 { margin-left: 35px !important;}
.ml40 { margin-left: 40px !important;}
.ml45 { margin-left: 45px !important;}
.ml50 { margin-left: 50px !important;}
.ml120 { margin-left: 120px !important;}


/* ---------------------------------------------
	preset padding 
--------------------------------------------- */
.pt00 { padding-top:  0   !important;}
.pt05 { padding-top:  5px !important;}
.pt10 { padding-top: 10px !important;}
.pt12 { padding-top: 12px !important;}
.pt15 { padding-top: 15px !important;}
.pt20 { padding-top: 20px !important;}
.pt25 { padding-top: 25px !important;}
.pt30 { padding-top: 30px !important;}
.pt35 { padding-top: 35px !important;}
.pt40 { padding-top: 40px !important;}
.pt45 { padding-top: 45px !important;}
.pt50 { padding-top: 50px !important;}

.pr00 { padding-right:  0   !important;}
.pr05 { padding-right:  5px !important;}
.pr10 { padding-right: 10px !important;}
.pr12 { padding-right: 12px !important;}
.pr15 { padding-right: 15px !important;}
.pr20 { padding-right: 20px !important;}
.pr25 { padding-right: 25px !important;}
.pr30 { padding-right: 30px !important;}
.pr35 { padding-right: 35px !important;}
.pr40 { padding-right: 40px !important;}
.pr45 { padding-right: 45px !important;}
.pr50 { padding-right: 50px !important;}

.pb00 { padding-bottom:  0   !important;}
.pb05 { padding-bottom:  5px !important;}
.pb10 { padding-bottom: 10px !important;}
.pb12 { padding-bottom: 12px !important;}
.pb15 { padding-bottom: 15px !important;}
.pb20 { padding-bottom: 20px !important;}
.pb25 { padding-bottom: 25px !important;}
.pb30 { padding-bottom: 30px !important;}
.pb35 { padding-bottom: 35px !important;}
.pb40 { padding-bottom: 40px !important;}
.pb45 { padding-bottom: 45px !important;}
.pb50 { padding-bottom: 50px !important;}

.pl00 { padding-left:  0   !important;}
.pl05 { padding-left:  5px !important;}
.pl10 { padding-left: 10px !important;}
.pl12 { padding-left: 12px !important;}
.pl15 { padding-left: 15px !important;}
.pl20 { padding-left: 20px !important;}
.pl25 { padding-left: 25px !important;}
.pl30 { padding-left: 30px !important;}
.pl30 { padding-left: 35px !important;}
.pl40 { padding-left: 40px !important;}
.pl45 { padding-left: 45px !important;}
.pl50 { padding-left: 50px !important;}


/* ---------------------------------------------
	inline align
--------------------------------------------- */
.inlineL { text-align: left;}
.inlineC { text-align: center;}
.inlineR { text-align: right;}


/* ---------------------------------------------
	vertical align
--------------------------------------------- */
.vlineT { vertical-align: top    !important;}
.vlineM { vertical-align: middle !important;}
.vlineB { vertical-align: bottom !important;}


/* ---------------------------------------------
	6 - preset width
--------------------------------------------- */
.wHalf  { width: 48%;}
.wTri   { width: 33%;}
.wQuart { width: 24%;}
.wFull  { width: 99.9%;}
.wMax   { width: 100%;}

/* table */
.tw03 { width:  3% !important;}
.tw05 { width:  5% !important;}
.tw10 { width: 10% !important;}
.tw13 { width: 13% !important;}
.tw15 { width: 15% !important;}
.tw20 { width: 20% !important;}
.tw25 { width: 25% !important;}
.tw30 { width: 30% !important;}
.tw35 { width: 35% !important;}
.tw40 { width: 40% !important;}
.tw45 { width: 45% !important;}
.tw50 { width: 50% !important;}


/* ---------------------------------------------
	5 - float
--------------------------------------------- */
.fltL {
	display: inline;
	float: left;
}
.fltR {
	display: inline;
	float: right;
}
.ft {
	overflow: hidden;
	zoom: 1;
}


/* ---------------------------------------------
	imgBox 
--------------------------------------------- */
.imgBoxL,
.imgBoxR {
	display: block;
	min-height: 1%;
}
.imgBoxL:after,
.imgBoxR:after {
	clear: both;
	content:".";
	display: block;
	height: 0;
	visibility: hidden;
}
* html .imgBoxL,
* html .imgBoxR {
	height: 1%;
	/*\*//*/
	height: auto;
	overflow: hidden;
	/**/
}
	.imgBoxL .fltImg {
		display: inline;
		float: left;
		margin-right: 20px;
	}
	.imgBoxR .fltImg {
		display: inline;
		float: right;
		margin-left: 10px;
	}


/* ---------------------------------------------
	4 - clearfix
--------------------------------------------- */
.clearfix {
	display: block;
	min-height: 1%;
}
.clearfix:after {
	clear: both;
	content:".";
	display: block;
	height: 0;
	visibility: hidden;
}
* html .clearfix {
	height: 1%;
	/*\*//*/
	height: auto;
	overflow: hidden;
	/**/
}


/* ---------------------------------------------
	block align
--------------------------------------------- */
.blockC { text-align: center;}
	.blockC .block {
		margin-right: auto;
		margin-left: auto;
		text-align: left;
	}
	/* ie 6 Fix */
	* html .blockC .block {
		margin-right: 0;
		margin-left: 0;
	}
.blockR { text-align: right;}
	.blockR .block {
		margin-left: auto;
		text-align: left;
	}
	/* ie 6 Fix */
	* html .blockR .block {
		margin-left: 0;
	}


/* ---------------------------------------------
	tools
--------------------------------------------- */
.clear { 
	clear: both;
}

.block  { display: block;}
.inline { display: inline;}
.hide   { display: none;}

.nobg {
	background: none !important;
}

.underLine { text-decoration: underline;}
.noLine    { text-decoration: none;}

/* ============================================
	HEADINGS
============================================ */
h1,h2,h3,h4,h5,h6{
font-weight:500;
}

.h2_basic {
   margin-bottom:25px;
   padding:16px 10px 10px 10px;
   border-bottom:1px dotted #ddd;
   color:#004899;
   font-size:18px;
   background:#fff url("../images/bg_main_h3.gif") 0 0 repeat-x;
}

.h3_basic {
    font-size : 1.2em; 
    line-height : 1; /* 24px */
    margin-bottom : 1em;
   margin-bottom:25px;
   padding:16px 10px 10px 10px;
   border-bottom:1px dotted #ddd;
   color:#003399;
}

.h4_basic {
   margin-bottom:5px;
   padding:5px;
   font-size:14px;
   border-left:5px solid #004694;
   border-bottom:1px dotted #ddd;
}
.h4_ocean {
	color: #36C;
   margin-bottom:5px;
   padding:5px;
   font-size:14px;
   border-left:5px solid #36C;
   border-bottom:1px dotted #36C;
}
.h4_studio {
	color: #663;
   margin-bottom:5px;
   padding:5px;
   font-size:14px;
   border-left:5px solid #663;
   border-bottom:1px dotted #663;
}
.h4_mountain {
	color:#063;
   margin-bottom:5px;
   padding:5px;
   font-size:14px;
   border-left:5px solid #063;
   border-bottom:1px dotted #063;
}

.h5_basic {
   margin-top:10px;
   margin-bottom:25px;
   padding:5px;
   font-size:13px;
   background: #f0f7fc;
}

.h6_basic {
   margin-bottom:5px;
   font-size:13px;
}

.h5_winner {
   font-size:12px;
   line-height:1.4em;
}
h1 {
    font-size : 3em; /* 48px */
    line-height : 1; /* 48px */
    margin-bottom : 0.5em;
} 
 
h2 {
    font-size : 2.25em; /* 36px */
    line-height : 1.3333; /* 48px */
    margin-bottom : 0.6667em;
} 
 
h3 {
    font-size : 1.2em; 
    line-height : 1; /* 24px */
    margin-bottom : 1em;
} 
/* ============================================
	PARAGRAPHS
============================================ */
p{
   line-height:1.4em;
   margin:10px;
}


/* ============================================
	BLOCKQUOTES
============================================ */
blockquote{
	width:95%;
font-size:1.5em;
color:#888;
margin:30px auto;
padding:0 0 0 20px;
border:2px dashed #99CCFF;
}

	blockquote span{font-size:0.7em;color:#000;display:block;}
	blockquote.small{font-size:1.2em;}


/* ============================================
	LISTS
============================================ */
ul {
        margin:0 0 0 20px; padding:0 0 0 10px;
        list-style-position:outside;    /* リストマークをリストボックスの左に配置 */
}
	
ol {
        margin:0 0 0 20px; padding:0 0 0 10px;
        list-style-position:outside;    /* リストマークをリストボックスの左に配置 */
}

.ds { list-style-type: disc }        /* 黒まる */
.cc { list-style-type: circle }      /* 白まる */
.sq { list-style-type: square }      /* 四角 */
.dc { list-style-type: decimal }     /* 数字 */
.lr { list-style-type: lower-roman } /* ローマ数字小文字 */
.ur { list-style-type: upper-roman } /* ローマ数字大文字 */
.la { list-style-type: lower-alpha } /* アルファベット小文字 */
.ua { list-style-type: upper-alpha } /* アルファベット大文字 */
.nn { list-style-type: none }        /* マークなし */


.dl_basic {
        margin:0 0 0 1em;
		padding:0 0 0 0px;
}
	.dl_basic dt {
   		margin-bottom:5px;
   		margin-left:5px;
   		color:#333333;
  		 font-weight:bold;
		}

	.dl_basic dd {
   		margin:0 0 2em 2em;
		}
ul.checks{
padding:0;
margin:0 0 20px 20px;

}

	ul.checks li{
	list-style-type:none;
	margin:0;
	background:url(../img/icon-check.png) no-repeat 5px 0.5em;
	padding-left:30px;
	}

/* ============================================
	Common Parts (Table)
============================================ */
.table_basic {
	width: 98.5%;
	line-height: 1.5;
	margin:0 auto;
}
	.table_basic th,
	.table_basic td {
		border:1px solid #e2e2e2;
		padding:5px;
	}
	.table_basic th {
		background: #fafafa;
		color: #333333;
		font-weight: bold;
		text-align:center;
		vertical-align:middle;
   		background:#f0f7fc;
	}
	.table_basic td {
		background: #ffffff;
		text-align:center;
		vertical-align:middle;
	}
	.table_basic td.left {
		text-align:left;
		padding-left:1em;
	}
	.table_basic td.no {
		white-space: nowrap;
	}
	.table_basic td.odd {
		background: #f0f0f0;
		text-align:center;
	}
		.table_basic th div,
		.table_basic td div {
			padding: 5px 12px;
		}
		
	.table_basic tr.cancel01 td,
	.table_basic tr.cancel01 th {
		background: #f0f0f0!important;
		font-size: 100%;
	}
	.table_basic tr.cancel02 td,
	.table_basic tr.cancel02 th {
		background: #fff!important;
		font-size: 100%;
	}
	
	.table_basic caption{
		margin-bottom:8px;
		color:#000;
	}
	
	.table_basic tr td.odd2 {
		background: #C1D8EC;
		text-align:center;
	}
	
	.table_basic tr td.odd3 {
		background: #C8E1F8;
		text-align:center;
	}






/* ============================================
	Common Parts (Text)
============================================ */
.headCaption {
	margin: 0 0 40px 29px;
	font-size: 150%;
	color: #C00;
	font-weight: bold;
}
.txtStyle01 {
	font-size: 115%;
	color: #1279C6;
	font-weight: bold;
}
.txtStyle02 {
	font-size: 130%;
   margin-top:10px;
   margin-bottom:25px;
   padding:5px 5px 5px 0px;
   color:#1279C6;
}
.txtStyle03 {
	font-size: 130%;
   margin-top:10px;
   margin-bottom:25px;
   padding:5px 5px 5px 0px;
   color: #666633;
}
.txtStyle04 {
	font-size: 130%;
   margin-top:10px;
   margin-bottom:25px;
   padding:5px 5px 5px 0px;
   color: #006633;
}


/* ============================================
	Common Parts (Link)
============================================ */
.arrowLinkR01 a {
	background: url(/common/img/ico/ico_arrowR_02.gif) no-repeat right 0.3em;
	padding-right: 9px;
}
.bgLink01 {
	background: #243242;
	padding: 3px 10px;
	color: #ffffff;
}
	.bgLink01 a {
		background: url(/common/img/ico/ico_arrowR_03.gif) no-repeat right center;
		padding-right: 12px;
		color: #ffffff;
	}




/* ---------------------------------------------
	コーディングマーカー
--------------------------------------------- */
.atode { border: 2px solid #9966CC; padding: 10px; text-align: center; background-color: #FF99FF; font-size: 30px; color: #FFF;}


/* ---------------------------------------------
	JavaScript Class
--------------------------------------------- */
.over            {/* ロールオーバー呼び出し用 */}
.heightLine-     {/* heightLine.js呼び出し用 */}
.png             {/* DD_belatedPNG.js呼び出し用 */}
.js_window_open-width-height  {}
.js_page_print   {}
.js_window_close {}
.opacityOver {
	background: #ffffff;
}