/* <system section="theme" selected="6653812171397406126"> */
/*フォント*/
@import url(https://fonts.googleapis.com/css?family=Cabin);
@import url(https://fonts.googleapis.com/css?family=Montserrat);
/*
  Theme: Naked
  Author: Yukihy
  Description: this theme can be customized flexibly
  Responsive: yes
*/
/*サイドバー黒線#acacac　日付など灰色#888　薄い灰色#ccc 背景など薄い灰色#f5f5f5　リンク青#0693cd*/
body {
    color: #444;
    font-family: 'arial' ,游ゴシック, YuGothic, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
    font-size: 16px;
    background-image: url('https://cdn.blog.st-hatena.com/images/theme/backgrounds/2014/polygon-01.jpg?version=9bfff836f89904fd2839062014b61f');
    background-attachment: fixed;
    background-size: cover;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
    position: relative;
    z-index: 2;
}
@media screen and (max-width: 680px) {
    body {
        font-size: 15px;
        background-size: auto;
        background-repeat: repeat;
    }
}
#content a {
    text-decoration: none;
}
#content a:hover {
    opacity: .6;
}
/*
************レイアウト・フォント************
*/
/*レイアウト*/
#content {
    position: relative;
    background-color: #f5f5f5;
}
#blog-title-inner,
#content-inner {
    max-width: 1024px;
    width: 90%;
    margin: 0 auto;
}
#blog-title-content {
    padding: 80px 0 40px 0;
}
#content-inner {
    padding-top: 30px;
}
#content-inner::after {
    display: block;
    visibility: hidden;
    clear: both;
    height: 0;
    content: '';
}
#wrapper {
    width: 100%;
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
            box-sizing: border-box;
    float: left;
    margin-right: -340px;
    padding-right: 340px;
}
#box2 {
    float: right;
    width: 300px;
    padding-bottom: 40px;
    margin-top: 10px;
}
article {
    position: relative;
    margin: 10px 0 40px 0;
    padding: 32px 32px 40px 32px;
    background-color: #fff;
}
#footer-inner {
    padding-top: 20px;
    padding-bottom: 30px;
}
@media screen and (max-width: 768px) {
    #wrapper {
        float: none;
        margin-right: 0;
        padding-right: 0;
    }
    #box2 {
        float: none;
        width: 90%;
        margin: 20px auto 0 auto;
    }
}
@media screen and (max-width: 680px) {
    #blog-title-inner,
    #content-inner {
        width: 100%;
    }
    #content-inner {
        padding-top: 20px;
    }
    #blog-title-content {
        padding: 20px 10px 5px 10px;
    }
    article {
        margin: 10px 0 40px 0;
        padding: 10px 10px 20px 10px;
    }
    #box2 {
        width: 300px;
    }
}
/*数字フォントの変更部分*/
.entry-date a,
#box2 .urllist-date-link a,
#box2 .hatena-module-archive .hatena-module-body a,
.archive-entry-header .date a {
    font-family: 'Montserrat', sans-serif;
}

/*
************ヘッダー・ブログタイトル************
*/
#globalheader-container {
    color: #ccc;
}
#title {
    display: inline;
}
#title a {
    color: #fff;
    font-family: 'Cabin', sans-serif;
    font-size: 30px;
    font-weight: normal;
    text-decoration: none;
    letter-spacing: 5px;
}
@media screen and (max-width: 680px) {
    #title a {
        font-size: 20px;
        letter-spacing: 2px;
    }
}

/*
************ブログの説明************
*/
#blog-description {
    color: #ececec;
    font-family: 'Cabin', sans-serif;
    font-size: 12px;
    font-weight: normal;
    letter-spacing: 1px;
}
@media screen and (max-width: 680px) {
    #blog-description {
        font-size: 10px;
    }
}
/*
************タイトル下***********
*/
/*メニュー*/
#n-menu {
    padding: 5px 0;
}
#n-menu .menu-inner {
    max-width: 1024px;
    width: 90%;
    height: 40px;
    margin: 0 auto;
}
#n-menu .menu-btn {
    display: none;
}
#n-menu .menu-content {
    list-style-type: none;
    width: 100%;
    height: 100%;
    margin: 0;
    padding-left: 0;
}
#n-menu .menu-content > li {
    position: relative;
    float: left;
    height: 100%;
    text-align: center;
}
#n-menu .menu-content > li > a {
    display: block;
    height: 100%;
    padding: 0 15px;
    color: #fff;
    font-size: 80%;
    font-weight: bold;
    text-decoration: none;
    line-height: 40px;
}
#n-menu .menu-content > li > a:hover {
    border-bottom: 1px solid #fff;
}
/*２階層目*/
#n-menu .menu-content > li:hover .second-level {
    visibility: visible;
    top: 40px;
    opacity: 1;
    transition: .5s;
}
#n-menu .second-level {
    visibility: hidden;
    list-style-type: none;
    position: absolute;
    z-index: 9999;
    top: 60px;
    width: 200px;
    margin: 0;
    padding-left: 0;
    border: 2px solid #acacac;
    opacity: 0;
}
#n-menu .second-level > li {
    display: block;
    width: 100%;
    border-bottom: 1px solid #acacac;
    text-align: center;
}
#n-menu .second-level > li:last-child {
    border-bottom: none;
}
#n-menu .second-level > li > a {
    display: block;
    padding: 15px;
    background-color: #fff;
    color: #444;
    font-size: 70%;
    font-weight: bold;
    text-decoration: none;
}
#n-menu .second-level > li > a:hover {
    background-color: #f6f6f6;
}
/*トグルメニュ*/
@media screen and (max-width:768px) {
    #n-menu {
        padding: 0;
    }
    #n-menu .menu-inner {
        width: 100%;
        height: auto;
    }
    #n-menu .btn-content {
        text-align: right;
    }
    #n-menu .menu-btn {
        display: block;
        padding: 10px 15px;
        color: #fff;
        font-size: 90%;
        cursor: pointer;
    }
    #n-menu .menu-content {
        display: none;
        width: 100%;
    }
    #n-menu .menu-content > li {
        float: none;
        width: 100%;
        height: 40px;
    }
    #n-menu .menu-content > li > a {
        width: 100%;
        padding: 0;
        line-height: 40px;
    }
    #n-menu .menu-content > li > a:hover {
        border: none;
    }
    #n-menu .second-level {
        display: none;
    }
}
@media screen and (max-width:680px) {
    #n-menu .menu-btn {
        font-size: 80%;
    }
}

/*
************記事************
*/
.entry-header {
    position: relative;
}
/*日付*/
.entry-date a {
    color: #888;
    font-size: 12px;
}
.entry-date a::before {
    margin-right: 1px;
    font-family: 'blogicon';
    content: '\f043';
}
.entry-date .hyphen {
    display: none;
}
.entry-date .date-month::before,
.entry-date .date-day::before {
    content: '.';
}
/*記事タイトル*/
.entry-title {
    margin: 0;
    padding: 10px 0 0 0;
    line-height: 1.2;
}
.entry-title a {
    color: #222;
    font-size: 26px;
    letter-spacing: 1px;
}
@media screen and (max-width: 680px) {
    .entry-title {
        margin: 0;
    }
    .entry-title a {
        font-size: 20px;
        letter-spacing: 0;
    }
}
/*カテゴリ*/
.entry-categories {
    margin-bottom: 10px;
}
.entry-categories a {
    margin: 0 4px 10px 0;
    color: #888;
    font-size: 12px;
}
.entry-categories a::before {
    margin-right: 3px;
    font-family: 'blogicon';
    content: '\f022';
}

/*編集リンク*/
.entry-header-menu {
    position: absolute;
    right: 0;
    top: 0;
}
.entry-header-menu a {
    display: inline-block;
    padding: 10px 20px;
    border: double #ccc;
    color: #222 !important;
    font-size: 12px;
    font-weight: bold;
}

/*記事*/
.entry-content {
    color: #444;
    font-size: 16px;
}
.entry-content a {
    color: #0693cd;
}
.etnry-content p {
    margin: 1em 0;
    line-height: 1.7em;
}
@media screen and (max-width: 680px) {
    .entry-content {
        font-size: 15px;
    }
}

.entry-content h1 {
    margin: 36px -32px 20px -32px;
    padding: 20px 5px 20px 20px;
    border-left: 5px solid #444;
    color: #444 ;
    font-size: 20px ;
    font-weight: bold;
    line-height: 1.4;
    letter-spacing: 2px;
}
.entry-content h2 {
    margin: 36px -32px 20px -32px;
    padding: 20px 5px 20px 20px;
    background-color: #444;
    color: #fff ;
    font-size: 20px ;
    font-weight: bold;
    line-height: 1.4;
    letter-spacing: 2px;
}
.entry-content h3 {
    margin: 32px -32px 20px -32px;
    padding: 12px 16px;
    border-left: 6px solid #444;
    background-color: #f6f6f6;
    color: #444;
    font-size: 20px;
    font-weight: bold;
    line-height: 1.4;
    letter-spacing: 1px;
}
.entry-content h4 {
    margin: 28px -16px 20px -16px;
    padding: 0 12px;
    border-bottom: 10px solid #f6f6f6;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.4;
    letter-spacing: 1px;
}
.entry-content h5 {
    position: relative;
    margin: 28px 0 20px 16px;
    color: #444;
    font-size: 16px;
    font-weight: bold;
    line-height: 1.4;
}
.entry-content h5::before {
    position: absolute;
    top: -webkit-calc(50% - 4px) ;
    top:         calc(50% - 4px);
    left: -16px;
    border: 5px solid #444;
    content: '';
}
.entry-content h6 {
    margin: 28px 0 20px 0;
    font-size: 16px;
    font-weight: bold;
    line-height: 1.4;
}
@media screen and (max-width: 680px) {
    .entry-content h1 {
        margin: 30px -5px 20px -5px;
        padding: 15px 5px 15px 10px;
        border-left: 5px solid #444;
        color: #444 ;
        font-size: 16px;
        letter-spacing: 0;
    }
    .entry-content h2 {
        margin: 30px -5px 20px -5px;
        padding: 15px 5px 15px 10px;
        background-color: #444;
        color: #fff;
        font-size: 16px;
        letter-spacing: 1px;
    }
    .entry-content h3 {
        margin: 30px -5px 20px -5px;
        padding: 10px;
        border-left: 5px solid #444;
        background-color: #f6f6f6;
        color: #444;
        font-size: 16px;
        letter-spacing: 0;
    }
    .entry-content h4 {
        margin: 20px 0 16px 0;
        padding: 0;
        border-bottom: 10px solid #f6f6f6;
        font-size: 16px;
        letter-spacing: 0;
    }
    .entry-content h5 {
        position: relative;
        margin: 20px 0 16px 16px;
        color: #444;
        font-size: 16px;
    }
    .entry-content h6 {
        margin: 20px 0 16px 0;
        font-size: 16px;
    }
}

a.entry-see-more {
    display: inline-block;
    padding: 10px 20px;
    -webkit-border-radius: 5px;
       -moz-border-radius: 5px;
            border-radius: 5px;
    background-color: #444;
    color: #fff;
    font-size: 14px;
    text-align: center;
    letter-spacing: 1px;
}
@media screen and (max-width: 680px) {
    .entry-see-more {
        font-size: 12px;
    }
}

.entry-content blockquote {
    position: relative;
    margin: 0;
    padding: 30px;
    background-color: #f6f6f6;
}
.entry-content blockquote::before {
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    opacity: .2;
    font-family: serif;
    font-size: 500%;
    line-height: 1;
    content: '“';
}
.entry-content blockquote::after {
    position: absolute;
    right: 0;
    bottom: 0;
    opacity: .2;
    font-family: serif;
    font-size: 500%;
    line-height: 0;
    content: '”';
}
.entry-content blockquote p {
    margin-top: 0;
}
.entry-content blockquote cite {
    font-weight: bold;
    font-style: italic;
}
@media screen and (max-width: 680px) {
    .entry-content blockquote {
        padding: 20px;
        font-size: 90%;
    }
    .entry-content blockquote::before,
    .entry-content blockquote::after {
        font-size: 400%;
    }
}

.entry-content ul {
    margin: 16px 0;
    padding: 0 0 0 40px;
}
.entry-content ul ul {
    margin-top: 0;
    margin-bottom: 0;
}
.entry-content ol {
    margin: 16px 0;
    padding: 0 0 0 40px;
}
.entry-content ol ol {
    margin-top: 0;
    margin-bottom: 0;
}
@media screen and (max-width: 680px) {
    .entry-content ul,
    .entry-content ol {
        margin: 16px 0;
        padding: 0 0 0 24px;
    }
}

.entry-content dt {
    margin-top: 1.7em;
    border-bottom: 5px solid #f6f6f6;
    font-weight: bold;
}
.entry-content dd {
    margin-bottom: 1.7em;
}
@media screen and (max-width: 680px) {
    .entry-content dd {
        margin-left: 20px;
    }
}

.entry-content table {
    border-spacing: 0;
    border-collapse: collapse;
    max-width: none;
    width: 100%;
    margin: 0 0 1.7em;
    border: 1px solid #ccc;
    font-size: 90%;
    line-height: 1.6;
}
.entry-content th,
.entry-content td {
    border-bottom: 1px solid #ccc;
    border-left: 1px solid #ccc;
}
.entry-content th:first-child,
.entry-content td:first-child {
    border-left: none;
}
.entry-content th {
    display: table-cell;
    padding: 1em;
    background-color: #efefef;
    font-weight: bold;
}
.entry-content tbody {
    display: table-row-group;
    border-color: inherit;
    vertical-align: middle;
}
.entry-content td {
    padding: 1em;
    text-align: center;
}
.entry-content pre {
    padding: 24px;
    background-color: #222;
    color: #eee;
}
/*記事下*/
.entry-footer {
    font-size: 90%;
}
/*コメント欄*/
.comment-box {
    padding-bottom: 40px;
}
.comment-box  .comment {
    list-style: none;
    margin: 10px 0;
    padding: 0;
}
.comment-box .entry-comment {
    margin-bottom: 10px;
}
.comment-box .comment-user-name {
    margin-bottom: 0;
}
.comment-box .comment-user-id {
    color: #333;
    font-weight: bold;
}
.comment-box .hatena-id-icon {
    width: 40px;
    height: 40px;
}
.comment-box .comment-content {
    padding: 10px 30px;
    background-color: #f6f6f6;
}
/*
************サイドバー************
*/
#box2 {
    font-size: 90%;
}
.hatena-module-title a,
.hatena-module-body a {
    color: #444;
}
#box2 .hatena-module {
    margin-bottom: 40px;
}
.hatena-module-title {
    margin-bottom: 10px;
    padding: 5px 15px;
    border-left: 5px solid #ccc;
    color: #444;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 2px;
}
@media screen and (max-width: 680px) {
    #box2 .hatena-module {
        margin-bottom: 20px;
    }
    .hatena-module-title {
        margin-bottom: 5px;
        padding: 5px 10px;
        font-size: 16px;
        letter-spacing: 1px;
    }
}

