@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=Mrs+Saint+Delafield&display=swap');
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond&display=swap');

/*--------------------テンプレート情報--------------------*/
/*template　Maison de R*/
/*url　https://maisonder.web.fc2.com/*/
/*title　AMETHYST EYES*/
/*code　CSS3*/

/*--------------------ライセンス--------------------*/

/*HTML5 Reset Stylesheet
html5doctor.com Reset Stylesheet v1.6.1
License : CC0 Public Domain Dedication, MIT License
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
*/

/*
hamburger menu
Knoweb 世界一わかりやすいWeb制作
https://knoweb.net/html-css/css/responsive-hamburgermenu/
*/

/*
Google Fonts
"Noto Serif Japanese"
Designer : Google
License : SIL Open Font License
https://fonts.google.com/
https://scripts.sil.org/OFL

"Mrs Saint Delafield"
Designer : Sudtipos
License : SIL Open Font License
https://fonts.google.com/
https://scripts.sil.org/OFL

"EB Garamond"
Designer : Georg Duffner,Octavio Pardo
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: 20px;
    line-height: 2;
    color: white;
    letter-spacing: 0.05em;
    text-align: left;
    background: #bdb2d7;
    /*モバイル端末でのテキストサイズの自動調整対策*/
    -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: white;
    transition: 0.2s;
    /*アニメーション*/
}

a:hover {
    color: white;
}

/*画像*/
img {
    /*フルードイメージ（親要素の幅に応じて縦横比を保持したまま自動的に画像の拡大縮小をする）*/
    max-width: 100%;
    height: auto;
    /*ディセンダー対策（画像の下の隙間を無くす）*/
    vertical-align: bottom;
}

a img {
    /*画像リンクの枠線を消す*/
    border: 0;
}

/*段落*/
p {}

/*newマーク*/
.new::after {
    content: "NEW";
    margin-left: 0.5em;
    border: 1px solid #5a5a5a;
    color: #5a5a5a;
    padding: 0 8px;
}

/*ulリスト共通*/
ul {
    /*リストマークを非表示*/
    list-style-type: none;
    /*リストマークを内側に表示*/
    list-style-position: inside;
}

/*ulリストタイプ1（横並びリスト）*/
.ultype1 {}

.ultype1 li {
    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 {}

/*--------------------テキスト関連の設定--------------------*/
/*フォントの種類 太さ*/
h1,
h2 {
    font-weight: normal;
    font-family: 'EB Garamond', serif;
}

.sub2,
.ntsub {
    font-family: 'Mrs Saint Delafield', cursive;
}

nav {
    font-family: 'EB Garamond', serif;
}

/*テキスト 行の高さ*/
h1,
h2,
nav,
nav ul li,
.sub1,
.sub2 {
    line-height: 1;
}

.new::after {
    line-height: 1;
}

.ntsub,
.ntmain {
    line-height: 1;
}

/*タイトル・サブタイトルが2行になりそうな場合はこちらの設定がおすすめです*/
h1 {
    line-height: 1.2;
}

.sub1 {
    line-height: 1.8;
}

.sub2 {
    line-height: 1.4;
}

/*テキスト 文字間隔*/
h1 {
    letter-spacing: 0.2em;
}

.h1end {
    letter-spacing: 0;
}

.sub1 {
    letter-spacing: 0.2em;
}

.sub2,
.ntsub {
    letter-spacing: 0;
}

h2 {
    letter-spacing: 0.2em;
}

h2 span {
    letter-spacing: 0;
}

nav,
nav ul li {
    letter-spacing: 0.2em;
}

/*--------------------構造関連の設定--------------------*/

/*ブロックを画面いっぱいに広げる*/
html,
#all {
    height: 100%;
}

.container1 {
    /*コンテンツ量が多いときに伸びるようにする*/
    min-height: 100%;
    height: auto;
}

/*ボディ*/
#all {
    width: 100%;
}

/*背景画像*/
body::before {
    content: "";
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100vh;
    background: url('bg01.jpg') no-repeat center center;
    background-size: cover;
}

/*　ハンバーガーボタン　*/
.hamburger {
    display: block;
    position: fixed;
    z-index: 3;
    right: 13px;
    top: 12px;
    width: 42px;
    height: 42px;
    cursor: pointer;
    text-align: center;
}

.hamburger span {
    display: block;
    position: absolute;
    width: 30px;
    height: 2px;
    left: 6px;
    background: #5a5a5a;
    transition: 0.3s ease-in-out;
}

.hamburger span:nth-child(1) {
    top: 10px;
}

.hamburger span:nth-child(2) {
    top: 20px;
}

.hamburger span:nth-child(3) {
    top: 30px;
}

/* ナビ開いてる時のボタン */
.hamburger.active span:nth-child(1) {
    top: 16px;
    left: 6px;
    transform: rotate(-45deg);
}

.hamburger.active span:nth-child(2),
.hamburger.active span:nth-child(3) {
    top: 16px;
    transform: rotate(45deg);
}

/*ハンバーガーメニュー*/
nav.globalMenuSp {
    position: fixed;
    z-index: 2;
    top: 0;
    right: 0;
    color: white;
    background: #bdb2d7;
    text-align: center;
    transform: translateX(100%);
    transition: all 0.6s;
    width: 100%;
    height: 100%;
    padding: 60px 0;
}

nav.globalMenuSp ul {
    margin: 0 auto;
    padding: 0;
    width: 100%;
}

nav.globalMenuSp ul li {
    list-style-type: none;
    padding: 0;
    width: 100%;
    font-size: 20px;
}

