/* <system section="theme" selected="17680117126993484579"> */
@charset "UTF-8";
/**!
  Theme: Ocean
  Theme URI: https://blog.hatena.ne.jp/-/store/theme/17680117126993484579/
  Responsive: yes
  Author: Askthewind’s diary
  Description: レスポンシブデザインに対応したはてなブログ用デザインテーマです。
  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
/* Document
   ========================================================================== */
/**
 * 1. line-heightを1.15で設定。
 * 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のマージンを取り除く。
 */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0
}

/**
/* Chrome、Firefox、Safariで、sectionとarticleコンテキスト内の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のmonospaceのフォントサイズがが縮小されるのを正しい表示に修正する。
 * 2. preのフォントサイズを1emで調整する。
 */
/**
 * 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
   ========================================================================== */
/**
 * Chrome、Edge、Opera、Safariでtext-decorationを正しい表示に修正する。
 */
/**
 * Add the correct text decoration in Chrome, Edge, Opera, and Safari.
 */
abbr[title] {
  text-decoration: underline; 
  text-decoration: underline dotted 
}

/**
 * Chrome、Edge、Safariでフォントの太さを調整する。
 */
/**
 * Add the correct font weight in Chrome, Edge,and Safari.
 */
b,
strong {
  font-weight: bolder
}

/**
 * 1. code,kbd,sampのmonospaceのフォントサイズがが縮小されるのを正しい表示に修正する。
 * 2. code,kbd,sampのフォントサイズを1emで調整する。
 */
/**
 * 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
   ========================================================================== */
/**
 * button,input,optgroup,select,textareaのフォントスタイルを設定。
 */
/**
 * Change the font styles in all browsers.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; 
  font-size: 100%; 
  line-height: 1.15;
}

/**
 * 開発者がfieldsetをゼロにしたときの挙動をpadding: 0で制御する。
 */
/**
 * Remove the padding so developers are not caught out when they zero out
 * `fieldset` elements in all browsers.
 */
legend {
  padding: 0
}

/**
 * Chrome、Firefox、Opera用にprogressをvertical-align: baselineで設定。
 */
/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline
}

/* Interactive
   ========================================================================== */
/**
 * summaryをdisplay: list-itemで設定。
 */
/*
 * 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% 27%);
    font-family: Roboto,Arial,sans-serif;
    font-feature-settings: "palt";
    font-size: 1rem;
    line-height: 1.6
}

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

a {
    color: hsl(0 0% 27%);
    text-decoration: none
}

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

h1 a:hover, h2 a:hover, h3 a:hover, h4 a:hover, h5 a:hover, h6 a:hover {
    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,svg,select,textarea {
    max-width: 100%
}

svg {
    fill: currentColor
}

/* @blogicon-* lg
====================================== */

[class*=blogicon-] {
    display: inline-block;
    fill: currentColor;
    font-family: blogicon;
    font-style: normal;
    font-variant: normal;
    font-weight: 400;
    line-height: 1;
    text-rendering: auto
}

[class*=blogicon-].lg {
    font-size: 1.33333333em;
    line-height: .75em;
    vertical-align: -10%
}

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

#blog-title {
    padding: 50px 0;
    text-align: center
}

.page-entry #blog-title {
    margin-bottom: 0
}

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

#title {
    font-size: 1.8rem;
    margin: 0
}

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

#title a {
    color: hsl(0 0% 53%)
}

#title a:hover {
    color: hsl(0 0% 67%)
}

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

#blog-description {
    font-size: .8rem;
    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 2em;
    padding: 0
}

@media (min-width: 992px) {
    .header-image-enable #blog-title,
    .header-image-only #blog-title {
        margin: 0 auto 4em
    }
    .page-entry.header-image-enable #blog-title,
    .page-entry.header-image-only #blog-title {
        margin: 0 auto 3em
    }
}

.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;
    align-items: center
}

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

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

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

@media (min-width: 768px) {
    #container {
        border-radius: 10px;
        padding: 0 4%
    }
}

@media (min-width: 1100px) {
    #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,#box1
====================================== */

#wrapper,#box2 {
    width: 100%
}

#wrapper {
    margin-bottom: 40px
}

#box2 {
    overflow-wrap: anywhere
}

@media (min-width: 992px) {
    #wrapper {
        width: 60%
    }
    #box2 {
        width: 34%
    }
}

#box1 {
    display: none
}

/* @box2 box2-inner
====================================== */