/*プロフィール*/
.profile-description a {
    color: #0693cd;
}
.profile-icon {
    margin: 0 16px 16px 0;
    border-radius: 4px;
    float: left;
    overflow: hidden;
}
/*検索*/
.search-form {
    position: relative;
    height: 40px;
    padding: 10px 0;
}
.search-module-input {
    width: 240px;
    width: -webkit-calc(100% - 60px) ;
    width:         calc(100% - 60px);
    height: 100%;
    margin: 0 auto;
    padding: 0 40px 0 20px;
    border: none;
    -webkit-border-radius: 3px;
       -moz-border-radius: 3px;
            border-radius: 3px;
    background-color: #fff;
    -webkit-transition: .5s;
       -moz-transition: .5s;
        -ms-transition: .5s;
         -o-transition: .5s;
            transition: .5s;
}
.search-module-input:focus {
    background-color: #555;
    color: #fff;
}
.search-module-button {
    position: absolute;
    top: 10px;
    right: 0;
    width: 40px;
    height: 40px;
    padding: 0;
    border: none;
    -webkit-border-radius: 0 3px 3px 0;
       -moz-border-radius: 0 3px 3px 0;
            border-radius: 0 3px 3px 0;
    background: transparent url(https://cdn.blog.st-hatena.com/images/theme/search.png) no-repeat right center;
    background-position: center;
    text-indent: -9999px;
}
/*リンク*/
.hatena-module-links .hatena-urllist {
    list-style: none;
    margin: 0;
    padding: 8px 0;
}
.hatena-module-links li {
    display: block;
    border-top: 1px solid #acacac;
}
.hatena-module-links li:last-child {
    border-bottom: 1px solid #acacac;
}
.hatena-module-links a {
    display: block;
    padding: 8px 0;
    color: #0693cd !important;
}
/*最新記事・関連記事・注目記事*/
.recent-entries,
.entries-access-ranking,
.related-entries {
    margin: 0 0 10px 0;
    padding: 0;
}
.urllist-item {
    list-style-type: none;
    margin-bottom: 10px;
    padding: 10px;
    background-color: #fff;
}
.urllist-item a {
    color: #444;
    text-decoration: none;
}
.urllist-date-link a,
.urllist-categories a {
    color: #888;
    font-size: 10px;
}
.urllist-date-link a::before {
    font-family: 'blogicon';
    content: '\f043';
}
.urllist-categories a::before {
    font-family: 'blogicon';
    content: '\f022';
}
.urllist-title-link {
    font-size: 13px;
    font-weight: bold;
}
.urllist-entry-body {
    color: #888;
    font-size: 10px;
}
/*カテゴリ*/
.hatena-module-category .hatena-urllist {
    list-style: none;
    margin: 10px 0;
    padding: 0;
}
.hatena-module-category li {
    display: block;
    width: 100%;
    padding: 0;
    border-bottom: 1px solid #acacac;
    font-size: 12px;
}
.hatena-module-category a {
    display: block;
    padding: 8px 10px;
    -webkit-transition: .3s;
       -moz-transition: .3s;
        -ms-transition: .3s;
         -o-transition: .3s;
            transition: .3s;
}
.hatena-module-category a:hover {
    padding: 8px 5px 8px 15px;
}
.hatena-module-category a::before {
    margin-right: 5px;
    font-family: 'blogicon';
    content: '\f006';
}
/*月間アーカイブ*/
.hatena-module-archive .hatena-urllist {
    margin: 10px 0;
    font-size: 14px;
}
.archive-module-year {
    padding: 8px 0;
}
.archive-module-months {
    font-size: 13px;
}
.archive-module-month {
    padding-left: 30px;
}
/*最新のコメント*/
.recent-comments {
    list-style: none;
    margin: 10px 0;
    padding: 0;
}
.recent-comments li {
    padding: 10px 0;
    border-bottom: 1px solid #acacac;
}
.recent-comments a::before {
    font-family: 'blogicon';
    content: '\f01d';
}
/*参加グループ*/
.hatena-module-circles .hatena-urllist {
    margin: 10px 0;
    padding: 0;
}
.hatena-module-circles li {
    margin-bottom: 10px;
}
.hatena-module-circles a {
    font-weight: bold;
}

/*
************ページャー************
*/
.pager {
    overflow: hidden;
    margin-bottom: 40px;
}
.pager a {
    color: #0693cd;
}
.pager .pager-prev {
    float: left;
    width: 40%;
    text-align: left;
}
.pager .pager-next {
    float: right;
    width: 40%;
    text-align: right;
}

/*
************フッター************
*/
/*フッター*/
#footer {
    color: #ccc;
    text-align: center;
}
#footer a {
    color: #ccc;
    font-weight: bold;
    text-decoration: none;
}
#footer a:hover {
    opacity: .6;
}
/*オリジナルフッター*/
#n-footer {
    padding: 40px 0;
    background-color: #eee;
}
#n-footer-inner {
    overflow: hidden;
    width: 300px;
    margin: 0 auto;
}
#n-footer .content {
    width: 300px;
    margin-bottom: 10px;
}
@media screen and (min-width: 680px) {
    #n-footer-inner {
        width: 640px;
    }
    #n-footer .content {
        float: left;
        margin-right: 10px;
        margin-left: 10px;
    }
}
@media screen and (min-width: 1110px) {
    #n-footer-inner {
        max-width: 1024px;
        width: 90%;
    }
    #n-footer .content {
        float: none;
        display: inline-block;
        vertical-align: top;
        margin-right: 15px;
        margin-left: 15px;
    }
}

#n-copyright {
    padding-top: 30px;
    padding-bottom: 60px;
}
#n-copyright h4,
#n-copyright a {
    color: #fff;
    font-size: 14px;
    text-align: center;
    text-decoration: none;
}
/*
************Aboutページ************
*/
.page-about .entry-content .profile-icon {
    width: 32px;
    height: 32px;
}

/*
************Archive************
*/
.page-archive .archive-heading {
    margin: 0 0 20px 0;
    font-size: 24px;
}
.page-archive .archive-entries {
    margin: 10px 0 40px 0;
}
.page-archive .archive-entry {
    position: relative;
    margin-bottom: 20px;
    padding: 24px 32px;
    background-color: #fff;
}

/*日付*/
.page-archive .date a {
    color: #888;
    font-size: 12px;
}
.page-archive .date a::before {
    margin-right: 1px;
    font-family: 'blogicon';
    content: '\f043';
}
/*記事タイトル*/
.page-archive .entry-title {
    margin: 0;
    padding: 10px 0 0 0;
    line-height: 1.2;
}
.page-archive .entry-title a {
    color: #222;
    font-size: 26px;
    letter-spacing: 1px;
}
/*カテゴリ*/
.page-archive .categories {
    margin-bottom: 10px;
}
.page-archive .categories a {
    margin: 0 4px 0 0;
    color: #888;
    font-size: 12px;
}
.page-archive .categories a::before {
    margin-right: 3px;
    font-family: 'blogicon';
    content: '\f022';
}
@media screen and (max-width: 680px) {
    .page-archive .archive-heading {
        margin: 0 0 10px 0;
        font-size: 16px;
        text-align: center;
    }
    .page-archive .archive-entries {
        margin-bottom: 30px;
    }
    .page-archive .archive-entry {
        margin-bottom: 20px;
        padding: 20px;
        background-color: #fff;
    }
    .page-archive .entry-title a {
        font-size: 20px;
        letter-spacing: 0;
    }
    .page-archive .entry-description {
        font-size: 90%;
    }
}

/*
************カテゴリページ************
*/
/*パンくずリスト*/
#top-box {
    height: 60px;
    border-bottom: 1px solid #ccc;
    background-color: #f8f8f8;
}
#top-box .breadcrumb {
    height: 100%;
}
#top-box .breadcrumb-inner {
    max-width: 1024px;
    width: 90%;
    height: 100%;
    margin: 0 auto;
    font-size: 14px;
    line-height: 60px;
}
#top-box .breadcrumb-link,
#top-box .breadcrumb-child {
    color: #444;
    font-weight: bold;
    text-decoration: none;
}
#top-box .breadcrumb-gt {
    margin: 0 10px;
}

/*from Yukihy Life*/
/*目次*/
ul.table-of-contents {
    list-style-type: decimal;
    padding: 20px 10px 20px 40px;
    border: 1px solid #e4e4e4;
    -webkit-border-radius: 5px;
       -moz-border-radius: 5px;
            border-radius: 5px;
    font-size: 90%;
}
ul.table-of-contents ul {
    list-style-type: decimal;
    margin-left: 0;
    font-size: 90%;
}
ul.table-of-contents::before {
    position: relative;
    font-size: 150%;
    font-weight: bold;
    content: '目次';
}

/*--------------------------------------
  ヨメレバ・カエレバ（レスポンシブ）
--------------------------------------*/
.booklink-box,
.kaerebalink-box {
    overflow: hidden;
    margin-bottom: 10px;
    padding: 25px;
    border: double #ccc;
    font-size: small;
    -webkit-border-radius: 5px;
       -moz-border-radius: 5px;
            border-radius: 5px;
}
.booklink-image,
.kaerebalink-image {
    float: left;
    min-width: 160px;
    margin: 0 15px 0 0;
    text-align: center;
}
.booklink-image img,
.kaerebalink-image img {
    margin: 0 auto;
    text-align: center;
}
.booklink-info,
.kaerebalink-info {
    overflow: hidden;
    margin: 0;
    line-height: 120%;
}
.booklink-name,
.kaerebalink-name {
    margin-bottom: 24px;
    line-height: 1.5em;
}
.booklink-powered-date,
.kaerebalink-powered-date {
    margin-top: 10px;
    font-family: verdana;
    font-size: 8px;
    line-height: 120%;
}
.booklink-detail,
.kaerebalink-detail {
    font-size: 12px;
}
.booklink-powered-date,
.kaerebalink-detail {
    margin-bottom: 15px;
}
.booklink-link2,
.kaerebalink-link1 {
    margin-top: 10px;
}
.booklink-link2 a,
.kaerebalink-link1 a {
    display: inline-block;
    float: left;
    width: 30%;
    margin: 5px 2px 0 0;
    padding: 10px 1px;
    -webkit-border-radius: 5px;
       -moz-border-radius: 5px;
            border-radius: 5px;
    text-shadow: 1px 1px 1px #dcdcdc;
    color: #fff !important;
    font-size: 12px;
    font-weight: 800;
    text-decoration: none;
    text-align: center;
}
.booklink-link2 a:hover,
.kaerebalink-link1 a:hover {
    opacity: .6;
}
.booklink-link2 a:active
.kaerebalink-link1 a:active {
    position: relative;
    top: 1px;
}
.shoplinkamazon a {
    border: 1px solid #ff9901 !important;
    color: #ff9901 !important;
}
.shoplinkrakuten a {
    border: 1px solid #c20004 !important;
    color: #c20004 !important;
}
.shoplinkkindle a {
    border: 1px solid #007dcd !important;
    color: #007dcd !important;
}
.shoplinkkakakucom a {
    border: 1px solid #314995;
    color: #314995 !important;
}
.shoplinkyahoo a {
    border: 1px solid #7b0099 !important;
    color: #7b0099 !important;
}
.shoplinkyahoo img {
    display: none;
}
.shoplinkyahoo a {
    font-size: 10px;
}
.booklink-footer {
    display: none;
}

@media screen and (max-width: 680px) {
    .booklink-box,
    .kaerebalink-box {
        padding: 15px;
    }
    .booklink-image,
    .kaerebalink-image {
        min-width: initial;
        width: 100px !important;
    }
    .booklink-name > a,
    .kaerebalink-name > a {
        font-size: 15px;
        font-weight: bold;
    }
    .booklink-name,
    .kaerebalink-name {
        margin-bottom: 12px;
    }
    .booklink-powered-date,
    .kaerebalink-powered-date {
        margin-top: 5px;
    }
    .booklink-link2 a,
    .kaerebalink-link1 a {
        width: -webkit-calc(100% - 4px) ;
        width:         calc(100% - 4px);
        margin: 2px 0;
        padding: 10px 0;
        -webkit-border-radius: 5px;
           -moz-border-radius: 5px;
                border-radius: 5px;
    }
}

/*アプリーチ*/
#appreach-box {
    margin-bottom: 10px;
    border: double 2px #ececec;
    -webkit-border-radius: 5px;
       -moz-border-radius: 5px;
            border-radius: 5px;
}
.appreach-links {
    margin-bottom: 10px;
}
.appreach-footer {
    margin-bottom: 0;
    line-height: 0;
}

/* </system> */
/*******グローバルナビ********/
.slideButton {
    display: none;
}
#slideMenu {
    position: relative;
    width: 100%;
    height: 40px;
    background-color: #444;/*メニューの背景色*/
}
#slideMenu > .slideMenuInner {
    list-style-type: none;
    width: 960px;/*メニューの横幅を*/
    height: 100%;
    margin: 0 auto;
    padding-left: 0;
}
#slideMenu > .slideMenuInner li {
    position: relative;
    float: left;
    height: 100%;
    text-align: center;
}
#slideMenu > .slideMenuInner > li a {
    display: block;
    position: relative;
    z-index: 2;
    height: 100%;
    padding-right: 20px;/*文字の左の余白*/
    padding-left: 20px;/*文字の右の余白*/
    background-color: #444;/*文字の背景色*/
    color: #fff;/*文字色*/
    font-size: 70%;
    text-decoration: none;
    line-height: 40px;
}
#slideMenu > .slideMenuInner > li:hover a {
    background-color: #555;/*文字の背景色（マウスホバー時）*/
}
/*２階層目*/
#slideMenu > .slideMenuInner > li > ul.second-level {
    visibility: hidden;
    list-style-type: none;
    position: absolute;
    z-index: -1;
    top: 0;
    margin: 0;
    padding-left: 0;
}
#slideMenu > .slideMenuInner > li:hover > ul.second-level {
    visibility: visible;
    z-index: 1;
    top: 40px;
    transition: all .3s;
}
#slideMenu > .slideMenuInner > li:hover > ul.second-level > li {
    width: 200px;
    height: 40px;
    text-align: center;
}
#slideMenu > .slideMenuInner > li:hover > ul.second-level > li > a {
    display: block;
    background-color: #444;/*子メニューの文字の背景色*/
    color: #fff;/*子メニューの文字色*/
    font-size: 70%;
    text-decoration: none;
    line-height: 40px;
}
#slideMenu > .slideMenuInner > li:hover > ul.second-level > li > a:hover {
    background-color: #555;/*子メニューの背景色（マウスホバー時）*/
}
/*２階層目ここまで*/
/******スライドメニュー*******/
@media screen and (max-width:960px) {/*１*/
    #menuButton {
        z-index: 10;
        width: 100%;
        background-color: #444;/*メニューバーの色*/
    }
    #menuButtonInner {
        position: relative;
        width: 100%;
        margin: 0 auto;
        text-align: right;
    }
    .slideButton {
        display: inline-block;
        margin: 5px;
        padding: 8px 15px;
        background-color: #555;/*「MENU」の背景色*/
        color: #fff;/*「MENU」の文字色*/
        font-size: 70%;
        text-decoration: none;
        cursor: pointer;
    }
    #slideMenu {
        overflow-x: hidden;
        overflow-y: auto;
        position: absolute;
        z-index: 20;
        top: 0;
        right: -260px;
        width: 260px;
        height: 100%;
        margin: 0;
        padding: 0;
        box-shadow: 0 8px 17px 0 rgba(0, 0, 0, 0.2);
    }
    #slideMenu > .slideMenuInner {
        position: static;
        width: 100%;
        height: 100%;
    }
    #slideMenu > .slideMenuInner > li {
        display: block;
        position: relative;
        float: none;
        width: 100%;
        height: 40px;
        margin: 0 auto;
        border-top: 1px solid #eee;
        text-align: center;
    }
    #slideMenu > .slideMenuInner > li a {
        display: block;
        position: relative;
        z-index: 1;
        width: 100%;
        height: 100%;
        padding: 0;
        background-color: #fff;/*スライドメニューの背景色*/
        color: #333;/*スライドメニューの文字色*/
        font-size: 70%;
        font-weight: bold;
        line-height: 40px;
    }
    #slideMenu > .slideMenuInner > li:hover a {
        background-color: #fff;/*スライドメニューの背景色（マウスホバー時）*/
        color: #333;/*スライドメニューの文字色（マウスホバー時）*/
    }
    #slideMenu > .slideMenuInner > li > a:active {
        opacity: .8;
    }
    #slideMenu > .slideMenuInner > li:hover > ul.second-level {
        display: none;
    }
    .closeArea {
        height: 100%;
        background-color: #333;/*クローズエリア（スライドメニューの下の部分）の色*/
        cursor: pointer;
    }
    #layer {
        display: none;
        position: fixed;
        z-index: 10;
        top: 0;
        width: 100%;
        height: 150%;
        background-color: #222;/*レイヤーの色*/
        opacity: .4;/*レイヤーの透明度*/
        cursor: pointer;
    }
}
/* <system section="theme" selected="17680117126987827641"> */
@charset "UTF-8";
/*!
  Theme Rosa
  Author: Askthewind's diary
  Responsive: yes
  Description: モバイルファースト最適化済みのはてなブログ用デザインテーマです。
  Breakpoint: Bootstrap compliant.
  License: Released under the GPL.
*/

/* ==========================================================================
/* ! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css
/* Vendor Prefix and IE other than text-size-adjust CSS that removed
/* 備考: IE向け記述と不要なベンダープレフィックスを削除
/* Document ページ全体の基本的な設定
   ========================================================================== */
/**
 * 1. 全ブラウザで行の高さを統一。
 * 2. iOSで画面を回転させた際に、文字サイズが勝手に調整されるのを防ぐ。
 */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections 主要なセクション要素の設定
   ========================================================================== */
/**
 * body要素にデフォルトで設定されている余白（margin）を削除。
 */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
/* h1要素のフォントサイズと余白を、ブラウザ間で差異が出ないように調整。
/* 
 */
/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content グループ化される要素の設定
   ========================================================================== */
/**
 * 1. preタグ（整形済みテキスト）のフォントを等幅フォントに統一し、
 * 2. フォントサイズが他の要素から正しく継承されるように修正。
 */
/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics テキスト関連の要素の設定
   ========================================================================== */
/**
 * title属性を持つabbrタグ（略語など）の下線を点線で表示するように統一。
 */
/**
 * Add the correct text decoration in Chrome, Edge, Opera, and Safari.
 */
abbr[title] {
  text-decoration: underline; 
  text-decoration: underline dotted; 
}

/**
 * bタグとstrongタグ（太字）のフォントの太さを、より太く表示するように統一。
 */
