@charset "UTF-8";
/*--------------------------------------

 初期化

--------------------------------------*/
/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:16px;
    vertical-align:baseline;
    background:transparent;
}
/*フォントサイズと行の高さを同じに*/
body {
    line-height:1;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
    display:block;
}
a {
    margin:0;
    padding:0;
    vertical-align:baseline;
    background:transparent;
}
mark {
    background-color:#ff9;
    color:#000; 
    font-style:italic;
    font-weight:bold;
}
table {
    border-collapse:collapse;
    border-spacing:0;
}
input, select {
    vertical-align:middle;
}
/* chtml5doctorから変更
--------------------------------------*/
ol li, ul li{
    list-style-type: none;
}
hr {
    display:block;
    height:1px;
    border:0;   
    border-top:1px dotted #cccccc;
    margin:1em 0;
    padding:0;
}

/* clerfix */
.clear:after {
  content: "";
  clear: both;
  display: block;
}

/*--------------------------------------

 共通のスタイル

--------------------------------------*/
body {
    margin: 0px;
    padding: 0px;
    min-width:100%;
    color: #333;
    -webkit-text-size-adjust: 100%;
    line-height: 1.5em;
	font-family: "Lucida Grande", "segoe UI", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Verdana, Arial, sans-serif;
	position: relative;
}


/* 全体のレイアウト
--------------------------------------*/
div#header{
    margin: 0 auto;
	padding: 0;
    width: 100%;
}
div#wrapper {
    margin: 2rem auto 0; 
    width: 100%;
}
div#content{
    width: 100％;
}
div#sidenavi{
    width: 210px;
    float: right;   
}
div#footer{
    width: 100%;
    background-color: #999DA0;
}


/* ヘッダ
--------------------------------------*/
header{
    line-height: 0;
    font-size: 0; 
}
div#header{
}
div#header p.logo{
    margin: 0 0 20px;
    padding: 10px 0 0 10px;
    width: 20%;
}
/* サイドナビ
--------------------------------------*/

/* フッター
--------------------------------------*/
address{
    padding: 20px 0;
    width: 100％;
    text-align: center;
    font-size: 10px;
    color: #fff;
    font-style: normal;
}


/* 見出し関連
--------------------------------------*/
.title{
    box-sizing: border-box;
    margin: 0 auto 1.5rem;
    padding: 20px 10px;
    width: 100%;
    line-height: 1.3em;
    font-size: 18px;
    font-weight: bold;
    letter-spacing: 0.3em;
    color: #333;
    border-top: 2px solid #CCCED0;
    border-bottom: 2px solid #0081E9;
    -webkit-box-shadow:  0 4px 0 0 #F7F7F8;   
    -moz-box-shadow:  0 4px 0 0 #F7F7F8;    
     box-shadow: 0 4px 0 0 #F7F7F8; 
}
.subheading-01 {
    margin: 0 0 1.5rem 0;
	padding: 15px 15px 15px 30px;
    line-height: 1.3em;
    font-size: 16px;
    font-weight: normal;
    border-top: 1px solid #CCCED0;
    border-bottom: 1px solid #CCCED0;
    background-color: #F7F7F8;
}
.subheading-01:before{
    content:'';
    left: 15px;
    width: 4px;
    height: 1.3rem;
	position:absolute; 
    background: #0081E9 repeat-y left top;   
}
.subheading-02 {
    margin: 0 10px 1.5em;
	padding: 0 0 15px 25px;
    line-height: 1.3em;
    font-size: 130%;
    font-weight: normal;
    border-bottom: 3px double #d6d8d8;
    position: relative;
}
.subheading-02:before{
    content:'';
    left: 1px;
    width: 4px;
    height: 24px;
	position:absolute; 
    background: transparent url(../img/bg_subheading-02.gif) repeat-y left top;   
}
.subheading-03 {
    margin: 0 10px 1.5em;
	padding: 15px 0 15px 25px;
    line-height: 1.3em;
    font-size: 130%;
    color: #0091d4;
    border-bottom: 1px dotted #d6d8d8;
}

/* ページの先頭にもどる
--------------------------------------*/
p#page-top {
    bottom: 10px;
    position: fixed;
    right: 20px;
    z-index: 100;
}
div#page-back{
    margin: 3rem 0 0;
    padding: 1rem 0;
    width: 100%;
    background: #E6E5E5 repeat-y left top;  
}
div#page-back div.box-01{
    width: 50%;
    text-align: left;
}
div#page-back div.box-02{
    width: 50%;
    text-align: right;
}