@media (min-width: 576px) and (max-width: 991px) {
    #box2 #box2-inner {
        display: grid;
        gap: 30px;
        grid-template-columns: 1fr 1fr
    }
}

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

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

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

#bottom-editarea {
    margin: 0 auto
}

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

#top-box {
    font-size: .9rem;
    margin: 0 auto
}

.page-entry #top-box {
    margin-bottom: 50px
}

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

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

.breadcrumb {
    padding: 10px
}

.page-entry .breadcrumb {
    border: 1px solid hsl(0 0% 87%);
    border-radius: 3px;
    margin-bottom: 0
}

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

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

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

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

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

.entry {
    border-bottom: 2px solid hsl(0 0% 87%);
    margin-bottom: 4em;
    padding-bottom: 2em;
    position: relative
}

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

.entry-header {
    min-height: 120px;
    padding: 0 0 .9375em;
    position: relative
}

.entry-header::before {
    border-bottom: solid 2px hsl(0 100% 80%);
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    transition: .9s;
    width: 0
}

.entry-header:hover::before {
    width: 100%
}

/* @date entry-date
====================================== */

.date {  
    margin-bottom: 1em
}

.date a {
    background-color: hsl(0 100% 80%);
    box-shadow: 0 2px 2px hsl(0 0% 0% / .12);
    color: hsl(0 0% 100%);
    display: inline-block;
    font-size: .875rem;
    padding: .0625em .25em;
    transform: none
}

.date a::before {
    content: "\f043";
    font-family: "blogicon";
    height: 13px;
    margin-right: .075em;
    vertical-align: middle;
    width: 13px
}

.date-last-updated {
    background-color: hsl(0 100% 80%);
    box-shadow: 0 2px 2px hsl(0 0% 0% / .12);
    color: hsl(0 0% 100%);
    display: inline-block;
    font-size: .875rem;
    margin-left: 1em;
    padding: .094em .25em;
    transform: none
}

.date-last-updated .blogicon {
    vertical-align: -10%
}

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

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

@media (min-width: 576px) {
    .entry-title {
        font-size: 1.1rem
    }
}

@media (min-width: 768px) {
    .entry-title {
        font-size: 1.2rem
    }
}

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

.categories {
    margin-top: .3125em
}

.categories a {
    background-color: hsl(33 31% 50% / .95); 
    border-radius: 2px;
    color: hsl(0 0% 100%);
    display: inline-block;
    font-size: .625rem;
    line-height: 1.4;
    margin: .1875em 0; 
    padding: .0625em .25em;   
    position: relative
}

.categories a::before {
    content: "\f04a";
    font-family: "blogicon";
    letter-spacing: .3em
}

.categories a:hover {
    opacity: .87
}

@media (min-width: 768px) {
    .categories a {
        font-size: .75rem
    }
}

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

/* 編集ボタン */

.entry-header-menu {
    position: absolute;
    top: 0;
    right: 0
}

.entry-header-menu a {
    background-color: hsl(162 95% 40%);
    border-radius: 3px;
    color: hsl(0 0% 100%);
    display: inline-block;
    font-size: .75rem;
    line-height: 1;
    margin-bottom: 0;
    padding: .25em;
    text-align: center;
    width: 56px
}

.entry-header-menu a:hover {
    background-color: hsl(0 0% 40%)
}

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

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

.entry-content {
    line-height: 1.7
}

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

@media (min-width: 768px) {
    .entry-content {
        line-height: 1.8
    }
    .entry-content p {
        line-height: 2
    }
}

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

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

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

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

/* @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-top: 3px solid hsl(13 90% 71%);
    border-bottom: 3px solid hsl(13 90% 71%);
    font-size: 1.4rem;
    margin: 1.5em 0;
    padding: .8em 0 .8em 1.8em;
    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(150 100% 98%);
    font-size: 1.4rem;
    margin: 1.5em 0;
    padding-bottom: .8em
}

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

/* 見たまま編集 続きを読む */