/**
 * Add the correct font weight in Chrome, Edge,and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. code, kbd, sampタグ（コードなど）のフォントを等幅フォントに統一し、
 * 2. フォントサイズが正しく継承されるように修正。
 */
/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * smallタグ（小さい文字）のフォントサイズを親要素の80%に設定。
 */
/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * subタグ（下付き文字）とsupタグ（上付き文字）が、
 * 行の高さ（line-height）に影響を与えないように設定。
 */
/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}

/* Forms フォーム関連の要素の設定
   ========================================================================== */
/**
 * ボタンや入力フォームなどのフォント関連のスタイルを、
 * 親要素から継承するように設定し、表示を統一
 */
/**
 * Change the font styles in all browsers.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; 
  font-size: 100%; 
  line-height: 1.15;
}

/**
 * fieldsetを囲むlegend要素の余白（padding）を削除。
 */
/**
 * Remove the padding so developers are not caught out when they zero out
 * `fieldset` elements in all browsers.
 */
legend {
  padding: 0;
}

/**
 * progress要素（プログレスバー）の縦方向の表示位置を揃える。
 */
/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/* Interactive 操作可能な要素の設定
   ========================================================================== */
/**
 * details要素内で使用されるsummary要素を、
 * リストアイテムとして表示するように統一。
 */
/**
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* End normalize.css v8.0.1
   ========================================================================== */
/* HTML Structure 外枠行順 */
/* @container > container-inner >
====================================== */

/* blog-title */
/* top-editarea */
/* top-box */
/* content > content-inner( 2カラム wrapper - box2 ) */
/* bottom-editarea */

/* containerと同じ外枠 */
/* footer > footer-inner( address - p ) */

/* CSS Document */
/* @*,html,body
====================================== */

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    background-color: hsl(0 0% 95%);
    color: hsl(0 0% 25%);
    font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue",
                 Helvetica, "Inter", Roboto, Arial, "Noto Sans JP", 
                 "Hiragino Sans", Meiryo, "Nimbus Sans L", 
                 "Liberation Sans", "DejaVu Sans", ui-sans-serif, 
                 sans-serif, "Apple Color Emoji", "Segoe UI Variable", 
                 "Segoe UI Emoji", "Noto Color Emoji";
    font-feature-settings: "palt";
    font-size: 1rem;
    line-height: 1.6;
}

/* @img a h*
====================================== */

img {
    vertical-align: top;
}

a {
    color: hsl(188 93% 43%);
    text-decoration: none;
}

a:hover {
    color: hsl(0 0% 46%);
    transition: all .3s;
}

h1, h2, h3, h4, h5, h6,
h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
    color: hsl(213 5% 39%);
    line-height: 1.3;
}

h1 a:hover, h2 a:hover, h3 a:hover, h4 a:hover, h5 a:hover, h6 a:hover {
    color: hsl(0 0% 46%);
    transition: all .6s;
}

/* @strong em
====================================== */

/* ツールバー 太字 */

strong {
    background: linear-gradient(transparent 70%, hsl(25 100% 50% / .5) 70%);
}

/* ツールバー 斜体 */

em {
    background: linear-gradient(transparent 60%, hsl(0 100% 50% / .5) 60%);
}

/* @canvas,svg,select,textarea
====================================== */

canvas,picture,svg,select,textarea {
    max-width: 100%;
}

:where(svg:not([fill])) {
    fill: currentColor;
}

/* ヘッダー */
/* ブログタイトル ブログ説明文 */
/* @blog-title
====================================== */

#blog-title {
    margin: 0 0 70px;
    text-align: center;
}

/* @title
====================================== */

#title {
    color: hsl(0 0% 53%);
    font-size: 1.6rem;
    font-weight: 700;
    margin: 0;
    padding: 50px 5px 5px;
}

@media (min-width: 768px) {
    #title {
        font-size: 1.8rem;
    }
}

@media (min-width: 992px) {
    #title {
        font-size: 2rem;
    }
}

#title a {
    display: block;
}

#title a:hover {
    color: hsl(341 81% 49%);
}

#title a:first-letter {
    color: hsl(0 100% 80%);
}

#title a:hover:first-letter {
    color: hsl(0 100% 70%);
}

/* @blog-description
====================================== */

#blog-description {
    color: hsl(0 0% 25%);
    font-size: .8rem;
    font-weight: 700;
    margin: 0;
}

@media (max-width: 767px) {
    #blog-description {
        display: none;
    }
}

/* @header-image-enable
====================================== */

/* ヘッダ画像を設定したとき */
/* 画像とテキストを表示 */
/* 画像だけ表示  */

.header-image-enable #blog-title,
.header-image-only #blog-title {
    margin: 0 auto 4em;
    padding: 0;
}

.header-image-enable #blog-title #blog-title-inner, 
.header-image-only #blog-title #blog-title-inner {
    background-size: cover;
    height: 20vw!important;
    max-height: 200px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.header-image-enable #blog-title-content,
.header-image-only #blog-title-content {
    margin: 0 .625em;
}

.header-image-enable #title,
.header-image-only #title {
    padding: 0 5px 5px;
}

/* レイアウト 2カラム */
/* @container
====================================== */

#container {
    background-color: hsl(0 0% 100%);
    margin: 0 auto;
    overflow-wrap: break-word;
    padding: 0 20px 40px;
    width: 100%;
}

@media (min-width: 992px) {
    #container {
        max-width: 960px;
        padding: 0 40px 40px;
    }
}

@media (min-width: 1200px) {
    #container {
        max-width: 1100px;
    }
}

/* @content-inner
====================================== */

#content-inner {
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

@media (min-width: 992px) {
    #content-inner {
        flex-direction: row;
    }
}

/* @wrapper,box2
====================================== */

#wrapper,#box2 {
    width: 100%;
}

#wrapper {
    margin-bottom: 40px;
}

#box2 {
    overflow-wrap: anywhere
}

@media (min-width: 992px) {
    #wrapper { 
        width: 68%;
    }
    #box2 {
        width:28%;
    }
}

/* @main
====================================== */

@media (min-width: 992px) {
    #main {
        margin-left: auto;
        padding: 0 30px;
        width: 85%;
    }
}

@media (min-width: 1200px) {
    #main {
        width: 87%;
    }
}

/* ブログタイトル ブログ説明文下 */
/* content枠最下部 */
/* @top-editarea,bottom-editarea
====================================== */

#top-editarea,#bottom-editarea {
    font-size: .9rem;
}

#top-editarea {
    margin: 0 auto 1em;
}

#bottom-editarea {
    margin: 0 auto;
}

#top-editarea ul,#bottom-editarea ul {
    list-style: none;
    margin-block-start: 0;
    margin-block-end: 0;
    padding-inline-start: 0;
}

/* ブログタイトル ブログ説明文下 */
/* @top-box
====================================== */

#top-box {
    margin: 5px 0;
}

@media(max-width: 767px) {
    #top-box {
        display: none;
    }
}

@media (min-width: 768px) {
    #top-box {
        margin: 20px auto;
    }
}

/* @breadcrumb
====================================== */

.breadcrumb {
    font-size: .9rem;
}

@media (min-width: 992px) {
    .breadcrumb {
        padding-left: 120px;
    }
}

.breadcrumb a {
    color: hsl(0 0% 27%);
    padding: 0 0 .3125em;
    position: relative;
}

.breadcrumb a:hover {
    color: hsl(188 93% 43%);
}

.breadcrumb a::before {
    background-color: hsl(0 100% 80%);
    content: "";
    height: 3px;
    position: absolute;
    bottom: 0;
    left: 50%;
    transition: all .25s ease;
    width: 0;
}

.breadcrumb a:hover::before {
    left: 0;
    width: 100%;
}

.breadcrumb-gt:nth-last-of-type(2),
.breadcrumb-child:last-of-type {
    display: none;
}

.breadcrumb-link span::before,
.breadcrumb-child-link span::before {
    font-family: "blogicon";
    vertical-align: 0;
}

.breadcrumb-link span::before {
    content: "\f017";
}

.breadcrumb-child-link span::before {
    content: "\f04a";
    letter-spacing: .3em;
}

/* ポスト メインカラム */
/* @entry
====================================== */

.entry {
    margin-bottom: 5em;
    position: relative;
}

/* @entry-header
====================================== */

.entry-header {
    margin: 0;
    padding: 0 0 .2em;
    position: relative;
}

.entry-header:after {
    background: repeating-linear-gradient(-45deg,
        hsl(175 53% 62% / .9),
        hsl(175 53% 62% / .9) 2px,
        hsl(0 0% 100% / .9) 2px,
        hsl(0 0% 100% / .9) 4px
    );
    content: "";
    height: 7px;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
}

/* @date
====================================== */

.date {
    font-size: .875rem;
    line-height: 35px;
    margin: 0;
}

@media (min-width: 992px) {
    .date { 
        border-right: 1px solid hsl(0 0% 93%);
        position: absolute;
        top: 0;
        left: -122px;
        width: 100px;
    }
    .entry-date time {
        background-color: hsl(0 100% 63%);
        border-radius: 8px;
        color: hsl(0 0% 100%);
        display: block;
        font-size: .875rem;
        font-weight: 700;
        text-align: center;
        width: 90px;
    }
    .entry-date span:nth-of-type(4){
        display: none;
    }
    .entry-date .date-day {
        background-color: hsl(0 100% 80%);
        border-radius: 0 0 8px 8px;
        display: block;
        font-size: 2rem;
    }
}

@media (min-width: 1200px) {
    .date {
        left: -132px;
    }
}

.date-last-updated {
    color: hsl(0 100% 63%);
}

.date-last-updated::before {
    content: "updated";
    font-weight: 600;
    font-style: italic;
}

/* @entry-title
====================================== */

.entry-title {
    font-size: 1.2rem;
    margin: 0 0 1em;
    line-height: 1.4;
    word-break: break-all;
}

.entry-title a {
    position: relative;
}

/* @categories
====================================== */

.categories {
    margin-bottom: 1em;
}

.categories a {
    background: hsl(7 42% 38%) 
        linear-gradient(hsl(7 42% 48%),hsl(7 42% 38%));
    box-shadow: 1px 1px 6px 0 hsl(0 0% 0% / .4);
    color: hsl(0 0% 100%);
    display: inline-block;
    font-size: .6875rem;
    font-weight: 700;
    margin: 0 .2em .4em;
    padding: .4375em .625em;
    outline: 1px dashed hsl(0 0% 100%);
    outline-offset: -5px;
    text-shadow: hsl(6 38% 56%) 1px 1px 1px;
    white-space: nowrap;
}

.categories a:hover {
    background: hsl(204 87% 41%) 
        linear-gradient(hsl(204 87% 51%),hsl(204 87% 41%));
    color: hsl(0 0% 100%);
}

/* @entry-header-menu
====================================== */

/* 編集ボタン */

.entry-header-menu a {
    background-color: hsl(0 0% 33%);
    color: hsl(0 0% 100%);
    font-size: .6875rem;
    font-weight: 700;
    padding: .3125em .625em;
    position: absolute;
    top: 0;
    right: 0;
}

@media (min-width: 992px) {
    .entry-header-menu a {
        top: -35px;
    }
}

.entry-header-menu a::before {
    content: "\f010";
    font-family: "blogicon";
    font-size: 1em;
    letter-spacing: .1em;
}

.entry-header-menu a:hover {
    background-color: hsl(195 100% 44%);
}

/* @entry-header social-buttons
====================================== */

.entry-header .social-buttons {
    margin-top: 1.25rem;
}

@media (min-width: 992px) {
    .entry-header .social-buttons {
        margin-top: 0;
        position: absolute;
        top: 210px;
        left: -122px;
        flex-direction: column;
    }
    .page-index .entry-header .social-buttons {
        top: 100px;
    }
}

@media (min-width: 1200px) {
    .entry-header .social-buttons {
        left: -132px;
    }
}

/* @entry-content a
====================================== */

.entry-content {
    line-height: 1.8;
}

@media (min-width: 768px) {
    .entry-content {
        line-height: 1.9;
    }
}

.entry-content a {
    overflow-wrap: anywhere;
}

/* @entry-content img,video
====================================== */

.entry-content img {
    border: 1px solid hsl(0 0% 82%);
    box-shadow: 0 6px 6px -6px hsl(0 0% 80%);
}

.entry-content video {
    height: auto;
    max-width: 100%;
}

/* @entry-content h*
====================================== */

.entry-content h1 {
    border-bottom: 5px solid hsl(170 100% 32% / .95);
    display: inline-block;
    font-size: 1.5rem;
    margin: 1.5em 0;
    padding: .1em 0 .2em 1.8em;
    position: relative;
}

.entry-content h1::before,
.entry-content h1::after {
    background-color: hsl(170 100% 32% / .95);
    border-radius: 100%;
    content: "";
    position: absolute;
}

.entry-content h1::before {
    height: 18px;
    top: .2em;
    left: .2em;
    width: 18px;
}

.entry-content h1::after {
    height: 13px;
    top: .7em;
    left: .9em;
    width: 13px;
}

.entry-content h2 {
    border-bottom: 3px solid hsl(13 90% 71%);
    font-size: 1.4rem;
    margin: 1.5em 0;
    padding: .4em 0 .8em 1.7em;
    position: relative;
}

.entry-content h2::before,
.entry-content h2::after {
    background-color: hsl(13 90% 71%);
    content: "";
    position: absolute;
}

.entry-content h2::before {
    height: 12px;
    top: .5em;
    left: .5em;
    transform: rotate(45deg);
    width: 12px;
}

.entry-content h2::after {
    height: 8px;
    top: 1.1em;
    left: .2em;
    transform: rotate(15deg); 
    width: 8px;
}

/* ツールバー 大見出し */

.entry-content h3 {
    border-bottom: 3px solid hsl(185 100% 43%);
    font-size: 1.4rem;
    margin: 1.5em 0;
    padding: .4em 0 .8em 1.7em;
    position: relative;
}

.entry-content h3::before,
.entry-content h3::after {
    background-color: hsl(185 100% 43%);
    content: "";
    position: absolute;
}

.entry-content h3::before {
    height: 12px;
    top: .5em;
    left: .5em;
    transform: rotate(45deg);
    width: 12px;
}

.entry-content h3::after {
    height: 8px;
    top: 1.1em;
    left: .2em;
    transform: rotate(15deg); 
    width: 8px;
}

/* ツールバー 中見出し */

.entry-content h4 {
    border-bottom: double 5px hsl(0 100% 80%);
    font-size: 1.4rem;
    margin: 1.5em 0;
    padding-bottom: .8em;
}

/* ツールバー 小見出し */

.entry-content h5 {
    border-bottom: dashed 3px hsl(35 100% 74%);
    font-size: 1.4rem;
    margin: 1.5em 0;
    padding-bottom: .8em;
}

.entry-content h6 {
    border-bottom: dotted 3px hsl(35 100% 74%);
    font-size: 1.4rem;
    margin: 1.5em 0;
    padding-bottom: .8em;
}

/* @entry-see-more
====================================== */

/* ツールバー 続きを読む */

a.entry-see-more {
    background: hsl(158 69% 45%)
        linear-gradient(hsl(158 69% 45%),hsl(158 69% 43%));
    border-radius: 4px;
    box-shadow: 0 3px 0 hsl(0 0% 0% / .01);
    color: hsl(0 0% 100%);
    display: inline-block;
    font-weight: 700;
    height: 40px;
    line-height: 40px;
    margin-top: 1em;  
    text-align: center;
    text-shadow: 0 1px 1px hsl(0 0% 0% / .1);
    transition: all .4s;
    width: 200px;
}

a.entry-see-more:hover {
    opacity: .87;
}

/* @entry-content table-of-contents
====================================== */

/* ツールバー 目次 */

.entry-content ul.table-of-contents {
    background-color: hsl(38 100% 98%);
    border: solid 3px hsl(13 90% 71%);
    border-radius: 10px;
    color: hsl(0 0% 60%);
    font-size: .9rem;
    margin: 2.25em 0 1.5em;
    padding: 1em 2.25em;
    position: relative;
}

.entry-content ul.table-of-contents::before {
    color: hsl(35 100% 74%);
    content: "Contents";
    font-size: 1rem;
    font-weight: 700;
    padding: .625em 0;
}

.entry-content ul.table-of-contents::after {
    color: hsl(0 100% 80%);
    content: "目次";
    font-size: 1rem;
    font-weight: 700;
    opacity: .75;
    position: absolute;
    top: 8px;
    right: 24px;
}

.entry-content .table-of-contents a::after {
    display: none;
}

.entry-content ul.table-of-contents li a,
.entry-content ul.table-of-contents li a:visited {
    color: hsl(0 0% 60%);
}

.entry-content ul.table-of-contents li a:hover {
    color: hsl(0 0% 53%);
}

.entry-content ul.table-of-contents li {
    line-height: 1.5;
    list-style-type: none;
    margin: .3125em 0 .625em .375em;
    padding: 0;
    position: relative;
}

