/************************************************
 * coffybinder.css
 * システム標準のスタイルシートです.
 * カラーリングや見た目のスタイルは、user.cssに書き加えてください.
 * 
 * Copyright © 2019 coffy
 * coffy.tailslab.net
 ************************************************/

/*----------------------------------------------*/
/* ページ全体の共通スタイル */
/*----------------------------------------------*/
html {
    /* フォントファミリー（ゴシック系） */
    font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

/* 余計な余白をなくす */
* {
    box-sizing: border-box;
}

/* 謎の余白を削除 */
img {
    vertical-align: bottom;
}

/*----------------------------------------------*/
/* レイアウト関連 */
/*----------------------------------------------*/
/* フロートボックス */
.float-box>* {
    float: left;
}

.float-box.right>* {
    float: right;
}

.float-box.bottom>* {
    position: absolute;
    bottom: 0px;
}

/* 強制フロート解除 */
.float-box::after {
    content: "";
    display: block;
    clear: both;
}

/* 子要素をインライン要素にする */
.inline-box>* {
    display: inline;
    vertical-align: bottom;
}

/* 子要素をブロック要素にする */
.block-box>* {
    display: block;
}

/*----------------------------------------------*/
/* フレックスボックス関連 */
/*----------------------------------------------*/
/* フレックスボックス（横並び） */
.flexbox {
    display: flex;
    display: -webkit-flex;
    flex-direction: row;
    -webkit-flex-direction: row;
}

/* フレックスボックス（縦並び） */
.flexbox.row {
    flex-direction: column;
    -webkit-flex-direction: column;
}

/* 折り返しを許可 */
.flexbox.wrap {
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

/* 中央揃え */
.flexbox.center {
    justify-content: center;
    align-items: center;
}

/* 下揃え */
.flexbox.bottom {
    /* justify-content: center; */
    align-items: flex-end;
}

.flexbox.reverse {
    flex-flow: row-reverse;
}

/* フレックスアイテム（伸縮する） */
.flexitem-fill {
    flex-grow: 1;
}

/* 縦並び中央揃えのとき、要素がはみ出る不具合を修正 */
.flexbox.row.center * {
    /* max-height: 100%; */
}

/* 余白 */
.flexbox.gap {
    gap: 1em;
}

/*----------------------------------------------*/
/* ページングセクションのスタイル */
/*----------------------------------------------*/
pager {
    text-align: center;
}

pager ul {
    padding: 0;
}

pager li {
    display: inline-block;
    margin: 0 1rem;
    list-style-type: none;
}

/*----------------------------------------------*/
/* CSSアニメーション */
/*----------------------------------------------*/
/* フェードイン */
.fadein {
    animation: fadein 1s ease 0s 1 normal;
    -webkit-animation: fadein 1s ease 0s 1 normal;
}

@keyframes fadein {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@-webkit-keyframes fadein {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

/*----------------------------------------------*/
/* メニューボタン */
/*----------------------------------------------*/
.menu-btn {
    position: fixed;
    top: 10px;
    right: 10px;
    height: 50px;
    width: 50px;
    /* 中央揃え */
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1000;
    /* メニューボタンの非表示 */
    display: none;
}

.menu-btn span,
.menu-btn span:before,
.menu-btn span:after {
    content: '';
    position: absolute;
    display: block;
    height: 1px;
    width: 25px;
    border-radius: 3px;
    border-top: 1px solid black;
    transition: 0.3s;
}

.menu-btn span:before {
    bottom: 8px;
}

.menu-btn span:after {
    top: 8px;
}

#menu-trigger:checked~.menu-btn span {
    border-color: transparent;
}

#menu-trigger:checked~.menu-btn span::before {
    top: 0;
    transform: rotate(45deg);
}

#menu-trigger:checked~.menu-btn span::after {
    top: 0;
    transform: rotate(-45deg);
}

/*----------------------------------------------*/
/* 先頭に戻るボタン */
/*----------------------------------------------*/
.page_top {
    display: block;
    width: 50px;
    height: 50px;
    position: fixed;
    right: 10px;
    bottom: 10px;
    transition: 0.3s;
    /* 見た目 */
    background: rgba(255, 255, 255, 0.5);
    border: 1px solid lightgray;
    border-radius: 50%;
}

.page_top::before {
    content: '';
    position: absolute;
    top: 7px;
    right: 0;
    bottom: 0;
    left: 0;
    display: block;
    width: 14px;
    height: 14px;
    margin: auto;
    transform: rotate(-45deg);
    border-top: 1px solid black;
    border-right: 1px solid black;
}

/*----------------------------------------------*/
/* メディアクエリ */
/*----------------------------------------------*/
/* ↓縦向きの場合のスタイル  */
@media screen and (orientation: portrait) {

    /* ナビゲーションセクションを隠す */
    nav {
        position: fixed !important;
        top: 0;
        right: -100vh;
        height: 100vh;
        overflow-y: auto;
        transition: 0.3s;
        z-index: 100;
    }

    /* メニューボタンの表示 */
    .menu-btn {
        display: flex;
    }

    /* メニューボタン押下時のメニュー表示 */
    #menu-trigger:checked~nav {
        right: 0;
    }
}