a.entry-see-more {
    background: hsl(162 95% 40%) 
        linear-gradient(hsl(162 95% 40%),hsl(162 95% 38%));
    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 0 0;
    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 {
    border: solid 2px hsl(0 0% 93%);
    border-radius: 5px;
    color: hsl(0 0% 27%);
    font-style: italic;
    margin: 0 0 .625em;
    padding: 3.125em .625em;
    position: relative
}

@media (min-width: 1100px) {
    .entry-content blockquote {
        padding: .625em 3.125em
    }
}

.entry-content blockquote::before,
.entry-content blockquote::after {
    color: hsl(187 43% 63%);
    content: "\f704";
    display: inline-block;
    font-family: "blogicon";
    font-size: 25px;
    font-weight: 900;
    line-height: 1;
    position: absolute;
    vertical-align: middle
}

.entry-content blockquote::before {
    top: 20px;
    left: 15px
}

.entry-content blockquote::after {
    right: 15px;
    bottom: 20px;
    transform: rotate(180deg)
}

.entry-content blockquote p {
    margin: .625em 0;
    padding: 0;
    line-height: 1.7
}

.entry-content blockquote cite {
    color: hsl(0 0% 53%);
    display: block;
    font-size: .9em
}

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

/* 見たまま編集 箇条書き 番号付きリスト */

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

@media (min-width: 1100px) {
    .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 > code {
    font-family: "SF Mono","Courier New","Ubuntu Mono",monospace,sans-selif
}

.entry-content pre {
    background-color: hsl(210 17% 98%);
    border: 4px solid hsl(0 0% 93%);
    font-size: 1rem;
    line-height: 1.3;
    padding: 1.875em .9375em;
    position: relative
}

.entry-content code {
    background-color: hsl(210 17% 98% / .9);
    border: 1px solid hsl(0 0% 93% / .9);
    border-radius: 4px;
    padding: .0625em .25em
}

.entry-content pre.code,
.entry-content pre > code {
    font-size: 1rem;
    white-space: pre
}

.entry-content pre.code::before,
.entry-content pre > code::before {
    background-color: hsl(0 100% 80%);
    color: hsl(0 0% 100%);
    padding: 0 .8em;
    position: absolute;
    top: 0;
    left:0
}

.entry-content pre.code::before {
    content: attr(data-lang)
}

.entry-content pre > code::before {
    content: "Code"
}

/* @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: 1100px) {
    .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
====================================== */

/* HTML編集で<hr />を使う場合 */

.entry-content hr {
    border: 0;
    border-top: 8px dotted hsl(0 0% 50% / .75);
    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%)
}

.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,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%)
}

.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,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 social-buttons
====================================== */

.entry-footer .social-buttons {
    margin: 1em 0
}

.page-index .social-buttons { 
    display: none 
}

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

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

.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: 0 0 1.875em 0;
    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: 1.5em 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    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.5em .5em;
    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 {
        padding: 1em 1.5em .75em
    }
}

.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 {
    border-bottom: 1px solid hsl(0 0% 95%);
    font-size: .85rem;
    margin-bottom: 3em;
    position: relative
}

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

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

.hatena-module-title {
    color: hsl(0 0% 53%);
    font-weight: 700;
    font-size: 1.2rem;
    margin-bottom: .9375em;
    margin-left: 2.1875em;
    position: relative
}

@media (min-width: 768px) and (max-width: 1099px) {
    .hatena-module-title {
        font-size: 1.1rem
    }
}

.hatena-module-title::after {
    background: linear-gradient(to right,hsl(185 100% 43% / .95),transparent);
    content: "";
    display: block;
    height: 4px
}

.hatena-module-title a {
    color: hsl(0 0% 53%)
}

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

.hatena-module-title::before {
    background-color: hsl(185 100% 43% / .95);
    border-radius: 50%;
    color: hsl(0 0% 100%);
    display: inline-block;
    font-family: "blogicon"; 
    font-size: 1.25rem;
    height: 30px;
    line-height: 30px;
    position: absolute;
    top: 0;
    left: -35px;
    text-align: center;
    width: 30px
}

.hatena-module-profile .hatena-module-title::before {
    content: "\f016"
}

.hatena-module-search-box .hatena-module-title::before {
    content: "\f01a"
}

.hatena-module-recent-entries .hatena-module-title::before {
    content: "\f031"
}

.hatena-module-archive .hatena-module-title::before {
    content: "\f039"
}

.hatena-module-links .hatena-module-title::before {
    content: "\f042"
}

.hatena-module-related-entries .hatena-module-title::before {
    content: "\f013"
}

.hatena-module-entries-access-ranking .hatena-module-title::before {
    content: "\f050"
}

.hatena-module-category .hatena-module-title::before {
    content: "\f022"
}

.hatena-module-recent-comments .hatena-module-title::before {
    content: "\f01d"
}

.hatena-module-html .hatena-module-title::before {
    content: "\f710"
}

.hatena-module-circles .hatena-module-title::before {
    content: "\f021"
}

.hatena-module-authors-list .hatena-module-title::before {   
    content: "\f00b"
}