.entry-content ul.table-of-contents li::before {
    color: hsl(197 59% 56%);
    content: "\f727";
    font-family: blogicon;
    position: absolute;
    left: -1.2em;
}

.entry-content ul.table-of-contents li ul li::before {
    color: hsl(0 100% 80%);
}

.entry-content ul.table-of-contents li ul li ul li::before {
    color: hsl(170 100% 32% / .95);
}

.entry-content ul.table-of-contents li ul li ul li ul li::before {
    color: hsl(35 100% 74%);
}

/* @entry-content blockquote
====================================== */

/* ツールバー 引用 */

.entry-content blockquote {
    margin: 1.5em 0;
    padding-inline: 1em;
    position: relative;
}

.entry-content blockquote::before {
    background-color: hsl(180 2% 88%);
    border-radius: 4px;
    content: "";
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
}

.entry-content blockquote p:first-child {
    margin-top: 0;
}

.entry-content blockquote p:last-child {
    margin-bottom: 0;
}

/* @entry-content ul ol dd
====================================== */

/* ツールバー 箇条書き 番号付きリスト */

.entry-content ul,
.entry-content ol,
.entry-content dd {
    margin-bottom: 1em;
    padding: 0;
}

@media (min-width: 1200px) {
    .entry-content ul,
    .entry-content ol,
    .entry-content dd {
        margin-left: 1.5em;
    }
}

.entry-content ul li ul, 
.entry-content ul li ol,
.entry-content ol li ul,
.entry-content ol li ol,
.entry-content dd li ul,
.entry-content dd li ol {
    margin-bottom: 0;
}

/* @entry-content pre code
====================================== */

/* コードブロック */

.entry-content pre, 
.entry-content code,
.entry-content pre > code,
.entry-content pre[class*=lang] {
    font-family: "Fira Code", ui-monospace, Consolas,
                 SFMono-Regular, "SF Mono", Menlo, 
                 "Ubuntu Mono", "Liberation Mono", monospace;
}

.entry-content pre, 
.entry-content code {
    background-color: hsl(0 0% 100% / .9);
    border: 1px solid hsl(0 0% 87%);
    border-radius: .375em;
    font-size: 1em;
    line-height: 1.5;
}

.entry-content pre {
    margin: .5em 0;
    padding: 1em;
    position: relative;
}

.entry-content :not(pre) > code {
    padding: .0625em .25em;
}

.entry-content pre.code {
    padding-top: 2em;
    white-space: pre;
}

.entry-content pre.code::before {
    background-color: hsl(0 100% 80%);
    color: hsl(0 0% 100%);
    content: "Plain text";
    font-size: .875rem;
    font-weight: 500;
    line-height: 1;
    padding: .25rem .5rem;
    position: absolute;
    top: 0;
    left: 0;
}

.entry-content pre.code[class*=lang]::before {
    content: attr(data-lang);
}

/* @entry-content table
====================================== */

.entry-content table {
    border-bottom: 1em;
    border-collapse: collapse;
    border-spacing: 0;
    display: block;
    font-size: .8rem;
    margin-bottom: 1em;
    overflow: auto;
}

@media (min-width: 1200px) {
    .entry-content table {
        font-size: .9rem;
    }
}

.entry-content table th,
.entry-content table td {
    border: 1px solid hsl(0 0% 87%);
    padding: .3125em .625em;
}

.entry-content table th {
    background: hsl(213 71% 92% / .95) 
        linear-gradient(hsl(212 74% 95% / .95),hsl(213 71% 92% / .95));
    box-shadow: 0 1px 0 hsl(0 0% 100% / .8) inset;
}

.entry-content table th:first-child {
    border-radius: 6px 0 0 0;
}

.entry-content table th:last-child {
    border-radius: 0 6px 0 0;
}

.entry-content table th:only-child {
    border-radius: 6px 6px 0 0;
}

.entry-content table tr:last-child td:first-child {
    border-radius: 0 0 0 6px;
}

.entry-content table tr:last-child td:last-child {
    border-radius: 0 0 6px 0;
}

.entry-content table tr:last-child td:only-child {
    border-radius: 0 0 6px 6px;
}

/* @footnote footnote-number
====================================== */

/* ツールバー 脚注 */

.page-index .footnote { 
    display: none;
}

.footnote-number {
    scroll-margin-top: 3.5em;
}

/* @entry-content hr
====================================== */

.entry-content hr {
    border: 0;
    border-top: 8px dotted hsl(0 0% 0% / .1);
    margin: 4.375em auto;
    width: 50%;
}

/* @entry-content hatena-asin-detail
====================================== */

.hatena-asin-detail {
    background-color: hsl(213 28% 19% / .1);
    border: 3px solid hsl(213 28% 19%);
    border-radius: 4px;
    padding: .8em .6em;
    position: relative;
}

@media (min-width: 768px) {
    .hatena-asin-detail {
        padding: .8em 1.5em .8em .6em;
    }
}

.hatena-asin-detail a {
    color: hsl(36 100% 50%);
    
}

@media (min-width: 992px) {
    .hatena-asin-detail::before {
        background-color: hsl(213 28% 19%);
        color: hsl(36 100% 50%);
        content: "\293b";
        font-size: 1.8rem;
        font-weight: 900;
        height: 1.5rem;
        line-height: 2rem;
        position: absolute;
        top: -2px;
        right: -2px;
        text-align: center;
        width: 1.5rem;
        z-index: 1;
    }
    .hatena-asin-detail::after {
        color: hsl(0 0% 100%);
        content: "a";
        font-family: Arial, "Liberation Sans", sans-serif;
        font-size: 1.2rem;
        font-weight: 900;
        height: 1.5rem;
        line-height: 1rem;
        position: absolute;
        top: -2px;
        right: -2px;
        text-align:center;
        width: 1.5rem;
        z-index: 2;
    }
}

.hatena-asin-detail.hatena-rakuten-detail {
    background-color: hsl(0 100% 37% / .1);
    border: 3px solid hsl(0 100% 37%);
}

.hatena-asin-detail.hatena-rakuten-detail a {
    color: hsl(0 100% 37%);
}

@media (min-width: 992px) {
    .hatena-asin-detail.hatena-rakuten-detail::before {
        background-color: hsl(0 100% 37%);
        border-radius: 50%;
        color: hsl(0 0% 100%);
        content: "R";
        font-family: Arial, "Liberation Sans", sans-serif;
        font-size: .875rem;
        font-weight: 600;
        line-height: 1.5rem;
        position: absolute;
        top: 3px;
        right: 4px;
        text-align: center;
    }
    .hatena-asin-detail.hatena-rakuten-detail::after {
        content: none;
    }
}

/* @entry-content cite hatena-citation 
====================================== */

.entry-content cite.hatena-citation a::before {
    content: "\f009";
    font-family: "blogicon";
    letter-spacing: .3em;
    line-height: 1;
    vertical-align: middle;
}

/* ポスト下 */
/* @entry-footer
====================================== */

.entry-footer {
    position: relative;
}

/* @entry-footer social-buttons
====================================== */

.page-index .entry-footer .social-buttons {
    display: none;
}

@media (min-width: 992px) {
    .entry-footer .social-buttons {
        position: absolute;
        top: 0;
        left: -122px;
        flex-direction: column;
    }
}

@media (min-width: 1200px) {
    .entry-footer .social-buttons {
        left: -132px;
    }
}

/* @entry-footer-section
====================================== */

.entry-footer-section,
.entry-footer-section a {
    color: hsl(0 0% 60%);
    font-size: .9rem;
}

.page-index .entry-footer-section {
    display: none;
}

/*@entry-footer entry-footer-time
====================================== */

.entry-footer .entry-footer-time .updated  {
    display: none;
}

/*@entry-footer vcard
====================================== */

.entry-footer .author.vcard::before {
    content: "Author:\00a0";
}

/*@entry-tags-wrapper
====================================== */

.page-index .entry-tags-wrapper {
    display: none;
}

/* @hatena-star-container
====================================== */

.entry-footer .hatena-star-container {
    background-color: hsl(0 0% 99%);
    border-radius: 8px;
    margin: 1.5em 0;
    padding: 1em;
}

.entry-footer .hatena-star-container::before {
    content: "記事が面白かったら★をクリック！（連打できます）";
    display: block;
    font-size: .95rem;
    font-weight: 700;
    margin-bottom: .5em;
}

.page-index .entry-footer .hatena-star-container {
    display: none;
}

/* @ad-online-afc
====================================== */

.ad-online-afc .yads_ad .yads_ad_title,
.touch-afc-block .google_afc_blocklink .visible_url a {
    overflow-wrap: anywhere;
}

/* ポスト下 関連記事 */
/* @main entry-footer-modules
====================================== */

@media (min-width: 576px) {
    #main .entry-footer-modules .hatena-module {
        padding-top: 1em;
    }
    #main .entry-footer-modules .hatena-urllist {
        display: flex;
        flex-wrap: wrap;
        gap: .5em;
    }
    #main .entry-footer-modules .hatena-urllist li {
        border: 1px solid hsl(0 0% 93%);
        border-radius: 2px;
        margin: 0;
        padding: 1em;
        width: 100%;
    }
    #main .entry-footer-modules .hatena-urllist li:nth-of-type(n+2) {
        width: calc( 50% - ( .25em + 1px ) );
    }
    #main .entry-footer-modules .urllist-title-link {
        font-size: .875rem;
        padding-bottom: .5em;
    }
    #main .entry-footer-modules .urllist-entry-body {
        overflow: hidden;
    }
}

@media (min-width: 768px) {
    #main .entry-footer-modules .hatena-urllist {
        flex-direction: column;
    }
    #main .entry-footer-modules .hatena-urllist li:nth-of-type(n+2) {
        width: 100%;
    }
    #main .entry-footer-modules .urllist-title-link {
        font-size: .875rem;
    }
}

/* コメント欄 */
/* @comment-box
====================================== */

.comment-box {
    margin: 1em 0;
}

.page-index .comment-box {
    display: none;
}

/* @comment-box comment
====================================== */

.comment-box .comment {
    font-size: .875rem;
    line-height: 1.7;
    list-style: none;
    margin-block: 1.875rem;
    padding: 0;
}

@media (min-width: 768px) {
    .comment-box .comment {
        font-size: .9375rem;
    }
}

/* @comment-box entry-comment
====================================== */

.comment-box .entry-comment {
    background: linear-gradient(-155deg,
        hsl(0 0% 0% / 0) 1.5em, hsl(0 0% 99%) 0%);
    border-radius: 6px;
    box-shadow: 10px 10px 32px -15px hsl(0 0% 0% / .25);
    margin-bottom: .75em;
    padding: .625em 1.25em .625em 3.75em;
    position: relative;
}

.comment-box .entry-comment::after {
    background: linear-gradient(to left bottom,
        hsl(0 0% 0% / 0) 50%,
        hsl(0 0% 0% / .1) 0%,
        hsl(0 0% 0% / .2)
    );
    border-bottom-left-radius: 6px;
    box-shadow: -.2em .2em .3em -.1em hsl(0 0% 0% / .15);
    content: "";
    height: 3.5493em;
    position: absolute;
    top: 0;
    right: 0;
    transform: translateY(-1.89424em) rotate(-40deg);
    transform-origin: bottom right;
    width: 1.65507em;
}

/* @comment-box read-more-comments
====================================== */

.comment-box .read-more-comments {
    padding: .625em 0;
}

/* @comment-box hatena-id-icon
====================================== */

.comment-box .hatena-id-icon {
    border-radius: 3px;
    height: 50px !important;
    position: absolute;
    top: 10px;
    left: 0;
    width: 50px !important;
}

/* @comment-user-name
====================================== */

.comment-user-name {
    font-weight: 700;
    margin: 0 0 .4em 0;
}

/* @comment-content p img
====================================== */

.comment-content {
    color: hsl(0 0% 25%);
    font-size: .85rem;
    margin: 0 0 .4em 0;
}

.comment-content p {
    margin: 0 0 .6em 0;
}

.comment-content img {
    height: auto;
}

/* @comment-metadata a
====================================== */

.comment-metadata {
    color: hsl(0 0% 53%);
    font-size: .8rem;
    margin: 0;
}

.comment-metadata a {
    color: hsl(0 0% 53%);
}

/* @leave-comment-title
====================================== */

.leave-comment-title {
    border: 1px solid hsl(0 0% 78%);
    border-radius: .5em;
    color: hsl(0 0% 46%);
    font-size: .85rem;
    font-weight: 700;
    margin-top: 1em;
    padding: .6em 1em;
}

.leave-comment-title::before { 
    content: "\f024";
    font-family: "blogicon";
    letter-spacing: .3em;
}

.leave-comment-title:hover {
    color: hsl(225 6% 13%); 
}

/* ページ送りナビ */
/* @pager 
====================================== */

