@charset "UTF-8";
@import url("html5reset-1.6.1.css");
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Source+Serif+Pro&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville&display=swap');

/*--------------------テンプレート情報--------------------*/
/*template　Maison de R*/
/*url　https://maisonder.web.fc2.com/*/
/*title　MERCURY*/
/*code　CSS3*/

/*--------------------ライセンス--------------------*/

/*HTML5 Reset Stylesheet
html5doctor.com Reset Stylesheet v1.6.1
License : CC0 Public Domain Dedication, MIT L
icense
Author : Richard Clark
http://html5doctor.com/html-5-reset-stylesheet/
https://creativecommons.org/publicdomain/zero/1.0/
https://opensource.org/licenses/MIT
*/

/*
jQuery v3.6.1
License : MIT License
https://jquery.com/
https://jquery.org/license/
https://www.tldrlegal.com/l/mit
*/

/*
Smooth scroll
TechAcademyマガジン
https://techacademy.jp/magazine/9532
*/

/*
Google Fonts
"Noto Serif Japanese"
Designer : Google
License : SIL Open Font License
https://fonts.google.com/
https://scripts.sil.org/OFL

"Source Serif Pro"
Designer : Frank Grieshammer
License : SIL Open Font License
https://fonts.google.com/
https://scripts.sil.org/OFL

"Libre Baskerville"
Designer : Impallari Type
License : SIL Open Font License
https://fonts.google.com/
https://scripts.sil.org/OFL
*/

/*
Font Awesome(Font)
License : SIL Open Font License 1.1
https://fontawesome.com/v4.7.0/
http://scripts.sil.org/OFL
Font Awesome(Code)
License : MIT license
https://fontawesome.com/v4.7.0/
http://opensource.org/licenses/mit-license.php
*/

/*--------------------PCファースト/すべての画面サイズでベースとなるCSS--------------------*/

/*--------------------全体の設定--------------------*/

* {
    /*paddingとborderを幅と高さに含める*/
    box-sizing: border-box;
    /*単語の途中でも必ず改行される*/
    word-break: break-all;
    /*フォーム周辺のデザインをリセット*/
    -webkit-appearance: none;
    -moz-appearance: none;
}

html {}