/* @hatena-module-body
====================================== */

.hatena-module-body {
    padding: 0 .9375em
}

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

.hatena-module-profile .profile-icon {
    background-clip: padding-box;
    border-radius :5px
}

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

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

.hatena-module-profile .id {
    display: block;
    font-weight: 700;
    line-height: 2;
    margin-bottom: .3125em
}

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

.hatena-module-profile .profile-description p {
    font-size: .9rem;
    margin-top: 0
}

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

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

.hatena-urllist li {
    font-weight: 700;
    padding: .5em 0 .5em .25em
}

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

.hatena-urllist li a:hover {
    color: hsl(0 100% 70%)
}

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

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

@media (min-width: 768px) and (max-width: 1099px) {
    #box2 .hatena-urllist li .urllist-image {
       border-radius: 50%;
       width: 64px
    }
}

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

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

@media (min-width: 768px) and (max-width: 1099px) {
    #box2 .hatena-urllist li .urllist-title-link {
        font-size: .75rem
    }
}

/* @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
}

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

.urllist-date-link a {
    color: hsl(0 0% 60%);
    font-size: .7rem
}

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

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

.hatena-urllist .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
====================================== */

.hatena-module-search-box .search-form {
    background-clip: padding-box;
    background-color: hsl(0 0% 95%);
    border-radius: 4px;
    height: 40px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center
}

.hatena-module-search-box .search-module-input {
    background: none;
    border: none;
    height: 20px;
    opacity: .55;
    outline: none;
    text-indent: .5em;
    width: calc(100% - 45px)
}

.hatena-module-search-box .search-module-button {
    background: url(https://cdn.blog.st-hatena.com/images/theme/search.png?version=e0e0a3993d8aff6a6344f19dd784d5) no-repeat center;
    background-size: 20px 20px;
    border: none;
    color: transparent;
    cursor: pointer;
    height: 40px;
    opacity: .55;
    outline: none;
    width: 40px 
}

.hatena-module-search-box .search-module-button:hover {
    opacity: .87
}

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

#box2 .hatena-module-entries-access-ranking {
    counter-reset: rank
}

#box2 .hatena-module-entries-access-ranking .hatena-urllist li {
    counter-increment: rank;
    margin: .7em 0;
    padding: 0;
    position: relative
}

#box2 .hatena-module-entries-access-ranking .hatena-urllist li::before {
    background-color: hsl(120 100% 50% / .95);
    border-radius: 50%;
    color: hsl(0 0% 100%);
    content: counter(rank);
    display: block;
    font-size: 1rem;
    font-weight: 700;
    height: 20px;
    line-height: 20px;
    position: absolute;
    top: 0;
    left: 0;
    text-align: center;
    width: 20px
}

#box2 .hatena-module-entries-access-ranking .hatena-urllist li:first-of-type::before {
    background-color: hsl(40 100% 55% / .95)
}

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

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

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

#box2 .hatena-module-entries-access-ranking .urllist-date-link,
#box2 .hatena-module-entries-access-ranking .urllist-title-link {
    margin-left: 2em /* 1.5625em */
}

#box2 .hatena-module-entries-access-ranking .urllist-title-link {
    display: inline-block
}

#box2 .hatena-module-entries-access-ranking .urllist-image-link+.urllist-date-link,
#box2 .hatena-module-entries-access-ranking .urllist-image-link+.urllist-title-link,
#box2 .hatena-module-entries-access-ranking .urllist-image-link+.urllist-date-link+.urllist-title-link {
    margin-left: 0
}

#box2 .hatena-module-entries-access-ranking .urllist-image-link+.urllist-title-link,
#box2 .hatena-module-entries-access-ranking .urllist-image-link+.urllist-date-link+.urllist-title-link {
    display: inline
}

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

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

.hatena-module-category .hatena-urllist li a::before,
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
}

.hatena-module-category .hatena-urllist li a:hover::before,
ul.archive-module-months li a:hover::before  {
    left: 8px
}

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

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

.hatena-module-html ul {
    list-style: none
}

.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 {
    border: 1px solid hsl(0 0% 87%);
    padding: 1em
}

.hatena-module-circles .hatena-urllist li:nth-of-type(n+2) {
    border-top: none
}

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

.hatena-module-circles .hatena-urllist li:first-of-type a {
    color: hsl(349 53% 54%)
}

.hatena-module-circles .hatena-urllist li:nth-of-type(2) a {
    color: hsl(105 100% 20%)
}

.hatena-module-circles .hatena-urllist li:nth-of-type(3) a {
    color: hsl(195 100% 27%)
}