.pager {
    margin: 2em 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

@media (min-width: 768px) {
    .pager {
        flex-direction: row;
    }
}

.pager>* {
    flex: 1;
}

.pager .pager-next a,.pager .pager-prev a {
    background-color: hsl(0 0% 99%);
    border: 1px solid hsl(0 0% 80%);
    border-radius: 4px;
    color: hsl(0 0% 50%);
    cursor: pointer;
    display: block;
    font-size: .975rem;
    font-weight: 500;
    line-height: 1.4;
    padding: .75em 1.25em;
    text-align: center;
    text-overflow: ellipsis;
    transition: all .25s;
    overflow: hidden;
    white-space: nowrap;
}

@media(min-width: 768px) {
    .pager .pager-next a,.pager .pager-prev a {
        font-size: .975rem;
        padding: 1em 1.25em;
    }
}

.pager .pager-next a:hover,.pager .pager-prev a:hover {
    background-color: hsl(0 0% 96%);
    border: 1px solid hsl(0 0% 89%);
    color: hsl(0 0% 48%);
}

/* サイドカラム */
/* @hatena-module
====================================== */

.hatena-module {
    color: hsl(0 0% 46%);
    font-size: .85rem;
    margin-bottom: 3rem;
}

@media (min-width: 768px) {
    .hatena-module {
        font-size: .9rem;
    }
}

/* @hatena-module-title
====================================== */

.hatena-module-title {
    background: hsl(0, 100%, 80%) linear-gradient(
        transparent 8%,
        hsl(0 0% 100% / .5) 8%,
        hsl(0 0% 100% / .5) 12%,
        transparent 12%,
        transparent 88%,
        hsl(0 0% 100% / .5) 88%,
        hsl(0 0% 100% / .5) 92%,
        transparent 92%
    );
    box-shadow:0 1px 2px 0 hsl(0 0% 0% / .2);
    color: hsl(0 0% 100%);
    font-size: 1.125rem;
    line-height: 1.6;
    margin: 0 0 20px;
    padding: 10px 5px;
    position: relative;
    text-align: center;
}

@media (min-width: 1200px) {
    .hatena-module-title {
        margin: 0 -10px 40px;
        transform: rotate(-3deg) skew(-3deg);
    }
}

.hatena-module-title::before,
.hatena-module-title::after {
    border-color: transparent;
    border-style: solid;
    content: "";
    height: 0;
    position: absolute;
    width: 0;
}

.hatena-module-title::before {
    border-bottom-color: hsl(0 50% 60%);
    border-width: 0 0 5px 10px;
    top: -5px;
    left: 0;
}

.hatena-module-title::after {
    border-top-color: hsl(0 50% 60%);
    border-width: 5px 10px 0 0;
    top: 100%;
    right: 0;
}

.hatena-module-title a,
.hatena-module-title a:hover {
    color: hsl(0 0% 100%);
}

.page-archive .hatena-module-title:nth-of-type(1) {
    margin-top: 3rem;
}

/* @hatena-module-profile profile-icon
====================================== */

.hatena-module-profile .profile-icon {
    border: 1px solid hsl(0 0% 93%);
    border-radius: .5em;
    margin: 0 .625em .625em 0;
}

@media (min-width: 768px) and (max-width: 1199px) {
    .hatena-module-profile .profile-icon {
        border-radius: 50%;
    }
}

/* @hatena-module-profile id
====================================== */

.hatena-module-profile .id {
    background-color: hsl(185 100% 43% / .9);
    box-shadow: 0 1px 2px 0 hsl(0 0% 0% / .2),
                30px 0 0 0 hsl(185 100% 43% / .9),
                30px 0 0 0 hsl(185 100% 43% / .9);
    display: inline-block;
    line-height: 2;
    margin-bottom: 1em;
    max-width: 90%;
    padding-left: .5em;
    vertical-align: top;
}

.hatena-module-profile .id a span {
    color: hsl(0 0% 100%);
    font-weight: 700;
    text-shadow: 1px 1px 0 hsl(0 0% 20%);
}

/* @profile-description p
====================================== */

.hatena-module-profile .profile-description {
    margin: .75em 0;
}

.hatena-module-profile .profile-description p {
    font-size: .7rem;
    line-height: 1.5;
    margin: 0 0 .25em;
}

/* @hatena-urllist
====================================== */

.hatena-urllist {
    list-style: none;
    margin: 0;
    padding: 0;
}

.hatena-urllist li {
    border-bottom: 1px solid hsl(0 0% 93%);
    font-weight: 700;
    padding: .7em 0;
}

.hatena-urllist a {
    color: hsl(213 5% 39%);
}

.hatena-urllist a:hover {
    color: hsl(188 93% 43%);
}

/* @urllist-image
====================================== */

.hatena-urllist li .urllist-image {
    border-radius: .5em;
}

/* @urllist-title-link
====================================== */

.hatena-urllist li .urllist-title-link {
    font-size: .925rem; /* .8rem; */
}

@media (min-width: 768px) and (max-width: 1199px) {
    .hatena-urllist li .urllist-title-link {
        font-size: .7rem;
    }
}

/* @hatena-urllist urllist-category-link
====================================== */

.hatena-urllist .urllist-category-link {
    display: inline-block;
    font-size: .7rem;
    padding: .1em .3em;
}

.hatena-urllist .urllist-category-link:first-of-type,
.hatena-urllist .urllist-category-link:nth-of-type(5n+1) {
    color: hsl(185 99% 27%);
}

.hatena-urllist .urllist-category-link:nth-of-type(2),
.hatena-urllist .urllist-category-link:nth-of-type(5n+2) {
    color: hsl(326 37% 44%); 
}

.hatena-urllist .urllist-category-link:nth-of-type(3),
.hatena-urllist .urllist-category-link:nth-of-type(5n+3) {
    color: hsl(49 89% 33%); 
}

.hatena-urllist .urllist-category-link:nth-of-type(4),
.hatena-urllist .urllist-category-link:nth-of-type(5n+4) {
    color: hsl(28 53% 39%);
}

.hatena-urllist .urllist-category-link:nth-of-type(5),
.hatena-urllist .urllist-category-link:nth-of-type(5n) {
    color: hsl(355 52% 60%);
}

.hatena-urllist .urllist-category-link::before {
    content: "\f04a";
    font-family: "blogicon";
    font-size: .85em;
    letter-spacing: .2em;
}

.hatena-urllist .urllist-category-link:hover {
    opacity: .7;
}

/* @hatena-urllist urllist-date-link
====================================== */

.hatena-urllist .urllist-date-link a {
    color: hsl(0 0% 60%);
}

.hatena-urllist .urllist-date-link a::before {
    content: "\f043";
    font-family: "blogicon";
    font-size: .95em;
    letter-spacing: .1em;
}

/* @urllist-entry-body 
====================================== */

.urllist-entry-body {
    margin-top: .3em;
}

.hatena-module .hatena-urllist li:nth-of-type(n+2) .urllist-entry-body {
    display: none;
}

/* @hatena-module-search-box
====================================== */

.search-form {
    border: 1px solid hsl(0 0% 95%);
    border-radius: 4px; 
    height: 40px;
    position: relative;
    width: 100%;  
}


.search-form .search-module-input {
    background: none;
    border: none;
    font-size: .9rem;
    height: 20px;
    outline: none;
    margin: auto 0;
    opacity: .87;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    text-indent: .5em;
    width: calc(100% - (.5em + 50px)); 
}

.search-form .search-module-button {
    background-color: hsl(0 0% 33%);
    border: none;
    border-radius: 0 4px 4px 0;
    color: hsl(0 0% 100%);
    cursor: pointer;
    font-size: .9rem;
    height: 100%;
    outline: none;
    position: absolute;
    top: 0;
    right: 0;
    width: 50px;
}

.search-form .search-module-button:hover {
    background-color: hsl(188 93% 43%);
}

/* @entries-access-ranking
====================================== */

.entries-access-ranking {
    counter-reset: rank;
}

.entries-access-ranking li {
    margin: .7em 0;
    padding: 0;
    position: relative;
}

.entries-access-ranking li::before {
    border-radius: 50%;
    color: hsl(0 0% 100%);
    content: counter(rank);
    counter-increment: rank;
    display: block;
    font-size: .8125rem;
    font-weight: 700;
    height: 20px;
    line-height: 20px;
    position: absolute;
    top: 0;
    left: 0;
    text-align: center;
    width: 20px;
}

.entries-access-ranking li:nth-of-type(1)::before {
    background-color: hsl(40 100% 55% / .95);
}

.entries-access-ranking li:nth-of-type(2)::before {
    background-color: hsl(0 0% 54% / .95);
}

.entries-access-ranking li:nth-of-type(3)::before {
    background-color: hsl(30 30% 50% / .95);
}

.entries-access-ranking li:nth-of-type(n+4)::before {
    background-color: hsl(120 100% 50% / .95);
}

.entries-access-ranking li:nth-of-type(n+9)::before {
    background-color: hsl(0 0% 25% / .95); 
}

.entries-access-ranking .urllist-date-link {
    margin-left: 2.75em; 
}

.entries-access-ranking .urllist-title-link {
    display: inline-block;
    margin-left: 2.5em; 
}

.entries-access-ranking .urllist-image-link+.urllist-date-link,
.entries-access-ranking .urllist-image-link+.urllist-title-link,
.entries-access-ranking .urllist-image-link+.urllist-date-link+.urllist-title-link {
    margin-left: 0;
}

.entries-access-ranking .urllist-image-link+.urllist-title-link,
.entries-access-ranking .urllist-image-link+.urllist-date-link+.urllist-title-link {
    display: inline;
}

/* @hatena-module-category
====================================== */

.hatena-module-category .hatena-urllist li {
    padding: 0;
}

.hatena-module-category .hatena-urllist li a {
    display: block;
    padding: .5em;
}

.hatena-module-category .hatena-urllist li a:hover {
    background-color: hsl(25 22% 65%);
    color: hsl(0 0% 100%);
}

/* @hatena-module-html
====================================== */

.hatena-module-html p {
    margin: 0;
}

.hatena-module-html ul {
    list-style: none;
    margin-block: 0;
    padding-inline-start: 0;
}

.hatena-module-html video,
.hatena-module-html iframe {
    max-width: 100%;
}

.hatena-module-html video {
    height: auto;
}

/* @hatena-module-circles
====================================== */

.hatena-module-circles .hatena-urllist li {
    padding: 1em;
}

.hatena-module-circles .hatena-urllist li:hover {
    background-color: hsl(0 0% 97%);
}

/* @circle-urllist circle-image
====================================== */

.hatena-module-body .circle-urllist .circle-image { 
    margin-left: .3125em;
}

.hatena-module-body .circle-urllist li .circle-image {
    outline: 2px solid transparent;
}

.hatena-module-body .circle-urllist li:hover .circle-image {
    outline: 2px solid hsl(0 0% 87%);
}  

/* @archive-module-button
====================================== */

.archive-module-button {
    color: hsl(35 84% 62%);
}

/* @archive-module-months
====================================== */

ul.archive-module-months li a {
    display: block;
    overflow: hidden;
    padding-left: 1.25em;
    position: relative;
}

ul.archive-module-months li a::before {
    border-color: transparent transparent transparent hsl(188 93% 43%);
    border-style: solid;
    border-width: 4.5px 0 4.5px 6px;
    content: "";
    display: block;
    height: 0;
    position: absolute;
    top: calc(-5px + 50%);
    left: -7px;
    transition: left .35s;
    width: 0;
}

ul.archive-module-months li a:hover::before {
    left: 8px;
}

/* @archive-module-calendar
====================================== */

.hatena-module .archive-module-calendar,
.hatena-module .archive-module-calendar a {
    color: hsl(0 0% 46%);
}

.hatena-module .archive-module-calendar a {
    text-decoration: underline;
}

.hatena-module .calendar-sunday,
.hatena-module .archive-module-calendar-week td:first-of-type,
.hatena-module .archive-module-calendar-week td:first-of-type a {
    color: hsl(16 100% 50%);
}

.hatena-module .calendar-saturday,
.hatena-module .archive-module-calendar-week td:nth-of-type(7),
.hatena-module .archive-module-calendar-week td:nth-of-type(7) a {
    color: hsl(188 100% 50%);
}

.hatena-module .archive-module-calendar a:hover,
.hatena-module .archive-module-calendar-week td:first-of-type a:hover,
.hatena-module .archive-module-calendar-week td:nth-of-type(7) a:hover {
    opacity: .7;
}

/* @recent-comments
====================================== */

.recent-comments,
.recent-comments .user-id img {
    overflow-wrap: anywhere;
}

/* aboutページ編集 */
/* @page-about entry-content dt dd
====================================== */

.page-about .entry-content dt { 
    font-size: 1rem;
    font-weight: 700;
}

.page-about .entry-content dd {
    margin-bottom: 1.875em;
    margin-left: 0;
}

/* アーカイブページ */
/* @page-archive top-box
====================================== */

.page-archive #top-box {
    margin: 0;
}

/* @page-archive breadcrumb
====================================== */

.page-archive .breadcrumb {
    display: none;
}

/* @page-archive main
====================================== */

.page-archive #main {
    margin-left: 0;
    padding-left: 0;
    width: 100%;
}

/* @archive-header-category
====================================== */

.archive-header-category {
    margin-bottom: 1.5em;
}

/* @archive-heading
====================================== */

.archive-header-category .archive-heading {
    margin-bottom: 0;
}

.archive-header-category .archive-heading::before {
    content: "Category:";
    margin-right: .2em;
} 

/* @archive-entries
====================================== */

.page-archive .archive-entries {
    display: flex;
    flex-direction: column;
    gap: 1em 0;
}

@media (min-width: 576px) {
    .page-archive .archive-entries {
        flex-flow: row wrap;
        justify-content: space-between;
    }
}

/* @page-archive archive-entry
====================================== */

.page-archive .archive-entry {
    border: 1px solid hsl(0 0% 95%);
    padding: .625em;
    position: relative;
    word-break: break-all;
    display: flex;
    flex-direction: column;
}

@media (min-width: 576px) {
    .page-archive .archive-entry {
        width: calc(50% - .5em);
    }
}

/* @page-archive entry-thumb-link
====================================== */

.page-archive .archive-entry .entry-thumb-link {
    order: 0;
    overflow: hidden;
}

/* @page-archive entry-thumb
====================================== */

.page-archive .archive-entry .entry-thumb {
    aspect-ratio: 16 / 9;
    border-radius: 5px;
    float: none;
    height: auto;
    margin-right: 0;
    transition: .4s ease-in-out;
    width: 100%;
}

.page-archive .archive-entry .entry-thumb:hover {
    background-color: hsl(0 0% 0% / .08);
    opacity: .55;
    transform: scale(1.3);
}

/* @archive-entry-header
====================================== */

.archive-entry .archive-entry-header {
    margin-top: .5em;
    order: 1;
    display: flex;
    flex-direction: column-reverse;
}

/* @archive-entry-header entry-title
====================================== */

.archive-entry .archive-entry-header .entry-title {
    font-size: 1rem;
    margin-bottom: .5em;
}

/* @archive-entry-header date
====================================== */

.archive-entry .archive-entry-header .date {
    font-size: .8rem;
    font-weight: 700;
    line-height: inherit;
    margin-bottom: .5em;
    position: static;
}

.archive-entry .archive-entry-header .date a,
.archive-entry .archive-entry-header .date a:hover {
    color: hsl(0 0% 60%);
}

/* @page-archive archive-entry-body
====================================== */

.page-archive .archive-entry .archive-entry-body {
    order: 2;
}

/* @page-archive date after
====================================== */

.page-archive .date .hyphen { 
    display: none;
}

.page-archive .date .date-year::after,
.page-archive .date .date-month::after { 
    content: ".";
}

/* @page-archive categories
====================================== */

.page-archive .archive-entry .categories {
    display: none;
    /* order: 3; */
}

.page-archive .archive-entry .categories a {
    font-size: .7rem;
}

/* @page-archive entry-description
====================================== */

.archive-entry .archive-entry-body .entry-description {
    /* color: hsl(213 5% 39%); */
    display: none;
    /* font-weight: 600; */
    /* font-size: .8rem; */
    /* margin: 0; */
}

/* @page-archive social-buttons
====================================== */

.archive-entry .archive-entry-body .social-buttons {
    display: none;
    /* margin: .3em 0 1em; */
}

/* @page-archive span highlight 
====================================== */

.page-archive span.highlight {
    background-color: hsl(41 100% 48% / .15);
    border: 1px solid hsl(41 100% 48% / .16);
    color: hsl(41 100% 48%);
    line-height: 1;
    padding: 0;   
}

/* @archive-entry-tags-wrapper
====================================== */

.page-archive .archive-entry-tags-wrapper {
    display: none;
}

/* @page-archive search-result-button
====================================== */

.search-result-form .search-result-button {
    top: 50%;
    transform: translateY(-50%);
}

/* フッター */
/* @footer
====================================== */

#footer {
    color: hsl(0 0% 0% / .54);
    font-size: .8rem;
    margin: 0 auto;
    padding: 2em 0;
    text-align: center;
    width: 96%;
    display: flex;
    align-items: center;
    justify-content: center;
}

@media (min-width: 768px) {
    #footer {
        padding: .625em 4%; 
    }
}

@media (min-width: 992px) {
    #footer {
        max-width: 960px;
    }
}

@media (min-width: 1200px) {
    #footer {
        max-width: 1100px;
    }
}

#footer a,
#footer a:hover {
    color: hsl(0 0% 0% / .54);
}

#footer p {
    margin: .5em auto;
}

#footer address img {
    display: inline-block;
}

/* @footer End
====================================== */

/* End system
   ========================================================================== */
/* </system> */
/* <system section="theme" selected="17680117126987827641"> */
@charset "UTF-8";
/*!
  Theme Rosa
  Author: Askthewind's diary
  Responsive: yes
  Description: モバイルファースト最適化済みのはてなブログ用デザインテーマです。
  Breakpoint: Bootstrap compliant.
  License: Released under the GPL.
*/

/* ==========================================================================
/* ! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css
/* Vendor Prefix and IE other than text-size-adjust CSS that removed
/* 備考: IE向け記述と不要なベンダープレフィックスを削除
/* Document ページ全体の基本的な設定
   ========================================================================== */
/**
 * 1. 全ブラウザで行の高さを統一。
 * 2. iOSで画面を回転させた際に、文字サイズが勝手に調整されるのを防ぐ。
 */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections 主要なセクション要素の設定
   ========================================================================== */
/**
 * body要素にデフォルトで設定されている余白（margin）を削除。
 */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
/* h1要素のフォントサイズと余白を、ブラウザ間で差異が出ないように調整。
/* 
 */
/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content グループ化される要素の設定
   ========================================================================== */
/**
 * 1. preタグ（整形済みテキスト）のフォントを等幅フォントに統一し、
 * 2. フォントサイズが他の要素から正しく継承されるように修正。
 */
/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics テキスト関連の要素の設定
   ========================================================================== */
/**
 * title属性を持つabbrタグ（略語など）の下線を点線で表示するように統一。
 */
/**
 * Add the correct text decoration in Chrome, Edge, Opera, and Safari.
 */
abbr[title] {
  text-decoration: underline; 
  text-decoration: underline dotted; 
}

/**
 * bタグとstrongタグ（太字）のフォントの太さを、より太く表示するように統一。
 */
/**
 * Add the correct font weight in Chrome, Edge,and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. code, kbd, sampタグ（コードなど）のフォントを等幅フォントに統一し、
 * 2. フォントサイズが正しく継承されるように修正。
 */
/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * smallタグ（小さい文字）のフォントサイズを親要素の80%に設定。
 */
/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * subタグ（下付き文字）とsupタグ（上付き文字）が、
 * 行の高さ（line-height）に影響を与えないように設定。
 */
/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}

/* Forms フォーム関連の要素の設定
   ========================================================================== */
/**
 * ボタンや入力フォームなどのフォント関連のスタイルを、
 * 親要素から継承するように設定し、表示を統一
 */
/**
 * Change the font styles in all browsers.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; 
  font-size: 100%; 
  line-height: 1.15;
}

/**
 * fieldsetを囲むlegend要素の余白（padding）を削除。
 */
/**
 * Remove the padding so developers are not caught out when they zero out
 * `fieldset` elements in all browsers.
 */
legend {
  padding: 0;
}

/**
 * progress要素（プログレスバー）の縦方向の表示位置を揃える。
 */
/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/* Interactive 操作可能な要素の設定
   ========================================================================== */
/**
 * details要素内で使用されるsummary要素を、
 * リストアイテムとして表示するように統一。
 */
/**
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* End normalize.css v8.0.1
   ========================================================================== */
/* HTML Structure 外枠行順 */
/* @container > container-inner >
====================================== */

/* blog-title */
/* top-editarea */
/* top-box */
/* content > content-inner( 2カラム wrapper - box2 ) */
/* bottom-editarea */

