/* CSS 変数 */
:root {
    --main-color: #009843; /* ASR12 サンプル用メインカラー */
}

/* 共通 */
html {
    scroll-behavior: smooth;
}
body {
    margin: 0;
    font-family:'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
}

.photo {
    width: 100%;
    background-color: #eeeeee;
    border-bottom: solid 1px #dddddd;
}

/* リンク画像の枠線を消す */
a img {
    border-style: none;
}

a {
    color: #1570a6;
    text-decoration: none
}

a:hover {
    color: #000000;
    text-decoration: underline
}

/* コード例 */
.code {
    border: solid 1px #999;
    font-size: 13px;
    padding: 20px;
    white-space: nowrap;
    overflow: scroll;
    max-height: 250px;
    background-color: #eff6fb; 
}

.code-title {
    font-weight: bold;
}

.code-code {
}

.code-comment {
    color: #228b22;
}

.codeBoxTab {
    padding: 0;
    margin: 0;
    overflow: hidden;
}

.codeBoxTab li {
    padding: 0;
    margin: 0;
    border-top: solid 1px #999;
    border-left: solid 1px #999;
    border-right: solid 1px #999;
    width: 60px;
    padding: 3px;
    text-align: center;
    float: left;
    cursor: pointer;
}

.codeBoxTab li.select {
    color: #fff;
    text-align: center;
    font-size: 14px;
    font-weight: bold;
    background-color: #1570a6;
    padding: 3px;
}

.hide {
    display: none;
}

.tabContents {
    padding: 0;
    margin: 0;
}

/* パンくずリスト */
.bread {
    margin-bottom: 5px;
}

.bread ol {
    margin: 0;
    padding: 0;
    list-style: none;
}

.bread li a {
    display: inline-block;
    padding: 0;
    color: #000000;
    font-size: 14px;
    text-decoration: none;
}

.bread li a:hover {
    color: #1570a6;
    text-decoration: underline
}

.bread ol:after {
    content: "";
    display: block;
    clear: both;
}

.bread li {
    float: left;
    width: auto;
}

.bread li:after {
    content: '\003e';
    margin-left: 10px;
    margin-right: 10px;
    color: #888888;
}

.product-menu {
    margin-bottom: 10px;
    font-size: 14px;
}

/* タイトル */
.title h1 a {
    color:#666;
    text-decoration: none
}

.title h1 {
    margin: 0;
    color: #888;
    font-size: 30px;
    font-weight: bold;
    vertical-align:middle;
}

/* 記事 */
.article h1 {
    margin-top: 0;
    margin-bottom: 10px;
    padding-left: 20px;
    border-left: solid 20px var(--main-color);
    font-size: 26px; /*font-size: 28px; ASR12 サンプル調整*/
    font-weight: normal;
}

.article h2 {
    margin-top: 30px;
    margin-bottom: 20px;
    border-bottom: solid 1px #1570a6;
    font-size: 20px;
    font-weight: normal;
}

.article h3 {
    margin-top: 10px;
    margin-bottom: 10px;
    font-size: 18px;
    font-weight: normal;
}

.article h4 {
    margin-top: 5px;
    margin-bottom: 5px;
    font-size: 14px;
    font-weight: normal;
}

.article h2 i {
    margin-right: 7px;
    color: #1570a6
}

.article h3 i {
    margin-right: 7px;
    color: #1570a6
}

.article h4 i {
    margin-right: 7px;
    color: #1570a6
}

.article h3 span-red {
    color: #ff0000
}

.article p {
    margin-top: 0;
    margin-bottom: 20px;
    font-size: 14px;
}

.article p.fc-red {
    color: #ff0000;
}
.article p span-red {
    color:#ff0000;
}
.article p span-b {
    font-weight: bold;
}

.article p span-url {
    word-break: break-all;
}

.article p span-blue {
    color:#0000ff;
}

.article p i {
    margin-right: 7px;
    color: #1570a6
}

.article p.right-text {
    text-align: right;
    margin-bottom: 0;
}

#center-button {
    text-align: center;
}

.article ul {
    list-style: none;
}

.article li {
    margin-top: 0;
    font-size: 14px;
}