.hatena-module-circles .hatena-urllist li:nth-of-type(4) a {
    color: hsl(30 100% 22%) 
}

.hatena-module-circles .hatena-urllist li:nth-of-type(n+5) a {
    color: hsl(0 22% 58%) 
}

/* @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-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 {
    border-bottom: 1px solid hsl(0 0% 96%);
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: .3125em;
    padding-left: 1.25em
}

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

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

.page-archive .breadcrumb {
    display: none
}

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

.archive-header-category {
    margin-bottom: 1.5rem
}

/* @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: 480px) {
    .page-archive .archive-entries {
        flex-flow: row wrap;
        justify-content: space-between
    }
}

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

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

@media (min-width: 480px) {
    .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;
    object-fit: cover;
    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: .4em;
    order: 1;
    display: flex;
    flex-direction: column-reverse
}

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

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

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

.archive-entry .archive-entry-header .date {
    font-size: .625rem;
    margin: .5em 0 .2em
}

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

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

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

.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-top: .6em */
}

/* @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: 2px
}

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

#footer {
    color: hsl(0 0% 53%);
    font-size: .8rem;
    padding: .625em 1.25em;
    text-align: center
}

#footer a {
    color: hsl(0 0% 53%)
}

#footer p {
    margin: .5em auto
}

#footer address img {
    display: inline-block
}

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

/* End system
   ========================================================================== */
/* </system> */
/* <system section="background" selected="fff"> */
body{background:#fff;}
/* </system> */
/* 日付の背景色を変更する */

.date a {
    background-color: #b09a82
}

.date-last-updated {
    background-color: #b09a82
}
/* サイドバーのアイコンの色を変更する */
 
.hatena-module-title::before {
    background-color: #b09a82
}
/* サイドバーのタイトル下の下線の色を変更する */
 
.hatena-module-title::after {
    background: linear-gradient(to right,#b09a82,transparent)
}
.entry-header::before {
    border-bottom: solid 2px #b09a82
}
.entry-date time {
    background-color: #b09a82;
}
/* アーカイブページ(記事一覧ページ)のアイキャッチ画像を4:3にする */
 
.page-archive .archive-entry .entry-thumb {
    aspect-ratio: 4 / 3
}
.page-archive .archive-entry .entry-thumb-link {
    padding-top: 5%;
}
.profile-icon{
    border-radius: 50%;
}
.urllist-image{
    border-radius:50%;
}
.entry {
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    border-radius: 10px;
}
.header-image-only #blog-title #blog-title-inner {
  position: relative;
  background-size: cover;
  height: auto;
}
 
.header-image-only #blog-title #blog-title-inner:before {
  display: block;
  content: "";
  width: 100%;
  padding-top: 20%;
}
 
.header-image-only #blog-title #blog-title-content {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
/*リンクカラー*/
.entry-content a {
  color: #FF668C;
}
/*マウスをのせたとき*/
a:hover{
     color:#333333;
}
/*訪問後のリンク*/
a:visited {
    color:#b7b7b7;
}
/*改行時の行間調整*/
.entry-content p {
margin: 0;
}
.entry-content {
    font-size:15px;
}
.subscription-count-box {
display:none !important;
}
.hatena-module {
margin-bottom:20px;
}
/* Myカスタマイズ */
.entry-content p { line-height: 1.8em; margin:0;}
/*サイドバータブメニュー*/
.tab{
    display: inline-block;
    padding: 8px 5px 5px 5px;/*横に入りきらない場合はこの２番目と４番目の数字を小さく*/
    background: #f0f0f0;/*反応していないタブの背景色*/
    border-radius: 5px 5px 0 0;
    font-size: 12px;/*横に入りきらない場合はここの数字を小さく*/
    cursor: pointer;
}
.active{
    color: white;
    background:#b09a82;/*反応しているタブの背景色*/
    border-radius: 5px 5px 0 0;
}
.hatena-module-title2{
    border-bottom: 3px solid #b09a82;/*タブの下線*/
}
/* Categoryをタイル表示に変更（Innocent） */
.hatena-module-category .hatena-urllist {
margin: 0 0 -6px;
padding: 0;
}
.hatena-module-category .hatena-urllist li::before {
content: none;
}
.hatena-module-category .hatena-urllist li {
border-top: 0;
display: block;
float: left;
margin: 0 6px 6px 0;
padding: 0;
}
.hatena-module-category .hatena-urllist li a {
border: 1px solid #f999999;
border-radius: 2px;
display: block;
font-size: 0.8667em;
line-height: 30px;
padding: 0 10px;
}
.hatena-module-category .hatena-urllist li a:hover {
background-color: #f6f6f6;
color: #333;
}
#g-nav {
    display: table;
    width: 100%;
    font-weight: bold;
    background-color: #ffffff;/* 背景色 */
}
.nav-item {
    display: table-cell;
    width: calc(100% / 6);
   list-style-type: none;
   text-align: center;
}
.nav-item a {
    display: block;
    color: #fff;/* 文字色 */
    padding: 0px 0;
    text-decoration: none;
}
@media(max-width: 768px) {
    #g-nav {
        display: block;
    overflow-x: auto;
    }
    .nav-item a {
        display: inline-block;
        white-space: nowrap;
        padding: 0px 0px;
    }
}
.nav {
    display: block;
    background-color: #ffffff;/* #g-navと同じ色を指定 */
}
#g-nav {
    width: 90%;/* ナビゲーションの幅 */
    margin: 0 auto;
    margin: 0px 0px 25px 0px; /*全体の周囲の余白 上右下左の順*/
}
pre::-webkit-scrollbar{
　　height: 8px;
}