/* containerと同じ外枠 */
/* footer > footer-inner( address - p ) */

/* CSS Document */
/* @*,html,body
====================================== */

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    background-color: hsl(0 0% 95%);
    color: hsl(0 0% 25%);
    font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue",
                 Helvetica, "Inter", Roboto, Arial, "Noto Sans JP", 
                 "Hiragino Sans", Meiryo, "Nimbus Sans L", 
                 "Liberation Sans", "DejaVu Sans", ui-sans-serif, 
                 sans-serif, "Apple Color Emoji", "Segoe UI Variable", 
                 "Segoe UI Emoji", "Noto Color Emoji";
    font-feature-settings: "palt";
    font-size: 1rem;
    line-height: 1.6;
}

/* @img a h*
====================================== */

img {
    vertical-align: top;
}

a {
    color: hsl(188 93% 43%);
    text-decoration: none;
}

a:hover {
    color: hsl(0 0% 46%);
    transition: all .3s;
}

h1, h2, h3, h4, h5, h6,
h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
    color: hsl(213 5% 39%);
    line-height: 1.3;
}

h1 a:hover, h2 a:hover, h3 a:hover, h4 a:hover, h5 a:hover, h6 a:hover {
    color: hsl(0 0% 46%);
    transition: all .6s;
}

/* @strong em
====================================== */

/* ツールバー 太字 */

strong {
    background: linear-gradient(transparent 70%, hsl(25 100% 50% / .5) 70%);
}

/* ツールバー 斜体 */

em {
    background: linear-gradient(transparent 60%, hsl(0 100% 50% / .5) 60%);
}

/* @canvas,svg,select,textarea
====================================== */

canvas,picture,svg,select,textarea {
    max-width: 100%;
}

:where(svg:not([fill])) {
    fill: currentColor;
}

/* ヘッダー */
/* ブログタイトル ブログ説明文 */
/* @blog-title
====================================== */

#blog-title {
    margin: 0 0 70px;
    text-align: center;
}

/* @title
====================================== */

#title {
    color: hsl(0 0% 53%);
    font-size: 1.6rem;
    font-weight: 700;
    margin: 0;
    padding: 50px 5px 5px;
}

@media (min-width: 768px) {
    #title {
        font-size: 1.8rem;
    }
}

@media (min-width: 992px) {
    #title {
        font-size: 2rem;
    }
}

#title a {
    display: block;
}

#title a:hover {
    color: hsl(341 81% 49%);
}

#title a:first-letter {
    color: hsl(0 100% 80%);
}

#title a:hover:first-letter {
    color: hsl(0 100% 70%);
}

/* @blog-description
====================================== */

#blog-description {
    color: hsl(0 0% 25%);
    font-size: .8rem;
    font-weight: 700;
    margin: 0;
}

@media (max-width: 767px) {
    #blog-description {
        display: none;
    }
}

/* @header-image-enable
====================================== */

/* ヘッダ画像を設定したとき */
/* 画像とテキストを表示 */
/* 画像だけ表示  */

.header-image-enable #blog-title,
.header-image-only #blog-title {
    margin: 0 auto 4em;
    padding: 0;
}

.header-image-enable #blog-title #blog-title-inner, 
.header-image-only #blog-title #blog-title-inner {
    background-size: cover;
    height: 20vw!important;
    max-height: 200px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.header-image-enable #blog-title-content,
.header-image-only #blog-title-content {
    margin: 0 .625em;
}

.header-image-enable #title,
.header-image-only #title {
    padding: 0 5px 5px;
}

/* レイアウト 2カラム */
/* @container
====================================== */

#container {
    background-color: hsl(0 0% 100%);
    margin: 0 auto;
    overflow-wrap: break-word;
    padding: 0 20px 40px;
    width: 100%;
}

@media (min-width: 992px) {
    #container {
        max-width: 960px;
        padding: 0 40px 40px;
    }
}

@media (min-width: 1200px) {
    #container {
        max-width: 1100px;
    }
}

/* @content-inner
====================================== */

#content-inner {
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

@media (min-width: 992px) {
    #content-inner {
        flex-direction: row;
    }
}

/* @wrapper,box2
====================================== */

#wrapper,#box2 {
    width: 100%;
}

#wrapper {
    margin-bottom: 40px;
}

#box2 {
    overflow-wrap: anywhere
}

@media (min-width: 992px) {
    #wrapper { 
        width: 68%;
    }
    #box2 {
        width:28%;
    }
}

/* @main
====================================== */

@media (min-width: 992px) {
    #main {
        margin-left: auto;
        padding: 0 30px;
        width: 85%;
    }
}

@media (min-width: 1200px) {
    #main {
        width: 87%;
    }
}

/* ブログタイトル ブログ説明文下 */
/* content枠最下部 */
/* @top-editarea,bottom-editarea
====================================== */

#top-editarea,#bottom-editarea {
    font-size: .9rem;
}

#top-editarea {
    margin: 0 auto 1em;
}

#bottom-editarea {
    margin: 0 auto;
}

#top-editarea ul,#bottom-editarea ul {
    list-style: none;
    margin-block-start: 0;
    margin-block-end: 0;
    padding-inline-start: 0;
}

/* ブログタイトル ブログ説明文下 */
/* @top-box
====================================== */

#top-box {
    margin: 5px 0;
}

@media(max-width: 767px) {
    #top-box {
        display: none;
    }
}

@media (min-width: 768px) {
    #top-box {
        margin: 20px auto;
    }
}

/* @breadcrumb
====================================== */

.breadcrumb {
    font-size: .9rem;
}

@media (min-width: 992px) {
    .breadcrumb {
        padding-left: 120px;
    }
}

.breadcrumb a {
    color: hsl(0 0% 27%);
    padding: 0 0 .3125em;
    position: relative;
}

.breadcrumb a:hover {
    color: hsl(188 93% 43%);
}

.breadcrumb a::before {
    background-color: hsl(0 100% 80%);
    content: "";
    height: 3px;
    position: absolute;
    bottom: 0;
    left: 50%;
    transition: all .25s ease;
    width: 0;
}

.breadcrumb a:hover::before {
    left: 0;
    width: 100%;
}

.breadcrumb-gt:nth-last-of-type(2),
.breadcrumb-child:last-of-type {
    display: none;
}

.breadcrumb-link span::before,
.breadcrumb-child-link span::before {
    font-family: "blogicon";
    vertical-align: 0;
}

.breadcrumb-link span::before {
    content: "\f017";
}

.breadcrumb-child-link span::before {
    content: "\f04a";
    letter-spacing: .3em;
}

/* ポスト メインカラム */
/* @entry
====================================== */

.entry {
    margin-bottom: 5em;
    position: relative;
}

/* @entry-header
====================================== */

.entry-header {
    margin: 0;
    padding: 0 0 .2em;
    position: relative;
}

.entry-header:after {
    background: repeating-linear-gradient(-45deg,
        hsl(175 53% 62% / .9),
        hsl(175 53% 62% / .9) 2px,
        hsl(0 0% 100% / .9) 2px,
        hsl(0 0% 100% / .9) 4px
    );
    content: "";
    height: 7px;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
}

/* @date
====================================== */

.date {
    font-size: .875rem;
    line-height: 35px;
    margin: 0;
}

@media (min-width: 992px) {
    .date { 
        border-right: 1px solid hsl(0 0% 93%);
        position: absolute;
        top: 0;
        left: -122px;
        width: 100px;
    }
    .entry-date time {
        background-color: hsl(0 100% 63%);
        border-radius: 8px;
        color: hsl(0 0% 100%);
        display: block;
        font-size: .875rem;
        font-weight: 700;
        text-align: center;
        width: 90px;
    }
    .entry-date span:nth-of-type(4){
        display: none;
    }
    .entry-date .date-day {
        background-color: hsl(0 100% 80%);
        border-radius: 0 0 8px 8px;
        display: block;
        font-size: 2rem;
    }
}

@media (min-width: 1200px) {
    .date {
        left: -132px;
    }
}

.date-last-updated {
    color: hsl(0 100% 63%);
}

.date-last-updated::before {
    content: "updated";
    font-weight: 600;
    font-style: italic;
}

/* @entry-title
====================================== */

.entry-title {
    font-size: 1.2rem;
    margin: 0 0 1em;
    line-height: 1.4;
    word-break: break-all;
}

.entry-title a {
    position: relative;
}

/* @categories
====================================== */

.categories {
    margin-bottom: 1em;
}

.categories a {
    background: hsl(7 42% 38%) 
        linear-gradient(hsl(7 42% 48%),hsl(7 42% 38%));
    box-shadow: 1px 1px 6px 0 hsl(0 0% 0% / .4);
    color: hsl(0 0% 100%);
    display: inline-block;
    font-size: .6875rem;
    font-weight: 700;
    margin: 0 .2em .4em;
    padding: .4375em .625em;
    outline: 1px dashed hsl(0 0% 100%);
    outline-offset: -5px;
    text-shadow: hsl(6 38% 56%) 1px 1px 1px;
    white-space: nowrap;
}

.categories a:hover {
    background: hsl(204 87% 41%) 
        linear-gradient(hsl(204 87% 51%),hsl(204 87% 41%));
    color: hsl(0 0% 100%);
}

/* @entry-header-menu
====================================== */

/* 編集ボタン */

.entry-header-menu a {
    background-color: hsl(0 0% 33%);
    color: hsl(0 0% 100%);
    font-size: .6875rem;
    font-weight: 700;
    padding: .3125em .625em;
    position: absolute;
    top: 0;
    right: 0;
}

@media (min-width: 992px) {
    .entry-header-menu a {
        top: -35px;
    }
}

.entry-header-menu a::before {
    content: "\f010";
    font-family: "blogicon";
    font-size: 1em;
    letter-spacing: .1em;
}

.entry-header-menu a:hover {
    background-color: hsl(195 100% 44%);
}

/* @entry-header social-buttons
====================================== */

.entry-header .social-buttons {
    margin-top: 1.25rem;
}

@media (min-width: 992px) {
    .entry-header .social-buttons {
        margin-top: 0;
        position: absolute;
        top: 210px;
        left: -122px;
        flex-direction: column;
    }
    .page-index .entry-header .social-buttons {
        top: 100px;
    }
}

@media (min-width: 1200px) {
    .entry-header .social-buttons {
        left: -132px;
    }
}

/* @entry-content a
====================================== */

.entry-content {
    line-height: 1.8;
}

@media (min-width: 768px) {
    .entry-content {
        line-height: 1.9;
    }
}

.entry-content a {
    overflow-wrap: anywhere;
}

/* @entry-content img,video
====================================== */

.entry-content img {
    border: 1px solid hsl(0 0% 82%);
    box-shadow: 0 6px 6px -6px hsl(0 0% 80%);
}

.entry-content video {
    height: auto;
    max-width: 100%;
}

/* @entry-content h*
====================================== */

.entry-content h1 {
    border-bottom: 5px solid hsl(170 100% 32% / .95);
    display: inline-block;
    font-size: 1.5rem;
    margin: 1.5em 0;
    padding: .1em 0 .2em 1.8em;
    position: relative;
}

.entry-content h1::before,
.entry-content h1::after {
    background-color: hsl(170 100% 32% / .95);
    border-radius: 100%;
    content: "";
    position: absolute;
}

.entry-content h1::before {
    height: 18px;
    top: .2em;
    left: .2em;
    width: 18px;
}

.entry-content h1::after {
    height: 13px;
    top: .7em;
    left: .9em;
    width: 13px;
}

.entry-content h2 {
    border-bottom: 3px solid hsl(13 90% 71%);
    font-size: 1.4rem;
    margin: 1.5em 0;
    padding: .4em 0 .8em 1.7em;
    position: relative;
}

.entry-content h2::before,
.entry-content h2::after {
    background-color: hsl(13 90% 71%);
    content: "";
    position: absolute;
}

.entry-content h2::before {
    height: 12px;
    top: .5em;
    left: .5em;
    transform: rotate(45deg);
    width: 12px;
}

.entry-content h2::after {
    height: 8px;
    top: 1.1em;
    left: .2em;
    transform: rotate(15deg); 
    width: 8px;
}

/* ツールバー 大見出し */

.entry-content h3 {
    border-bottom: 3px solid hsl(185 100% 43%);
    font-size: 1.4rem;
    margin: 1.5em 0;
    padding: .4em 0 .8em 1.7em;
    position: relative;
}

.entry-content h3::before,
.entry-content h3::after {
    background-color: hsl(185 100% 43%);
    content: "";
    position: absolute;
}

.entry-content h3::before {
    height: 12px;
    top: .5em;
    left: .5em;
    transform: rotate(45deg);
    width: 12px;
}

.entry-content h3::after {
    height: 8px;
    top: 1.1em;
    left: .2em;
    transform: rotate(15deg); 
    width: 8px;
}

/* ツールバー 中見出し */

.entry-content h4 {
    border-bottom: double 5px hsl(0 100% 80%);
    font-size: 1.4rem;
    margin: 1.5em 0;
    padding-bottom: .8em;
}

/* ツールバー 小見出し */

.entry-content h5 {
    border-bottom: dashed 3px hsl(35 100% 74%);
    font-size: 1.4rem;
    margin: 1.5em 0;
    padding-bottom: .8em;
}

.entry-content h6 {
    border-bottom: dotted 3px hsl(35 100% 74%);
    font-size: 1.4rem;
    margin: 1.5em 0;
    padding-bottom: .8em;
}

/* @entry-see-more
====================================== */

/* ツールバー 続きを読む */

a.entry-see-more {
    background: hsl(158 69% 45%)
        linear-gradient(hsl(158 69% 45%),hsl(158 69% 43%));
    border-radius: 4px;
    box-shadow: 0 3px 0 hsl(0 0% 0% / .01);
    color: hsl(0 0% 100%);
    display: inline-block;
    font-weight: 700;
    height: 40px;
    line-height: 40px;
    margin-top: 1em;  
    text-align: center;
    text-shadow: 0 1px 1px hsl(0 0% 0% / .1);
    transition: all .4s;
    width: 200px;
}

a.entry-see-more:hover {
    opacity: .87;
}

/* @entry-content table-of-contents
====================================== */

/* ツールバー 目次 */

.entry-content ul.table-of-contents {
    background-color: hsl(38 100% 98%);
    border: solid 3px hsl(13 90% 71%);
    border-radius: 10px;
    color: hsl(0 0% 60%);
    font-size: .9rem;
    margin: 2.25em 0 1.5em;
    padding: 1em 2.25em;
    position: relative;
}

.entry-content ul.table-of-contents::before {
    color: hsl(35 100% 74%);
    content: "Contents";
    font-size: 1rem;
    font-weight: 700;
    padding: .625em 0;
}

.entry-content ul.table-of-contents::after {
    color: hsl(0 100% 80%);
    content: "目次";
    font-size: 1rem;
    font-weight: 700;
    opacity: .75;
    position: absolute;
    top: 8px;
    right: 24px;
}

.entry-content .table-of-contents a::after {
    display: none;
}

.entry-content ul.table-of-contents li a,
.entry-content ul.table-of-contents li a:visited {
    color: hsl(0 0% 60%);
}

.entry-content ul.table-of-contents li a:hover {
    color: hsl(0 0% 53%);
}

.entry-content ul.table-of-contents li {
    line-height: 1.5;
    list-style-type: none;
    margin: .3125em 0 .625em .375em;
    padding: 0;
    position: relative;
}

.entry-content ul.table-of-contents li::before {
    color: hsl(197 59% 56%);
    content: "\f727";
    font-family: blogicon;
    position: absolute;
    left: -1.2em;
}

.entry-content ul.table-of-contents li ul li::before {
    color: hsl(0 100% 80%);
}

.entry-content ul.table-of-contents li ul li ul li::before {
    color: hsl(170 100% 32% / .95);
}

.entry-content ul.table-of-contents li ul li ul li ul li::before {
    color: hsl(35 100% 74%);
}

/* @entry-content blockquote
====================================== */

/* ツールバー 引用 */

.entry-content blockquote {
    margin: 1.5em 0;
    padding-inline: 1em;
    position: relative;
}

.entry-content blockquote::before {
    background-color: hsl(180 2% 88%);
    border-radius: 4px;
    content: "";
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
}

.entry-content blockquote p:first-child {
    margin-top: 0;
}

.entry-content blockquote p:last-child {
    margin-bottom: 0;
}

/* @entry-content ul ol dd
====================================== */

/* ツールバー 箇条書き 番号付きリスト */

.entry-content ul,
.entry-content ol,
.entry-content dd {
    margin-bottom: 1em;
    padding: 0;
}

@media (min-width: 1200px) {
    .entry-content ul,
    .entry-content ol,
    .entry-content dd {
        margin-left: 1.5em;
    }
}