body {
    font-family: 'Noto Serif JP', serif;
    font-size: 13px;
    line-height: 1.7;
    color: gray;
    letter-spacing: 0.05em;
    text-align: left;
    background: white;
    /*モバイル端末でのテキストサイズの自動調整対策*/
    -webkit-text-size-adjust: 100%;
    -moz-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

/*--------------------主要タグの設定--------------------*/

/*フロート解除*/
.clearfix:after {
    content: "";
    display: block;
    clear: both;
}

/*リンク*/
a {
    color: #849ddc;
    transition: 0.2s;
    /*アニメーション*/
}

a:hover {
    color: #849ddc;
}

/*画像*/
img {
    /*フルードイメージ（親要素の幅に応じて縦横比を保持したまま自動的に画像の拡大縮小をする）*/
    max-width: 100%;
    height: auto;
    /*ディセンダー対策（画像の下の隙間を無くす）*/
    vertical-align: bottom;
}

a img {
    /*画像リンクの枠線を消す*/
    border: 0;
}

/*段落*/
p {}

/*newマーク*/
.new::after {
    content: "NEW";
    margin-left: 0.5em;
    background: silver;
    color: white;
    padding: 0 5px;
}

/*ulリスト共通*/
ul {
    /*リストマークを非表示*/
    list-style-type: none;
    /*リストマークを内側に表示*/
    list-style-position: inside;
}

/*ulリストタイプ1（横並びリスト）*/
.ultype1 {}

.ultype1 li {font-size:1.5em;
    display: inline;
    margin-right: 0.5em;
}

.ultype1 li:last-child {
    margin-right: 0;
}

/*dlリストタイプ1（項目と説明のリスト）*/
.dltype1 {}

.dltype1 dt {
    float: left;
}

.dltype1 dt::after {
    content: "-";
    margin: 0 0.5em;
}

.dltype1 dd {}

.dltype1 dd span {
    /*更新履歴で使用 カテゴリ名をspanで囲う*/
    margin-right: 0.8em;
}


/*--------------------テキスト関連の設定--------------------*/
/*フォントの種類 太さ*/
h1 {
    font-weight: normal;
    font-family: 'Libre Baskerville', serif;
}

h2,
h3 {
    font-weight: normal;
    font-family: 'Source Serif Pro', serif;
}

.sub,
nav {
    font-family: 'Source Serif Pro', serif;
}

/*テキスト 行の高さ*/
h1,
h2,
h3,
nav,
nav ul li,
.sub {
    line-height: 1;
}

.new::after {
    line-height: 1;
}

/*テキスト 文字間隔*/
h1 {
    letter-spacing: 0.2em;
}

h1 span {
    letter-spacing: 0;
}

.sub {
    letter-spacing: 0.1em;
}

h2,
h3,
nav,
nav ul li {
    letter-spacing: 0.1em;
}

h2 span {
    letter-spacing: 0;
}

em{
background:#ffe1e4;
background:-webkit-linear-gradient(rgba(255,225,228,0) 50%, #ffe1e4 0%);
background:linear-gradient(rgba(255,225,228,0) 50%, #ffe1e4 0%);
font-style:normal;
font-weight:700
}
/*--------------------構造関連の設定--------------------*/

/*ボディ*/
#all {
    width: 100%;
}

/*コンテナ1*/
.container1 {
    width: 100%;
    padding: 40px;
}

/*コンテナ2*/
.container2 {
    width: 100%;
    padding: 0 40px 40px;
}

/*レイアウト一括指定*/
header,
nav ul,
main,
footer {
    max-width: 900px;
    margin: 0 auto;
}

/*ヘッダー*/
header {
    text-align: center;
    /*inline-blockの隙間対策*/
    font-size: 0;
}

header a {
    text-decoration: none;
    color: #b3b3b3;
    /*リンク範囲調整*/
    display: inline-block;
}

header a:hover {
    color: #b3b3b3;
}

.titlebox {}

h1 {
    font-size: 24px;
}

.sub {
    display: block;
    font-size: 15px;
    margin-top: 20px;
}

/*メインビジュアル*/
.mainvisual {
    width: 100%;
    height: 200px;
    background: url(bg01.jpg) repeat center left;
}

/*ナビ*/
nav {
    z-index: 1000;
    width: 100%;
    height: 40px;
    padding: 0 40px;
    background: #abbde9;
    /*フレックスボックス 上下左右中央配置*/
    display: flex;
    align-items: center;
    justify-content: center;
    /*スクロール時に上部固定*/
    position: -webkit-sticky;
    position: sticky;
    top: 0;
}

nav a {
    text-decoration: none;
    color: white;
}

nav a:hover {
    color: white;
}

nav ul {
    width: 100%;
    text-align: center;
    /*隙間対策*/
    font-size: 0;
}

nav ul li {
    /*隙間対策 再指定*/
    font-size: 16px;
    display: inline-block;
    margin-right: 1em;
}

nav ul li:last-child {
    margin-right: 0;
}

/*メイン*/
main {}

/*ページ内リンク位置対策*/
.layout {
    padding-top: 80px;
    margin-top: -40px;
}

/*セクション1*/
.sectiontype1 {}

h2 {
    text-align: center;
    font-size: 18px;
    margin-bottom: 30px;
    color: #b3b3b3;
}

/*左右のライン*/
h2 {
    text-align: center;
    display: flex;
    align-items: center;
}

h2::before,
h2::after {
    background: #abbde9;
    content: "";
    flex-grow: 1;
    height: 1px;
}

h2::before {
    margin-right: 15px;
}

h2::after {
    margin-left: 15px;
}

/*セクション2*/
.sectiontype2 {
    margin-top: 25px;
}

.sectiontype2:first-child {
    margin-top: 0;
}

h3 {
    font-size: 15px;
    margin-bottom: 1em;
    display: inline-block;
}

h3::before {
    /*FontAwesome*/
    content: "\f0da";
    margin-right: 0.5em;
    color: #9be1f8;
    font-family: FontAwesome;
}

/*更新履歴ボックス*/
.update {
    overflow: auto;
    
    padding: 10px 10px;
    outline: 2px solid #dc143c;
    /*スクロールバーを非表示 Firefox用設定*/
    scrollbar-width: none;
    /*スクロールバーを非表示 IE用設定*/
    -ms-overflow-style: none;
}

/*スクロールバーを非表示 Chrome・Safari・Edge用設定*/
.update::-webkit-scrollbar {
    display: none;
}

/*セクション内のタグ間の設定（セクション直下の階層のタグのみ対象）*/
section>p,
section>ul,
section>dl {
    margin-top: 0.5em;
}

h2+p,
h2+ul,
h2+dl,
h3+p,
h3+ul,
h3+dl {
    /*見出しに隣接したタグの上マージンをリセット*/
    margin-top: 0;
}

/*フッター*/
footer {
    text-align: left;
    margin: 40px auto 0;
}

footer ul {}

footer ul li {
    display: inline-block;
    margin-right: 0.8em;
}

footer ul li:last-child {
    margin-right: 0;
}

footer ul li span {
    margin-right: 0.5em;
}

/*------------画面サイズ（横幅）700px以下用------------*/

@media screen and (max-width:700px) {

    .container1 {
        padding: 40px 20px;
    }

    .container2 {
        padding: 0 20px 40px;
    }

    nav {
        padding: 0 20px;
    }

    h1 {
        font-size: 22px;
    }

    .sub {
        font-size: 13px;
    }
}

/*ベンダープレフィックス設定済*/
/*エラーチェック済*/