nav.globalMenuSp ul li:last-child {
    padding-bottom: 0;
    border-bottom: none;
}

nav.globalMenuSp ul li:hover {
    background: rgb(255, 255, 255, 0.2);
}

nav.globalMenuSp ul li a:hover {
    color: white;
}

nav.globalMenuSp ul li a {
    display: block;
    color: white;
    padding: 1em 0;
    text-decoration: none;
}

/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
    transform: translateX(0%);
}

/*コンテナ1*/
.container1 {
    width: 100%;
    padding: 100px 0;
    /*フレックスボックス*/
    display: flex;
    align-items: stretch;
    justify-content: center;
}

/*ヘッダー*/
header {
    background: rgba(255, 255, 255, 0.8);
    color: #d397cb;
    width: 100%;
    padding: 60px 50px;
    /*フレックスボックス*/
    display: flex;
    align-items: center;
    justify-content: center;
}

.title {
    text-align: center;
}

h1 {
    font-size: 70px;
}

.h1a::after {
    /*タイトルの半角スペース*/
    content: " ";
}

.sub1 {
    font-size: 26px;
    margin-bottom: 30px;
}

.sub2 {
    font-size: 50px;
    margin-top: 30px;
}

/*コンテナ2*/
.container2 {
    color: #5a5a5a;
    width: 100%;
    padding: 60px 50px;
    background: rgba(255, 255, 255, 0.8);
    margin-top: 100px;
}

.container1+.container2 {
    margin-top: 0;
}

.container2 a {
    color: #5a5a5a;
}

.container2 a:hover {
    color: #d397cb;
}

/*セクション1*/
.sectiontype1 {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
}

h2 {
    text-align: center;
    font-size: 40px;
    color: #d397cb;
    margin-bottom: 50px;
}

h2 {
    /*見出しの両端の水平線デザイン*/
    /*フレックスボックス*/
    display: flex;
    /*要素を上下中央配置*/
    align-items: center;
}

h2::before,
h2::after {
    /*見出しの両端の水平線デザイン*/
    content: "";
    height: 2px;
    background: url(bg02.jpg) repeat center left;
    display: block;
    /*余ったスペースを水平線で埋める*/
    flex-grow: 1;
}

h2::before {
    /*見出しの両端の水平線デザイン*/
    margin-right: 1em;
}

h2::after {
    /*見出しの両端の水平線デザイン*/
    margin-left: 1em;
}

/*インナー*/
.inner {}

/*ストーリー用リスト*/
.ulstory {}

/*ストーリーの紹介文*/
.storytext {
    margin-top: 20px;
}

.storytext p {
    margin-top: 1em;
}

.storytext p:first-child {
    margin-top: 0;
}

/*キャラクター用リスト*/
.ulcharacter {
    margin-top: 30px;
}

.inner .ulcharacter:first-child {
    margin-top: 0;
}

/*キャラクターの名前*/
.charactername {
    text-align: center;
}

/*キャラクターの紹介文*/
.charactertext {
    margin-top: 10px;
}

/*小説用リスト*/
.ulnovel {}

.ulnovel {
    margin-top: 50px;
}

.inner .ulnovel:first-child {
    margin-top: 0;
}

/*小説のタイトル*/
.noveltitle {}

.noveltitleitem {
    text-align: center;
}

.ntsub {
    font-size: 32px;
}

.ntmain {
    margin-top: 20px;
}

/*小説の紹介文*/
.noveltext {
    margin-top: 30px;
}

/*小説の目次*/
.novelcontents {
    margin-top: 20px;
}

/*インフォメーション*/
.info {}

/*インフォメーション内のタグ間の設定（インフォメーション直下の階層のタグのみ対象）*/
.info>p,
.info>ul,
.info>dl {
    margin-top: 1em;
}

/*インフォメーション内の最初のタグの上マージンをリセット*/
.info p:first-child,
.info ul:first-child,
.info dl:first-child {
    margin-top: 0;
}

/*フッター*/
footer {
    padding: 40px 50px;
}

.footerbox {
    text-align: center;
    max-width: 800px;
    margin: 0 auto;
}

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;
}

/*------------画面サイズ（横幅）980px以下用------------*/

@media screen and (max-width:980px) {
    body {
        font-size: 18px;
    }

    header {
        padding: 60px 30px;
    }

    h1 {
        font-size: 60px;
    }

    .h1a::after {
        /*タイトルの半角スペースを無効*/
        display: none;
    }

    .h1b::before {
        /*タイトルを改行*/
        content: "\A";
        white-space: pre;
    }

    .sub1 {
        font-size: 24px;
    }

    .sub2 {
        font-size: 44px;
    }

    .container2 {
        padding: 60px 30px;
    }

    h2 {
        font-size: 38px;
    }

    footer {
        padding: 40px 30px;
    }
}

/*------------画面サイズ（横幅）600px以下用------------*/
@media screen and (max-width:600px) {
    body {
        font-size: 16px;
    }

    header {
        padding: 60px 20px;
    }

    h1 {
        font-size: 40px;
    }

    .sub1 {
        font-size: 20px;
    }

    .sub2 {
        font-size: 38px;
    }

    .container2 {
        padding: 60px 20px;
    }

    h2 {
        font-size: 30px;
    }

    h2::before {
        /*見出しの両端の水平線デザイン*/
        margin-right: 0.8em;
    }

    h2::after {
        /*見出しの両端の水平線デザイン*/
        margin-left: 0.8em;
    }

    .ntsub {
        font-size: 28px;
    }

    footer {
        padding: 40px 20px;
    }

}

/*ベンダープレフィックス設定済*/
/*エラーチェック済*/