/* →付きリンク
--------------------------------------*/
a {
    color: #333;
}
a:hover {
	color: #333;
    text-decoration: none;
}
a.more-01-01 {
/* display: block;なし */
    padding-left: 25px;
    background: transparent url(../img/arrow_01.png) no-repeat left center;
}
a.more-01-01:hover {
	color: #0081E9
    text-decoration: none;
    background: #E5F2FE url(../img/arrow_01.png) no-repeat left center;
}
a.more-01-02 {
/* display: block;あり */
    padding-left: 25px;
    display: block;
	background: transparent url(../img/arrow_01.png) no-repeat left center;
}
a.more-01-02:hover {
	color: #0081E9;
    text-decoration: none;
    background: #E5F2FE url(../img/arrow_01.png) no-repeat left center;
}
a.more-02-01 {
/* display: block;なし */
    padding-left: 25px;
    background: transparent url(../img/arrow_02.png) no-repeat left center;
}
a.more-02-01:hover {
	color: #0081E9
    text-decoration: none;
    background: #E5F2FE url(../img/arrow_02.png) no-repeat left center;
}
a.more-02-02 {
/* display: block;あり */
    padding-left: 25px;
    display: block;
	background: transparent url(../img/arrow_02.png) no-repeat left center;
}
a.more-02-02:hover {
	color: #0081E9;
    text-decoration: none;
    background: #E5F2FE url(../img/arrow_02.png) no-repeat left center;
}


/* 枠線
--------------------------------------*/
.frame-01 {
	margin: 0 auto;
    padding: 20px 20px 20px 25px;
	border: 1px double #D6D8D8;
    border-radius: 4px;
	background-color: #fff;
	-webkit-box-shadow:  0 0 0 4px #F1F2F2;   
    -moz-box-shadow:  0 0 0 4px #F1F2F2;    
     box-shadow: 0 0 0 4px #F1F2F2;   
    overflow: visible;/*IE8以下 */
	:root overflow: auto;/*それ以外 */
}

/* 注釈関連
--------------------------------------*/
.note-01 li,
.normal .note-01 li,/*入れ子対応*/
.note-02 .note-01 li{/*　文字ひとつ分の何か（※や①など）のとき　*/
    text-indent: -1.2rem;
    padding-left: 1.2rem;
    list-style-type: none;
}
.note-01 span,
.normal .note-01 span,/*入れ子対応*/
.note-02 ul.note-01 span/*入れ子対応*/{
    float: left;
    margin-right: 3px;
	display: block;
	width: 1rem;  
}
.note-02 li,
.normal .note-02 li/*入れ子対応*/{/*　複数文字分の数字にあたるもの（(1)、など）のとき　*/
    text-indent: -2.2rem;
    padding-left: 2.2rem;
    list-style-type: none;
}
.note-02 span,
.normal .note-02 span/*入れ子対応*/{
    float: left;
    margin-right: 3px;
	display: block;
	width: 2rem;
}
.note-03 li,
.normal .note-03 li/*入れ子対応*/{/*　複数文字分の数字にあたるもの（(※1　注1)、など）のとき */
    text-indent: -3.7em;
    padding-left: 3.7em;
    list-style-type: none;
}
.note-03 span,
.normal .note-03 span/*入れ子対応*/{
    float: left;
    margin-right: 3px;
	display: block;
	width: 3.5em;  
}
dl.note-04 dd{/*dlで（1）を使う場合*/
    padding-left: 2.5em;
    padding-bottom: 1.5em;
}
/* 以下上記以外の入れ子になった場合の対応*/
.note-01 ul.normal li,
.note-02 ul.normal li{
    text-indent: 0;
    padding-left: 0;
}
.note-02 .normal .note-01 li{
    text-indent: -1.7em;
    padding-left: 1.7em;
}
.note-02 .normal .note-01 span{
	width: 1.5em;  
}
.note-01 .normal .note-02 li{
    text-indent: -2.7em;
    padding-left: 2.7em;
}
.note-01 .normal .note-02 span{
    float: left;
    margin-right: 3px;
	display: block;
	width: 2.5em;  
}
.note-01 .normal .note-01 li{
    text-indent: -1.7em;
    padding-left: 1.7em;
}
.note-01 .normal .note-01 span{
	width: 1.5em;  
}
.note-02 .normal .note-02 li{
    text-indent: -2.7em;
    padding-left: 2.7em;
}
.note-02 .normal .note-02 span{
    float: left;
    margin-right: 3px;
	display: block;
	width: 2.5em;  
}

/* 文字位置
--------------------------------------*/
.align-01 {
    text-align: right;
}
.align-02 {
    text-align: center;
}
.align-03 {
    text-align: left;
}
.v_align-01 {
    vertical-align: top;
}
.v_align-02 {
    vertical-align: baseline;
}

/* テキスト装飾
--------------------------------------*/
.text-deco-bold {
    font-weight: bold;
}

.text-deco-normal {
    font-weight: normal;
}

.text-deco-uline {
    text-decoration: underline;
}
.text-deco-uline-dot {
	border-bottom: 1px dotted #333;
}
.text-deco-red {
    color: #d6d8d8;
}
.text-small {
    font-size: 90%;
}
.text-smaller {
    font-size: 85%;
    font-weight: normal;
}
.text-big {
    font-size: 130%;
}
.text-bigger {
    font-size: 150%;
}
.text-box {
    display: block;
}