.entry-content ul li ul, 
.entry-content ul li ol,
.entry-content ol li ul,
.entry-content ol li ol,
.entry-content dd li ul,
.entry-content dd li ol {
    margin-bottom: 0;
}

/* @entry-content pre code
====================================== */

/* コードブロック */

.entry-content pre, 
.entry-content code,
.entry-content pre > code,
.entry-content pre[class*=lang] {
    font-family: "Fira Code", ui-monospace, Consolas,
                 SFMono-Regular, "SF Mono", Menlo, 
                 "Ubuntu Mono", "Liberation Mono", monospace;
}

.entry-content pre, 
.entry-content code {
    background-color: hsl(0 0% 100% / .9);
    border: 1px solid hsl(0 0% 87%);
    border-radius: .375em;
    font-size: 1em;
    line-height: 1.5;
}

.entry-content pre {
    margin: .5em 0;
    padding: 1em;
    position: relative;
}

.entry-content :not(pre) > code {
    padding: .0625em .25em;
}

.entry-content pre.code {
    padding-top: 2em;
    white-space: pre;
}

.entry-content pre.code::before {
    background-color: hsl(0 100% 80%);
    color: hsl(0 0% 100%);
    content: "Plain text";
    font-size: .875rem;
    font-weight: 500;
    line-height: 1;
    padding: .25rem .5rem;
    position: absolute;
    top: 0;
    left: 0;
}

.entry-content pre.code[class*=lang]::before {
    content: attr(data-lang);
}

/* @entry-content table
====================================== */

.entry-content table {
    border-bottom: 1em;
    border-collapse: collapse;
    border-spacing: 0;
    display: block;
    font-size: .8rem;
    margin-bottom: 1em;
    overflow: auto;
}

@media (min-width: 1200px) {
    .entry-content table {
        font-size: .9rem;
    }
}

.entry-content table th,
.entry-content table td {
    border: 1px solid hsl(0 0% 87%);
    padding: .3125em .625em;
}

.entry-content table th {
    background: hsl(213 71% 92% / .95) 
        linear-gradient(hsl(212 74% 95% / .95),hsl(213 71% 92% / .95));
    box-shadow: 0 1px 0 hsl(0 0% 100% / .8) inset;
}

.entry-content table th:first-child {
    border-radius: 6px 0 0 0;
}

.entry-content table th:last-child {
    border-radius: 0 6px 0 0;
}

.entry-content table th:only-child {
    border-radius: 6px 6px 0 0;
}

.entry-content table tr:last-child td:first-child {
    border-radius: 0 0 0 6px;
}

.entry-content table tr:last-child td:last-child {
    border-radius: 0 0 6px 0;
}

.entry-content table tr:last-child td:only-child {
    border-radius: 0 0 6px 6px;
}

/* @footnote footnote-number
====================================== */

/* ツールバー 脚注 */

.page-index .footnote { 
    display: none;
}

.footnote-number {
    scroll-margin-top: 3.5em;
}

/* @entry-content hr
====================================== */

.entry-content hr {
    border: 0;
    border-top: 8px dotted hsl(0 0% 0% / .1);
    margin: 4.375em auto;
    width: 50%;
}

/* @entry-content hatena-asin-detail
====================================== */

.hatena-asin-detail {
    background-color: hsl(213 28% 19% / .1);
    border: 3px solid hsl(213 28% 19%);
    border-radius: 4px;
    padding: .8em .6em;
    position: relative;
}

@media (min-width: 768px) {
    .hatena-asin-detail {
        padding: .8em 1.5em .8em .6em;
    }
}

.hatena-asin-detail a {
    color: hsl(36 100% 50%);
    
}

@media (min-width: 992px) {
    .hatena-asin-detail::before {
        background-color: hsl(213 28% 19%);
        color: hsl(36 100% 50%);
        content: "\293b";
        font-size: 1.8rem;
        font-weight: 900;
        height: 1.5rem;
        line-height: 2rem;
        position: absolute;
        top: -2px;
        right: -2px;
        text-align: center;
        width: 1.5rem;
        z-index: 1;
    }
    .hatena-asin-detail::after {
        color: hsl(0 0% 100%);
        content: "a";
        font-family: Arial, "Liberation Sans", sans-serif;
        font-size: 1.2rem;
        font-weight: 900;
        height: 1.5rem;
        line-height: 1rem;
        position: absolute;
        top: -2px;
        right: -2px;
        text-align:center;
        width: 1.5rem;
        z-index: 2;
    }
}

.hatena-asin-detail.hatena-rakuten-detail {
    background-color: hsl(0 100% 37% / .1);
    border: 3px solid hsl(0 100% 37%);
}

.hatena-asin-detail.hatena-rakuten-detail a {
    color: hsl(0 100% 37%);
}

@media (min-width: 992px) {
    .hatena-asin-detail.hatena-rakuten-detail::before {
        background-color: hsl(0 100% 37%);
        border-radius: 50%;
        color: hsl(0 0% 100%);
        content: "R";
        font-family: Arial, "Liberation Sans", sans-serif;
        font-size: .875rem;
        font-weight: 600;
        line-height: 1.5rem;
        position: absolute;
        top: 3px;
        right: 4px;
        text-align: center;
    }
    .hatena-asin-detail.hatena-rakuten-detail::after {
        content: none;
    }
}

/* @entry-content cite hatena-citation 
====================================== */

.entry-content cite.hatena-citation a::before {
    content: "\f009";
    font-family: "blogicon";
    letter-spacing: .3em;
    line-height: 1;
    vertical-align: middle;
}

/* ポスト下 */
/* @entry-footer
====================================== */

.entry-footer {
    position: relative;
}

/* @entry-footer social-buttons
====================================== */

.page-index .entry-footer .social-buttons {
    display: none;
}

@media (min-width: 992px) {
    .entry-footer .social-buttons {
        position: absolute;
        top: 0;
        left: -122px;
        flex-direction: column;
    }
}

@media (min-width: 1200px) {
    .entry-footer .social-buttons {
        left: -132px;
    }
}

/* @entry-footer-section
====================================== */

.entry-footer-section,
.entry-footer-section a {
    color: hsl(0 0% 60%);
    font-size: .9rem;
}

.page-index .entry-footer-section {
    display: none;
}

/*@entry-footer entry-footer-time
====================================== */

.entry-footer .entry-footer-time .updated  {
    display: none;
}

/*@entry-footer vcard
====================================== */

.entry-footer .author.vcard::before {
    content: "Author:\00a0";
}

/*@entry-tags-wrapper
====================================== */

.page-index .entry-tags-wrapper {
    display: none;
}

/* @hatena-star-container
====================================== */

.entry-footer .hatena-star-container {
    background-color: hsl(0 0% 99%);
    border-radius: 8px;
    margin: 1.5em 0;
    padding: 1em;
}

.entry-footer .hatena-star-container::before {
    content: "記事が面白かったら★をクリック！（連打できます）";
    display: block;
    font-size: .95rem;
    font-weight: 700;
    margin-bottom: .5em;
}

.page-index .entry-footer .hatena-star-container {
    display: none;
}

/* @ad-online-afc
====================================== */

.ad-online-afc .yads_ad .yads_ad_title,
.touch-afc-block .google_afc_blocklink .visible_url a {
    overflow-wrap: anywhere;
}

/* ポスト下 関連記事 */
/* @main entry-footer-modules
====================================== */

@media (min-width: 576px) {
    #main .entry-footer-modules .hatena-module {
        padding-top: 1em;
    }
    #main .entry-footer-modules .hatena-urllist {
        display: flex;
        flex-wrap: wrap;
        gap: .5em;
    }
    #main .entry-footer-modules .hatena-urllist li {
        border: 1px solid hsl(0 0% 93%);
        border-radius: 2px;
        margin: 0;
        padding: 1em;
        width: 100%;
    }
    #main .entry-footer-modules .hatena-urllist li:nth-of-type(n+2) {
        width: calc( 50% - ( .25em + 1px ) );
    }
    #main .entry-footer-modules .urllist-title-link {
        font-size: .875rem;
        padding-bottom: .5em;
    }
    #main .entry-footer-modules .urllist-entry-body {
        overflow: hidden;
    }
}

@media (min-width: 768px) {
    #main .entry-footer-modules .hatena-urllist {
        flex-direction: column;
    }
    #main .entry-footer-modules .hatena-urllist li:nth-of-type(n+2) {
        width: 100%;
    }
    #main .entry-footer-modules .urllist-title-link {
        font-size: .875rem;
    }
}

/* コメント欄 */
/* @comment-box
====================================== */

.comment-box {
    margin: 1em 0;
}

.page-index .comment-box {
    display: none;
}

/* @comment-box comment
====================================== */

.comment-box .comment {
    font-size: .875rem;
    line-height: 1.7;
    list-style: none;
    margin-block: 1.875rem;
    padding: 0;
}

@media (min-width: 768px) {
    .comment-box .comment {
        font-size: .9375rem;
    }
}

/* @comment-box entry-comment
====================================== */

.comment-box .entry-comment {
    background: linear-gradient(-155deg,
        hsl(0 0% 0% / 0) 1.5em, hsl(0 0% 99%) 0%);
    border-radius: 6px;
    box-shadow: 10px 10px 32px -15px hsl(0 0% 0% / .25);
    margin-bottom: .75em;
    padding: .625em 1.25em .625em 3.75em;
    position: relative;
}

.comment-box .entry-comment::after {
    background: linear-gradient(to left bottom,
        hsl(0 0% 0% / 0) 50%,
        hsl(0 0% 0% / .1) 0%,
        hsl(0 0% 0% / .2)
    );
    border-bottom-left-radius: 6px;
    box-shadow: -.2em .2em .3em -.1em hsl(0 0% 0% / .15);
    content: "";
    height: 3.5493em;
    position: absolute;
    top: 0;
    right: 0;
    transform: translateY(-1.89424em) rotate(-40deg);
    transform-origin: bottom right;
    width: 1.65507em;
}

/* @comment-box read-more-comments
====================================== */

.comment-box .read-more-comments {
    padding: .625em 0;
}

/* @comment-box hatena-id-icon
====================================== */

.comment-box .hatena-id-icon {
    border-radius: 3px;
    height: 50px !important;
    position: absolute;
    top: 10px;
    left: 0;
    width: 50px !important;
}

/* @comment-user-name
====================================== */

.comment-user-name {
    font-weight: 700;
    margin: 0 0 .4em 0;
}

/* @comment-content p img
====================================== */

.comment-content {
    color: hsl(0 0% 25%);
    font-size: .85rem;
    margin: 0 0 .4em 0;
}

.comment-content p {
    margin: 0 0 .6em 0;
}

.comment-content img {
    height: auto;
}

/* @comment-metadata a
====================================== */

.comment-metadata {
    color: hsl(0 0% 53%);
    font-size: .8rem;
    margin: 0;
}

.comment-metadata a {
    color: hsl(0 0% 53%);
}

/* @leave-comment-title
====================================== */

.leave-comment-title {
    border: 1px solid hsl(0 0% 78%);
    border-radius: .5em;
    color: hsl(0 0% 46%);
    font-size: .85rem;
    font-weight: 700;
    margin-top: 1em;
    padding: .6em 1em;
}

.leave-comment-title::before { 
    content: "\f024";
    font-family: "blogicon";
    letter-spacing: .3em;
}

.leave-comment-title:hover {
    color: hsl(225 6% 13%); 
}

/* ページ送りナビ */
/* @pager 
====================================== */