pre::-webkit-scrollbar-track{
  background: rgba(#fff,0.1);
  border: none;
}

pre::-webkit-scrollbar-thumb{
　　background: rgba(#fff,0.1);
　　border-radius: 8px;
　　box-shadow: inset 0 0 4px rgba(255,255,255,0.8);
}
/*上に戻る*/
#page-top {
  display:none;
  position:fixed;
  right:10px;
  bottom:20px;
  margin: 0;
  padding: 0;
  text-align:center;
}
#move-page-top{
  color:rgba(0,0,0,0.2);
  text-decoration:none;
  display:block;
  cursor:pointer;
}
#move-page-top:hover{
  color:rgba(0,0,0,0.4);
}
/* 吹き出しのCSS　*/
.entry-content .l-fuki,
.entry-content .r-fuki {
  position: relative;
  width: calc(100% - 82px);
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  padding: 20px;
  border-radius: 6px;
  border: 2px solid #ddd;
  box-shadow: 0 3px 8px -2px rgba(0,0,0,.16);
  background-color: #fff;
  z-index: 1;
  box-sizing: border-box;
}
.entry-content .l-fuki {
  margin: 20px auto 36px 0;
}
.entry-content .r-fuki {
  margin: 20px 0 36px auto;
}
.entry-content .l-fuki::before,
.entry-content .r-fuki::before {
  position: absolute;
  content: "";
  top: 16px;
  width: 10px;
  height: 10px;
  border-right: 2px solid #ddd;
  border-bottom: 2px solid #ddd;
  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: 60px;
  height: 60px;
  top: -6px;
  border-radius: 50%;
  border: 3px solid #fff;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  box-shadow: 1px 1px 5px #aaa;
  box-sizing: border-box;
}
.entry-content .l-fuki::after {
  right: -82px;
}
.entry-content .r-fuki::after {
  left: -82px;
}
@media screen and (min-width: 478px) {
  .entry-content .l-fuki::after,
  .entry-content .r-fuki::after {
    width: 80px;
    height: 80px;
  }
  .entry-content .l-fuki,
  .entry-content .r-fuki {
    width: calc(100% - 106px);
  }
  .entry-content .l-fuki::after {
    right: -106px;
  }
  .entry-content .r-fuki::after {
    left: -106px;
  }
}
.luca::after {background-image:url(https://cdn-ak.f.st-hatena.com/images/fotolife/r/ririblo/20200128/20200128100447.gif);}
.sara::after {background-image:url(https://cdn-ak.f.st-hatena.com/images/fotolife/r/ririblo/20200128/20200128100457.gif);}
.subscribe-button {
  margin: 1em 0;
}
.subscribe-button a {
  display: inline-block;
  margin: 0 auto;
  width: 100%;
  max-width: 120px;
  line-height: 30px;
  text-decoration: none;
  text-align: center;
  color: #fff;
  background-color: #866d52; /* ここでボタンの色 */
  box-shadow: 0 4px #b09a82; /* ここでボタンの影の部分の色 */
  border-radius: 4px;
  transition: all .3s;
}
.subscribe-button a:hover {
  transform: translateY(4px);
  box-shadow: 0 0 #999;
}
/*太文字マーカー*/
.entry-content strong {background: linear-gradient(transparent 60%, #ffffff 80%);
}