/* 画像関係
--------------------------------------*/
img.photo-01 {
    padding: 5px;
    border: 1px solid #ececec;
    background-color: #fff;
}
img.photo-02 {
    padding: 1px;
    border: 1px solid #ececec;
    background-color: #fff;
}
img.photo-03 {
    border: 1px solid #ececec;
}
img.photo_right {
    margin-right: 20px;
    margin-bottom: 30px;
    margin-left: 30px;
}
img.photo_left {
	margin-right: 30px;
	margin-bottom: 30px;
    margin-left: 20px;
}
img.text {
	padding: 0 5px;
    vertical-align: middle;
}
figure figcaption{
    text-align: center;
}
figure.right{
    float: right;
}
figure.left{
    float: left;
}

/* p,ul,ol 基本設定
--------------------------------------*/
div#content p,
div#content ul,
div#content ol,
div#content dl{
    /* 左側10pxに入れて下に2em */
    margin: 0 10px 2rem 10px;
}
div#content ul li,
div#content ol li{
    margin-bottom: 1.5rem;
}
div#content ul.bottom-reset li,
div#content ol.bottom-reset li{
    margin-bottom: 0;
}
ul.normal li{
    list-style-type: disc;
}
ol.normal li{
    list-style-type: decimal;
}
ul.reset li,
ol.reset li{
    list-style-type: none;
}
ul.reset li ul.normal li,
ol.reset li ul.normal li{
    list-style-type: disc;
}
ul.inline li,
ol.inline li{
    padding-right: 30px;
    float: left;
    list-style-position: outside;
}
div#content .reset{
    margin: 0;
}
div#content .top-reset{
    margin-top: 0;
}
div#content .bottom-reset{
    margin-bottom: 0;
}
div#content .rightleft-reset{
    margin-right: 0;
    margin-left: 0;
}
div#content .indent-reset{
    text-indent: 0;
}
div#content .topbottom-space{
    margin-top: 1.5rem;
    margin-bottom: 1.5rem; 
}
div#content .bottom-space-01{
    margin-bottom: 1.5rem;
}
div#content .bottom-space-02{
    margin-bottom: 2rem;
}
div#content .top-space-01{
    margin-top: 1.5rem;
}
div#content .top-space-02{
    margin-top: 2rem;
}


/* p,ul,ol,dl 共通
--------------------------------------*/
div#content .pt-01 {
/* 左右10px */
    margin-right: 10px;
    margin-left: 10px;
}
div#content .pt-02 {
/* 左40px右10px */
    margin-right: 10px;
    margin-left: 40px;
}
div#content .pt-03 {
/* 左50px右10px */
    margin-right: 10px;
    margin-left: 50px;
}
div#content .pt-04 {
/* 左60px右10px */
    margin-right: 10px;
    margin-left: 50px;
}
div#content .pt-05 {
/* 左30px右30px */
    margin-right: 30px;
    margin-left: 30px;
}
div#content .pt-06 {
/* 左90px右10px */
    margin-right: 10px;
    margin-left: 90px;
}

/* ボックス横並び display: table　関連
--------------------------------------*/
.box-wrap {
    margin: 0 auto 1.5em;
	display: table;
}
.box-01 {
	padding-right:24px;
	display: table-cell;
}
.box-02 {
	display: table-cell;
    text-align: left;
    vertical-align: top;
}


/* 横幅
--------------------------------------*/
.size-05{
	width: 5%;
}
.size-08{
	width: 5%;
}
.size-10{
	width: 10%;
}
.size-13{
	width: 13%;
}
.size-15{
	width: 15%;
}
.size-20{
	width: 20%;
}
.size-22{
	width: 22%;
}
.size-25{
	width: 25%;
}
.size-28{
	width: 25%;
}
.size-30{
	width: 30%;
}
.size-33{
	width: 33.333%;
}
.size-35{
	width: 35%;
}
.size-40{
	width: 40%;
}
.size-45{
	width: 40%;
}
.size-50{
	width: 50%;
}
.size-55{
	width: 50%;
}
.size-60{
	width: 60%;
}
.size-70{
	width: 70%;
}
.size-80{
	width: 80%;
}
.size-85{
	width: 85%;
}
.size-90{
	width: 90%;
}
.size-93{
	width: 93%;
}
.size-95{
	width: 95%;
}
.size-97{
	width: 97%;
}
.size-100{
	width: 100%;
}

/* 改行なし
--------------------------------------*/
.no-wrap{
	white-space: nowrap;
}


/*--------------------------------------

 ページ別設定

--------------------------------------*/

/* トップページ
--------------------------------------*/
body#top h1.title{
    margin-bottom: 0;
}
body#top div#wrapper {
    margin: 0 auto; 
    width: 100%;
}
div#content ol.link-list{
    margin: 1rem 0;
}
div#content ol.link-list li{
    box-sizing: border-box;
    margin:0 0 1rem;
    padding: 1rem;
    width: 100%;
    background: transparent url(../img/arrow_01.png) no-repeat right center;
    background-position: right 10px center;
    border-top: 1px solid #CCCED0;
    border-bottom: 1px solid #CCCED0;
    -webkit-box-shadow:  0 4px 0 0 #F7F7F8;   
    -moz-box-shadow:  0 4px 0 0 #F7F7F8;    
     box-shadow: 0 4px 0 0 #F7F7F8; 
}
div#content ol.link-list li a{
    display: block;
    text-decoration: none;
}