.article li i {
    margin-right: 1em;
    color: #1570a6
}

.article-li-detail {
    margin-left: 20px;
    font-size: 14px;
    color: #000000
}

.article .lead {
    max-width: 100%;
    font-size: 14px;
    color: #666666;
}

/* 字下げ 2行目以降 1文字 */
.article .indent-multiline{
    text-indent: -1em;
    padding-left: 1em;
    font-size: 14px;
}

/* 注釈 */
.article .annotation1{
    color: #ff0000;
    text-indent: -1em;
    padding-left: 1em;
}

.article .annotation1-5{
    color: #ff0000;
    text-indent: -1.5em;
    padding-left: 1.5em;
}

.article-img {
    width: 100%;
    height: auto;
    margin-bottom: 20px;
}

/* サイドメニュー */
.sidemenu {
    border: solid 1px var(--main-color);
}

.sidemenu h2 {
    margin: 0;
    padding: 5px;
    font-size: 14px;
    font-weight: normal;
    background-color: var(--main-color);
    color: #ffffff;
    text-align: center;
}

.sidemenu i {
    margin: 0 5px;
    color: #1570a6;
}

.tree1, .tree1 ul {
    font-size: 12px;
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.tree1 {
    margin: 10px 10px 20px 10px;
}
.tree1 ul {
    padding: 0 0 0 20px;
}
.tree1 li{
    padding-top: 5px;
}

.tree2 {
    margin: 0;
    padding: 0;
    list-style: none;
}

.tree2 li a {
    display: block;
    padding: 10px;
    border-top: solid 1px var(--main-color);
    color: #000000;
    font-size: 14px;
    text-decoration: none;
}

.tree2 li a:hover {
    background-color: #eeeeee;
}

/* Copyright */
.copyright {
    margin: 0;
    color: #fff;
    font-size: 14px;
    text-align: right;
}

/* テキスト */
input[type="text"] {
    border: 0; 
    font-size: 1em; 
    font-family:'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
    border: solid 1px #999; 
    margin: 0 0 10px; 
    -webkit-border-radius: 3px; 
    -moz-border-radius: 3px; 
    border-radius: 3px; 
}
/* コンボボックス */
select {
    border: 0; 
    font-size: 1em; 
    font-family:'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
    border: solid 1px #999; 
    margin: 0 0 10px; 
    -webkit-border-radius: 3px; 
    -moz-border-radius: 3px; 
    border-radius: 3px; 
}
/* テキストエリア */
textarea {
    border: 0; 
    font-size: 1em; 
    font-family:'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
    border: solid 1px #999; 
    margin: 0 0 10px; 
    -webkit-border-radius: 3px; 
    -moz-border-radius: 3px; 
    border-radius: 3px; 
}

/* ボタン */
input[type="submit"] {
    color: #fff;
    text-align: center;
    font-size: 14px;
    font-weight: bold;
    background-color: #1570a6;
    background-image: -webkit-gradient( linear, left top, left bottom, from(#1590e6), to(#1570a6));
    border: solid 1px #999;
    border-radius: 3px;
    padding-top: 5px;
    padding-bottom: 5px;
    cursor: pointer;
    width: 250px;
}
input[type="button"] {
    color: #fff;
    text-align: center;
    font-size: 14px;
    font-weight: bold;
    background-color: #1570a6;
    background-image: -webkit-gradient( linear, left top, left bottom, from(#1590e6), to(#1570a6));
    border: solid 1px #999;
    border-radius: 3px;
    padding-top: 5px;
    padding-bottom: 5px;
    cursor: pointer;
    width: 250px;
}
input[type="reset"] {
    color: #fff;
    text-align: center;
    font-size: 14px;
    font-weight: bold;
    background-color: #1570a6;
    background-image: -webkit-gradient( linear, left top, left bottom, from(#1590e6), to(#1570a6));
    border: solid 1px #999;
    border-radius: 3px;
    padding-top: 5px;
    padding-bottom: 5px;
}

/* ページトップ */
.pagetop {
	display: none;
	position: fixed;
	bottom: 30px;
	right: 0px;
}

.pagetop a {
	display: block;
	width: 40px;
	height: 40px;
	background-color: var(--main-color);
    border-radius: 40px;
	text-align: center;
	color: #fff;
	font-size: 20px;
	text-decoration: none;
	line-height: 40px;
}

/* header */
.header {
    border-bottom: solid 1px #dddddd;
}

/* footer */
.footer {
    padding-top: 5px;
    padding-bottom: 5px;
    background-color: var(--main-color);
}

.footer-inner p {
    margin: 5px 0 5px 5px;
    padding: 0;
}

/* ボックスの左右 */
.header, .header-nav, .info, .footer, .product1, .product2, .column-contents, .single-contents, .contents-header {
    padding-left: 15px;
    padding-right: 15px;
}

/* ボックスの上下 */
.header {
    padding-top: 20px;
    padding-bottom: 10px;
}

.column-contents {
    padding-top: 25px;
    padding-bottom: 25px;
}

.single-contents {
    padding-top: 25px;
    padding-bottom: 25px;
}

.contents-header img {
    width: 100%;
    height: auto;
}

.product-image-right {
    padding-bottom: 20px;
}

/* タイル型テーブル */
table.tile {
    width: 100%;
    font-size: 14px;
    margin: 0 auto;
    padding-bottom: 20px;
    border-collapse: separate;
    border-spacing: 1px;
    word-break: break-all;
}

table.tile th {
    padding: 10px;
    vertical-align: middle;
    text-align: left;
    border-bottom: #999 1px solid;
    color: #fff;
}

table.tile th a {
    color: #fff;
}

table.tile th a:hover {
    color: #000080;
}

table.tile td {
    padding: 10px;
    vertical-align: middle;
    text-align: left;
    border-bottom: #999 1px solid;
    font-size: 14px;
}
table.tile td span-red {
    color:#ff0000;
}

table.tile th.r1 {
    border-left: #999 1px solid;
    border-right: #999 1px solid;
    background: #1570a6;
}

table.tile th.rc1 {
    border-left: #999 1px solid;
    border-right: #999 1px solid;
    background: #1570a6;
    text-align: center;
}

table.tile th.r2 {
    border-right: #999 1px solid;
    background: #1570a6;
}
table.tile th.rc2 {
    border-right: #999 1px solid;
    background: #1570a6;
    text-align: center;
}

table.tile td.r1 {
    border-left: #999 1px solid;
    border-right: #999 1px solid;
    background: #ffffff;
}
table.tile td.rc1 {
    border-left: #999 1px solid;
    border-right: #999 1px solid;
    background: #ffffff;
    text-align: center;
}

table.tile td.rt1 {
    border-top: #999 1px solid;
    border-left: #999 1px solid;
    border-right: #999 1px solid;
    background: #ffffff;
}
table.tile td.rtc1 {
    border-top: #999 1px solid;
    border-left: #999 1px solid;
    border-right: #999 1px solid;
    background: #ffffff;
    text-align: center;
}

table.tile td.r2 {
    border-right: #999 1px solid;
    background: #ffffff;
}

table.tile td.rc2 {
    border-right: #999 1px solid;
    background: #ffffff;
    text-align: center;
}

table.tile td.rt2 {
    border-top: #999 1px solid;
    border-right: #999 1px solid;
    background: #ffffff;
}

table.tile td.rtc2 {
    border-top: #999 1px solid;
    border-right: #999 1px solid;
    background: #ffffff;
    text-align: center;
}

/* range-left, range-right を並べる */
.rangebox:after {
    content: "";
    display: block;
    clear: both;
}

.range-left {
    float: left;
    width: 50%;
}

.range-right {
    float: right;
    width: 48%;
}

/* range-left, range-right を並べる */
.rangebox46:after {
    content: "";
    display: block;
    clear: both;
}

.range46-left {
    float: left;
    width: 40%;
}

.range46-right {
    float: right;
    width: 58%;
}

/* ########## 359px 以下 ########## */
@media (max-width: 359px) {
    .title img {
        width: 100%;
        height: auto;
    }

    .range-left {
        float: none;
    }

    .range-right {
        float: none;
    }

    .range46-left {
        float: none;
        width: 100%;
    }

    .range46-right {
        float: none;
    }
}

/* ########## 599px 以下 ########## */
@media (max-width: 599px) {
    .title img {
        width: 100%;
        height: auto;
    }
    /* ナビゲーション */
    .menu li a {
        padding: 10px 7px;
        font-size: 11px;
    }
    /* キャッチコピー */
    .catch {
        padding: 5px 10px;
        font-size: 12px;
    }
    /* 記事 */
    .article h1 {
        font-size: 26px;
    }
    .article h2 {
        font-size: 20px;
    }
    .article .lead {
        font-size: 14px;
    }
    /* 記事の ul */
	.article ul {
	    list-style: none;
	}
    /* 記事のチェックリストのインデント */
	.article li.check-square {
	    margin-top: 0;
	    margin-left: -10px;
	    text-indent: -1em;
	    padding-left: 1em;
	}
}

/* ########## 767px 以下 ########## */
@media (max-width: 767px) {
    /* プロダクトメニュー */
    .product-menu ul {
        margin-top: 0;
        margin-bottom: 0;
        padding-left: 0;
        list-style: none;
    }

    .product-menu li a {
        display: block;
        padding: 0;
        color: #1570a6;
        font-size: 14px;
        text-decoration: none;
    }

    .product-menu li a:hover {
        color: #000000;
        text-decoration: underline;
    }

    /* フッターメニュー */
    .footer-menu ul {
        margin: 0;
        padding: 0;
        list-style: none;
    }

    .footer-menu li a {
        display: block;
        padding: 5px;
        color: #ffffff;
        font-size: 14px;
        text-decoration: none;
    }

    .footer-menu li a:hover {
        color: #000080;
    }

    /* ファイル作成（新規作成）用ボックス */
    .rangeboxA-1 {
        text-align: center;
    }
}

/* ########## 768px 以上 ########## */
@media (min-width: 768px) {
	/* プロダクトメニュー */
	.product-menu ul {
	    margin: 0;
	    padding: 0;
	    list-style: none;
	    text-align: right;
	}

	.product-menu li a {
	    /*display: inline-block;*/
	    padding: 0 10px 0 10px;
	    color: #1570a6;
	    font-size: 14px;
	    text-decoration: none;
	}

	.product-menu li a:hover {
	    color: #000000;
	    text-decoration: underline;
	}
	.product-menu li {
	    display: inline-block;
	    text-align: right;
	}

	.product-menu li+ li {
		border-left: 1px solid #999;
	}

    /* フッターメニュー*/
    .footer-menu ul {
        margin: 0;
        padding: 0;
        list-style: none;
    }

    .footer-menu li a {
        display: block;
        padding-right: 10px;
        color: #ffffff;
        font-size: 14px;
        text-decoration: none;
    }

    .footer-menu li a:hover {
        color: #000080;
    }

    .footer-menu ul:after {
        content: "";
        display: block;
        clear: both;
    }

    .footer-menu li {
        float: left;
        text-align: center;
    }
    /* column-contents-1, column-contents-2 を並べる */
    .column-contents:after {
        content: "";
        display: block;
        clear: both;
    }
    /* サイドメニューとメインコンテンツの割合はここで調整する */
    .column-contents-1 {
        float: right;
        width: 75%;
        padding-left: 50px;
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
    }

    .column-contents-2 {
        float: left;
        width: 25%;
    }

    /* 記事のチェックリストのインデント */
	.article li.check-square {
	    margin-top: 0;
	    text-indent: -1em;
	    padding-left: 1em;
	}

    .single-contents {
        width: 720px;
        margin-left: auto;
        margin-right: auto;
    }

    /* ファイル作成（新規作成）用ボックス */
    .rangeboxA:after {
        content: "";
        display: block;
        clear: both;
    }

    .rangeboxA-1 {
        float: left;
        width: 40%;
        text-align: left;
    }

    .rangeboxB {
        float: right;
        width: 58%;
        text-align: left;
    }
}


/* 1100px 以上 */
@media (min-width: 1100px) {
    /* 全体の幅を固定 */
    .info, .slider, .header-inner, .header-nav-inner, .footer-inner, .product1, .product2, .column-contents, .contents-header/*, .single-contents*/    {
        width: 1100px;
        margin-left: auto;
        margin-right: auto;
    }
}