.pager {
    margin: 2em 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

@media (min-width: 768px) {
    .pager {
        flex-direction: row;
    }
}

.pager>* {
    flex: 1;
}

.pager .pager-next a,.pager .pager-prev a {
    background-color: hsl(0 0% 99%);
    border: 1px solid hsl(0 0% 80%);
    border-radius: 4px;
    color: hsl(0 0% 50%);
    cursor: pointer;
    display: block;
    font-size: .975rem;
    font-weight: 500;
    line-height: 1.4;
    padding: .75em 1.25em;
    text-align: center;
    text-overflow: ellipsis;
    transition: all .25s;
    overflow: hidden;
    white-space: nowrap;
}

@media(min-width: 768px) {
    .pager .pager-next a,.pager .pager-prev a {
        font-size: .975rem;
        padding: 1em 1.25em;
    }
}

.pager .pager-next a:hover,.pager .pager-prev a:hover {
    background-color: hsl(0 0% 96%);
    border: 1px solid hsl(0 0% 89%);
    color: hsl(0 0% 48%);
}

/* サイドカラム */
/* @hatena-module
====================================== */

.hatena-module {
    color: hsl(0 0% 46%);
    font-size: .85rem;
    margin-bottom: 3rem;
}

@media (min-width: 768px) {
    .hatena-module {
        font-size: .9rem;
    }
}

/* @hatena-module-title
====================================== */

.hatena-module-title {
    background: hsl(0, 100%, 80%) linear-gradient(
        transparent 8%,
        hsl(0 0% 100% / .5) 8%,
        hsl(0 0% 100% / .5) 12%,
        transparent 12%,
        transparent 88%,
        hsl(0 0% 100% / .5) 88%,
        hsl(0 0% 100% / .5) 92%,
        transparent 92%
    );
    box-shadow:0 1px 2px 0 hsl(0 0% 0% / .2);
    color: hsl(0 0% 100%);
    font-size: 1.125rem;
    line-height: 1.6;
    margin: 0 0 20px;
    padding: 10px 5px;
    position: relative;
    text-align: center;
}

@media (min-width: 1200px) {
    .hatena-module-title {
        margin: 0 -10px 40px;
        transform: rotate(-3deg) skew(-3deg);
    }
}

.hatena-module-title::before,
.hatena-module-title::after {
    border-color: transparent;
    border-style: solid;
    content: "";
    height: 0;
    position: absolute;
    width: 0;
}

.hatena-module-title::before {
    border-bottom-color: hsl(0 50% 60%);
    border-width: 0 0 5px 10px;
    top: -5px;
    left: 0;
}

.hatena-module-title::after {
    border-top-color: hsl(0 50% 60%);
    border-width: 5px 10px 0 0;
    top: 100%;
    right: 0;
}

.hatena-module-title a,
.hatena-module-title a:hover {
    color: hsl(0 0% 100%);
}

.page-archive .hatena-module-title:nth-of-type(1) {
    margin-top: 3rem;
}

/* @hatena-module-profile profile-icon
====================================== */

.hatena-module-profile .profile-icon {
    border: 1px solid hsl(0 0% 93%);
    border-radius: .5em;
    margin: 0 .625em .625em 0;
}

@media (min-width: 768px) and (max-width: 1199px) {
    .hatena-module-profile .profile-icon {
        border-radius: 50%;
    }
}

/* @hatena-module-profile id
====================================== */

.hatena-module-profile .id {
    background-color: hsl(185 100% 43% / .9);
    box-shadow: 0 1px 2px 0 hsl(0 0% 0% / .2),
                30px 0 0 0 hsl(185 100% 43% / .9),
                30px 0 0 0 hsl(185 100% 43% / .9);
    display: inline-block;
    line-height: 2;
    margin-bottom: 1em;
    max-width: 90%;
    padding-left: .5em;
    vertical-align: top;
}

.hatena-module-profile .id a span {
    color: hsl(0 0% 100%);
    font-weight: 700;
    text-shadow: 1px 1px 0 hsl(0 0% 20%);
}

/* @profile-description p
====================================== */

.hatena-module-profile .profile-description {
    margin: .75em 0;
}

.hatena-module-profile .profile-description p {
    font-size: .7rem;
    line-height: 1.5;
    margin: 0 0 .25em;
}

/* @hatena-urllist
====================================== */

.hatena-urllist {
    list-style: none;
    margin: 0;
    padding: 0;
}

.hatena-urllist li {
    border-bottom: 1px solid hsl(0 0% 93%);
    font-weight: 700;
    padding: .7em 0;
}

.hatena-urllist a {
    color: hsl(213 5% 39%);
}

.hatena-urllist a:hover {
    color: hsl(188 93% 43%);
}

/* @urllist-image
====================================== */

.hatena-urllist li .urllist-image {
    border-radius: .5em;
}

/* @urllist-title-link
====================================== */

.hatena-urllist li .urllist-title-link {
    font-size: .925rem; /* .8rem; */
}

@media (min-width: 768px) and (max-width: 1199px) {
    .hatena-urllist li .urllist-title-link {
        font-size: .7rem;
    }
}

/* @hatena-urllist urllist-category-link
====================================== */

.hatena-urllist .urllist-category-link {
    display: inline-block;
    font-size: .7rem;
    padding: .1em .3em;
}

.hatena-urllist .urllist-category-link:first-of-type,
.hatena-urllist .urllist-category-link:nth-of-type(5n+1) {
    color: hsl(185 99% 27%);
}

.hatena-urllist .urllist-category-link:nth-of-type(2),
.hatena-urllist .urllist-category-link:nth-of-type(5n+2) {
    color: hsl(326 37% 44%); 
}

.hatena-urllist .urllist-category-link:nth-of-type(3),
.hatena-urllist .urllist-category-link:nth-of-type(5n+3) {
    color: hsl(49 89% 33%); 
}

.hatena-urllist .urllist-category-link:nth-of-type(4),
.hatena-urllist .urllist-category-link:nth-of-type(5n+4) {
    color: hsl(28 53% 39%);
}

.hatena-urllist .urllist-category-link:nth-of-type(5),
.hatena-urllist .urllist-category-link:nth-of-type(5n) {
    color: hsl(355 52% 60%);
}

.hatena-urllist .urllist-category-link::before {
    content: "\f04a";
    font-family: "blogicon";
    font-size: .85em;
    letter-spacing: .2em;
}

.hatena-urllist .urllist-category-link:hover {
    opacity: .7;
}

/* @hatena-urllist urllist-date-link
====================================== */

.hatena-urllist .urllist-date-link a {
    color: hsl(0 0% 60%);
}

.hatena-urllist .urllist-date-link a::before {
    content: "\f043";
    font-family: "blogicon";
    font-size: .95em;
    letter-spacing: .1em;
}

/* @urllist-entry-body 
====================================== */

.urllist-entry-body {
    margin-top: .3em;
}

.hatena-module .hatena-urllist li:nth-of-type(n+2) .urllist-entry-body {
    display: none;
}

/* @hatena-module-search-box
====================================== */

.search-form {
    border: 1px solid hsl(0 0% 95%);
    border-radius: 4px; 
    height: 40px;
    position: relative;
    width: 100%;  
}


.search-form .search-module-input {
    background: none;
    border: none;
    font-size: .9rem;
    height: 20px;
    outline: none;
    margin: auto 0;
    opacity: .87;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    text-indent: .5em;
    width: calc(100% - (.5em + 50px)); 
}

.search-form .search-module-button {
    background-color: hsl(0 0% 33%);
    border: none;
    border-radius: 0 4px 4px 0;
    color: hsl(0 0% 100%);
    cursor: pointer;
    font-size: .9rem;
    height: 100%;
    outline: none;
    position: absolute;
    top: 0;
    right: 0;
    width: 50px;
}

.search-form .search-module-button:hover {
    background-color: hsl(188 93% 43%);
}

/* @entries-access-ranking
====================================== */

.entries-access-ranking {
    counter-reset: rank;
}

.entries-access-ranking li {
    margin: .7em 0;
    padding: 0;
    position: relative;
}

.entries-access-ranking li::before {
    border-radius: 50%;
    color: hsl(0 0% 100%);
    content: counter(rank);
    counter-increment: rank;
    display: block;
    font-size: .8125rem;
    font-weight: 700;
    height: 20px;
    line-height: 20px;
    position: absolute;
    top: 0;
    left: 0;
    text-align: center;
    width: 20px;
}

.entries-access-ranking li:nth-of-type(1)::before {
    background-color: hsl(40 100% 55% / .95);
}

.entries-access-ranking li:nth-of-type(2)::before {
    background-color: hsl(0 0% 54% / .95);
}

.entries-access-ranking li:nth-of-type(3)::before {
    background-color: hsl(30 30% 50% / .95);
}

.entries-access-ranking li:nth-of-type(n+4)::before {
    background-color: hsl(120 100% 50% / .95);
}

.entries-access-ranking li:nth-of-type(n+9)::before {
    background-color: hsl(0 0% 25% / .95); 
}

.entries-access-ranking .urllist-date-link {
    margin-left: 2.75em; 
}

.entries-access-ranking .urllist-title-link {
    display: inline-block;
    margin-left: 2.5em; 
}

.entries-access-ranking .urllist-image-link+.urllist-date-link,
.entries-access-ranking .urllist-image-link+.urllist-title-link,
.entries-access-ranking .urllist-image-link+.urllist-date-link+.urllist-title-link {
    margin-left: 0;
}

.entries-access-ranking .urllist-image-link+.urllist-title-link,
.entries-access-ranking .urllist-image-link+.urllist-date-link+.urllist-title-link {
    display: inline;
}

/* @hatena-module-category
====================================== */

.hatena-module-category .hatena-urllist li {
    padding: 0;
}

.hatena-module-category .hatena-urllist li a {
    display: block;
    padding: .5em;
}

.hatena-module-category .hatena-urllist li a:hover {
    background-color: hsl(25 22% 65%);
    color: hsl(0 0% 100%);
}

/* @hatena-module-html
====================================== */

.hatena-module-html p {
    margin: 0;
}

.hatena-module-html ul {
    list-style: none;
    margin-block: 0;
    padding-inline-start: 0;
}

.hatena-module-html video,
.hatena-module-html iframe {
    max-width: 100%;
}

.hatena-module-html video {
    height: auto;
}

/* @hatena-module-circles
====================================== */

.hatena-module-circles .hatena-urllist li {
    padding: 1em;
}

.hatena-module-circles .hatena-urllist li:hover {
    background-color: hsl(0 0% 97%);
}

/* @circle-urllist circle-image
====================================== */

.hatena-module-body .circle-urllist .circle-image { 
    margin-left: .3125em;
}

.hatena-module-body .circle-urllist li .circle-image {
    outline: 2px solid transparent;
}

.hatena-module-body .circle-urllist li:hover .circle-image {
    outline: 2px solid hsl(0 0% 87%);
}  

/* @archive-module-button
====================================== */

.archive-module-button {
    color: hsl(35 84% 62%);
}

/* @archive-module-months
====================================== */

ul.archive-module-months li a {
    display: block;
    overflow: hidden;
    padding-left: 1.25em;
    position: relative;
}

ul.archive-module-months li a::before {
    border-color: transparent transparent transparent hsl(188 93% 43%);
    border-style: solid;
    border-width: 4.5px 0 4.5px 6px;
    content: "";
    display: block;
    height: 0;
    position: absolute;
    top: calc(-5px + 50%);
    left: -7px;
    transition: left .35s;
    width: 0;
}

ul.archive-module-months li a:hover::before {
    left: 8px;
}

/* @archive-module-calendar
====================================== */

.hatena-module .archive-module-calendar,
.hatena-module .archive-module-calendar a {
    color: hsl(0 0% 46%);
}

.hatena-module .archive-module-calendar a {
    text-decoration: underline;
}

.hatena-module .calendar-sunday,
.hatena-module .archive-module-calendar-week td:first-of-type,
.hatena-module .archive-module-calendar-week td:first-of-type a {
    color: hsl(16 100% 50%);
}

.hatena-module .calendar-saturday,
.hatena-module .archive-module-calendar-week td:nth-of-type(7),
.hatena-module .archive-module-calendar-week td:nth-of-type(7) a {
    color: hsl(188 100% 50%);
}

.hatena-module .archive-module-calendar a:hover,
.hatena-module .archive-module-calendar-week td:first-of-type a:hover,
.hatena-module .archive-module-calendar-week td:nth-of-type(7) a:hover {
    opacity: .7;
}

/* @recent-comments
====================================== */

.recent-comments,
.recent-comments .user-id img {
    overflow-wrap: anywhere;
}

/* aboutページ編集 */
/* @page-about entry-content dt dd
====================================== */

.page-about .entry-content dt { 
    font-size: 1rem;
    font-weight: 700;
}

.page-about .entry-content dd {
    margin-bottom: 1.875em;
    margin-left: 0;
}

/* アーカイブページ */
/* @page-archive top-box
====================================== */

.page-archive #top-box {
    margin: 0;
}

/* @page-archive breadcrumb
====================================== */

.page-archive .breadcrumb {
    display: none;
}

/* @page-archive main
====================================== */

.page-archive #main {
    margin-left: 0;
    padding-left: 0;
    width: 100%;
}

/* @archive-header-category
====================================== */

.archive-header-category {
    margin-bottom: 1.5em;
}

/* @archive-heading
====================================== */

.archive-header-category .archive-heading {
    margin-bottom: 0;
}

.archive-header-category .archive-heading::before {
    content: "Category:";
    margin-right: .2em;
} 

/* @archive-entries
====================================== */

.page-archive .archive-entries {
    display: flex;
    flex-direction: column;
    gap: 1em 0;
}

@media (min-width: 576px) {
    .page-archive .archive-entries {
        flex-flow: row wrap;
        justify-content: space-between;
    }
}

/* @page-archive archive-entry
====================================== */

.page-archive .archive-entry {
    border: 1px solid hsl(0 0% 95%);
    padding: .625em;
    position: relative;
    word-break: break-all;
    display: flex;
    flex-direction: column;
}

@media (min-width: 576px) {
    .page-archive .archive-entry {
        width: calc(50% - .5em);
    }
}

/* @page-archive entry-thumb-link
====================================== */

.page-archive .archive-entry .entry-thumb-link {
    order: 0;
    overflow: hidden;
}

/* @page-archive entry-thumb
====================================== */

.page-archive .archive-entry .entry-thumb {
    aspect-ratio: 16 / 9;
    border-radius: 5px;
    float: none;
    height: auto;
    margin-right: 0;
    transition: .4s ease-in-out;
    width: 100%;
}

.page-archive .archive-entry .entry-thumb:hover {
    background-color: hsl(0 0% 0% / .08);
    opacity: .55;
    transform: scale(1.3);
}

/* @archive-entry-header
====================================== */

.archive-entry .archive-entry-header {
    margin-top: .5em;
    order: 1;
    display: flex;
    flex-direction: column-reverse;
}

/* @archive-entry-header entry-title
====================================== */

.archive-entry .archive-entry-header .entry-title {
    font-size: 1rem;
    margin-bottom: .5em;
}

/* @archive-entry-header date
====================================== */

.archive-entry .archive-entry-header .date {
    font-size: .8rem;
    font-weight: 700;
    line-height: inherit;
    margin-bottom: .5em;
    position: static;
}

.archive-entry .archive-entry-header .date a,
.archive-entry .archive-entry-header .date a:hover {
    color: hsl(0 0% 60%);
}

/* @page-archive archive-entry-body
====================================== */

.page-archive .archive-entry .archive-entry-body {
    order: 2;
}

/* @page-archive date after
====================================== */

.page-archive .date .hyphen { 
    display: none;
}

.page-archive .date .date-year::after,
.page-archive .date .date-month::after { 
    content: ".";
}

/* @page-archive categories
====================================== */

.page-archive .archive-entry .categories {
    display: none;
    /* order: 3; */
}

.page-archive .archive-entry .categories a {
    font-size: .7rem;
}

/* @page-archive entry-description
====================================== */

.archive-entry .archive-entry-body .entry-description {
    /* color: hsl(213 5% 39%); */
    display: none;
    /* font-weight: 600; */
    /* font-size: .8rem; */
    /* margin: 0; */
}

/* @page-archive social-buttons
====================================== */

.archive-entry .archive-entry-body .social-buttons {
    display: none;
    /* margin: .3em 0 1em; */
}

/* @page-archive span highlight 
====================================== */

.page-archive span.highlight {
    background-color: hsl(41 100% 48% / .15);
    border: 1px solid hsl(41 100% 48% / .16);
    color: hsl(41 100% 48%);
    line-height: 1;
    padding: 0;   
}

/* @archive-entry-tags-wrapper
====================================== */

.page-archive .archive-entry-tags-wrapper {
    display: none;
}

/* @page-archive search-result-button
====================================== */

.search-result-form .search-result-button {
    top: 50%;
    transform: translateY(-50%);
}

/* フッター */
/* @footer
====================================== */

#footer {
    color: hsl(0 0% 0% / .54);
    font-size: .8rem;
    margin: 0 auto;
    padding: 2em 0;
    text-align: center;
    width: 96%;
    display: flex;
    align-items: center;
    justify-content: center;
}

@media (min-width: 768px) {
    #footer {
        padding: .625em 4%; 
    }
}

@media (min-width: 992px) {
    #footer {
        max-width: 960px;
    }
}

@media (min-width: 1200px) {
    #footer {
        max-width: 1100px;
    }
}

#footer a,
#footer a:hover {
    color: hsl(0 0% 0% / .54);
}

#footer p {
    margin: .5em auto;
}

#footer address img {
    display: inline-block;
}

/* @footer End
====================================== */

/* End system
   ========================================================================== */
/* </system> */
/* 箇条書きデザイン */
.entry-content > ul, .entry-content ol{
background: #ooooff;/*背景色*/
padding: 0.5em 0.5em 0.5em 2em;/*ボックス内の余白*/
border: solid 3px #ffb03f;/*線の種類 太さ 色*/
}

.entry-content ul li, .entry-content ol li {
line-height: 1.5; /*文の行高*/
padding: 0.5em 0; /*前後の文との余白*/
}


}
.box8 {
    padding: 0.5em 1em;
    margin: 2em 0;
    color: #232323;
    background: #fff8e8;
    border-left: solid 10px #ffc06e;
}
.box8 p {
    margin: 0; 
    padding: 0;
}
article u{

    text-decoration: none;

    background: linear-gradient(transparent 50%, #f0e68c 50%);

}
.article-btn a{
 display:block;
 text-decoration:none;
 padding:7px 10px;
 border-radius:4px;
 font-weight:bold;
 color:white;/* ボタンの文字色 */
 background-color:#40e0d0;/* ボタンの背景色 */
 box-shadow:0 2px #541a0b;/* ボタンの影の色 */
 transition:transform 0.3s;
 text-align:center;
}
.article-btn a:hover{
    transform:scale(1.1);
}
/*太文字マーカー*/
.entry-content strong {
background: linear-gradient(transparent 60%, #40e0d0 40%);
}
.box8 {
    padding: 0.5em 1em;
    margin: 2em 0;
    color: #232323;
    background: #fff8e8;
    border-left: solid 10px #ffc06e;
}
.box8 p {
    margin: 0; 
    padding: 0;
}
.box27 {
    position: relative;
    margin: 2em 0;
    padding: 0.5em 1em;
    border: solid 3px #62c1ce;
}
.box27 .box-title {
    position: absolute;
    display: inline-block;
    top: -27px;
    left: -3px;
    padding: 0 9px;
    height: 25px;
    line-height: 25px;
    font-size: 17px;
    background: #62c1ce;
    color: #ffffff;
    font-weight: bold;
    border-radius: 5px 5px 0 0;
}
.box27 p {
    margin: 0; 
    padding: 0;
}
.hatena-urllist li a{
color: #167ac6;
}
/* 吹き出しのCSS　*/
.entry-content .l-fuki,
.entry-content .r-fuki {
position: relative;
width: 80%;
box-sizing: border-box;
-webkit-box-sizing: border-box;
padding: 20px;
border-radius: 6px;
border: 2px solid #999;
box-shadow: 1px 1px 5px #aaa;
background-color: #fff;
z-index: 1;
}
.entry-content .l-fuki {
margin: 20px 20% 40px 0;
}
.entry-content .r-fuki {
margin: 20px 0 40px 19%;
}
.entry-content .l-fuki::before,
.entry-content .r-fuki::before {
position: absolute;
content: "";
top: 16px;
width: 10px;
height: 10px;
border-right: 2px solid #999;
border-bottom: 2px solid #999;
background-color: #fff;
z-index: 2;
}
.entry-content .l-fuki::before {
right: -7px;
transform: rotate(-45deg);
-webkit-transform: rotate(-45deg);
}
.entry-content .r-fuki::before {
left: -7px;
transform: rotate(135deg);
-webkit-transform: rotate(135deg);
}
.entry-content .l-fuki::after,
.entry-content .r-fuki::after {
position: absolute;
content: "";
width: 80px;
height: 80px;
top: -10px;
border-radius: 40px;
border: 3px solid #fff;
background-size: cover;
background-position: center center;
background-repeat: no-repeat;
box-shadow: 1px 1px 5px #aaa;
}
.entry-content .l-fuki::after {
right: -110px;
}
.entry-content .r-fuki::after {
left: -110px;
}
@media screen and (max-width: 620px) {
.entry-content .l-fuki,
.entry-content .r-fuki {
width: 70%
}
.entry-content .l-fuki {
margin-right: 30%;
}
.entry-content .r-fuki {
margin-left: 30%;
}
}
@media screen and (max-width: 478px) {
.entry-content .l-fuki::after,
.entry-content .r-fuki::after {
width: 60px;
height: 60px;
border-radius: 30px;
}
.entry-content .l-fuki::after {
right: -84px;
}
.entry-content .r-fuki::after {
left: -84px;
}
}

.nori01::after {background-image:url(https://cdn-ak.f.st-hatena.com/images/fotolife/c/carino-mare-doo/20190808/20190808142703.jpg);}

.nori02::after {background-image:url(https://cdn-ak.f.st-hatena.com/images/fotolife/c/carino-mare-doo/20190808/20190808142707.jpg);}

.nori03::after {background-image:url(https://cdn-ak.f.st-hatena.com/images/fotolife/c/carino-mare-doo/20190808/20190808142711.jpg);}

