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

/*アンダーバー*/
article u{

    text-decoration: none;

    background: linear-gradient(transparent 50%, #fff3b8 50%);
}


/*--------------------------------------
  ヨメレバ・カエレバ（レスポンシブ）
--------------------------------------*/
/*=================================================================================
	カエレバ・ヨメレバ・トマレバ
=================================================================================*/

.cstmreba {
	width:98%;
	height:auto;
	margin:36px auto;
	font-family:'Lucida Grande','Hiragino Kaku Gothic ProN',Helvetica, Meiryo, sans-serif;
	line-height: 1.5;
	word-wrap: break-word;
	box-sizing: border-box;
	display: block;
}
/* WordPressで自動挿入されるPタグの余白を対処 */
.cstmreba p {
	margin: 0;
	padding: 0;
}
.cstmreba a {
	transition: 0.8s ;
	color:#285EFF; /* テキストリンクカラー */
}
.cstmreba a:hover {
	color:#FFCA28; /* テキストリンクカラー(マウスオーバー時) */
}
.cstmreba .booklink-box,
.cstmreba .kaerebalink-box,
.cstmreba .tomarebalink-box {
	width: 100%;
	background-color: #fafafa; /* 全体の背景カラー */
	overflow: hidden;
	border-radius: 0px;
	box-sizing: border-box;
	padding: 12px 8px;
	box-shadow: 0px 2px 5px 0 rgba(0,0,0,.26);
}
/* サムネイル画像ボックス */
.cstmreba .booklink-image,
.cstmreba .kaerebalink-image,
.cstmreba .tomarebalink-image {
	width:150px;
	float:left;
	margin:0 14px 0 0;
	text-align: center;
	background: #fff;
}
.cstmreba .booklink-image a,
.cstmreba .kaerebalink-image a,
.cstmreba .tomarebalink-image a {
	width:100%;
	display:block;
}
.cstmreba .booklink-image a img,
.cstmreba .kaerebalink-image a img,
.cstmreba .tomarebalink-image a img {
	margin:0 ;
	padding: 0;
	text-align:center;
	background: #fff;
}
.cstmreba .booklink-info,.cstmreba .kaerebalink-info,.cstmreba .tomarebalink-info {
	overflow:hidden;
	line-height:170%;
	color: #333;
}
/* infoボックス内リンク下線非表示 */
.cstmreba .booklink-info a,
.cstmreba .kaerebalink-info a,
.cstmreba .tomarebalink-info a {
	text-decoration: none;
}
/* 作品・商品・ホテル名 リンク */
.cstmreba .booklink-name>a,
.cstmreba .kaerebalink-name>a,
.cstmreba .tomarebalink-name>a {
	border-bottom: 1px solid ;
	font-size:16px;
}
/* powered by */
.cstmreba .booklink-powered-date,
.cstmreba .kaerebalink-powered-date,
.cstmreba .tomarebalink-powered-date {
	font-size:10px;
	line-height:150%;
}
.cstmreba .booklink-powered-date a,
.cstmreba .kaerebalink-powered-date a,
.cstmreba .tomarebalink-powered-date a {
	color:#333;
	border-bottom: none ;
}
.cstmreba .booklink-powered-date a:hover,
.cstmreba .kaerebalink-powered-date a:hover,
.cstmreba .tomarebalink-powered-date a:hover {
	color:#333;
	border-bottom: 1px solid #333 ;
}
/* 著者・住所 */
.cstmreba .booklink-detail,.cstmreba .kaerebalink-detail,.cstmreba .tomarebalink-address {
	font-size:12px;
}
.cstmreba .kaerebalink-link1 div img,.cstmreba .booklink-link2 div img,.cstmreba .tomarebalink-link1 div img {
	display:none !important;
}
.cstmreba .kaerebalink-link1, .cstmreba .booklink-link2,.cstmreba .tomarebalink-link1 {
	display: inline-block;
	width: 100%;
	margin-top: 5px;
}
.cstmreba .booklink-link2>div,
.cstmreba .kaerebalink-link1>div,
.cstmreba .tomarebalink-link1>div {
	float:left;
	width:24%;
	min-width:128px;
	margin:0.5%;
}
/***** ボタンデザインここから ******/
.cstmreba .booklink-link2 a,
.cstmreba .kaerebalink-link1 a,
.cstmreba .tomarebalink-link1 a {
	width: 100%;
	display: inline-block;
	text-align: center;
	box-sizing: border-box;
	margin: 1px 0;
	padding:3% 0.5%;
	border-radius: 8px;
	font-size: 13px;
	font-weight: bold;
	line-height: 180%;
	color: #fff;
	box-shadow: 0px 2px 4px 0 rgba(0,0,0,.26);
}
/* トマレバ */
.cstmreba .tomarebalink-link1 .shoplinkrakuten a {background: #76ae25; border: 2px solid #76ae25; }/* 楽天トラベル */
.cstmreba .tomarebalink-link1 .shoplinkjalan a { background: #ff7a15; border: 2px solid #ff7a15;}/* じゃらん */
.cstmreba .tomarebalink-link1 .shoplinkjtb a { background: #c81528; border: 2px solid #c81528;}/* JTB */
.cstmreba .tomarebalink-link1 .shoplinkknt a { background: #0b499d; border: 2px solid #0b499d;}/* KNT */
.cstmreba .tomarebalink-link1 .shoplinkikyu a { background: #bf9500; border: 2px solid #bf9500;}/* 一休 */
.cstmreba .tomarebalink-link1 .shoplinkrurubu a { background: #000066; border: 2px solid #000066;}/* るるぶ */
.cstmreba .tomarebalink-link1 .shoplinkyahoo a { background: #ff0033; border: 2px solid #ff0033;}/* Yahoo!トラベル */
.cstmreba .tomarebalink-link1 .shoplinkhis a { background: #004bb0; border: 2px solid #004bb0;}/*** HIS ***/
/* カエレバ */
.cstmreba .kaerebalink-link1 .shoplinkyahoo a {background:#ff0033; border:2px solid #ff0033; letter-spacing:normal;} /* Yahoo!ショッピング */
.cstmreba .kaerebalink-link1 .shoplinkbellemaison a { background:#84be24 ; border: 2px solid #84be24;}	/* ベルメゾン */
.cstmreba .kaerebalink-link1 .shoplinkcecile a { background:#8d124b; border: 2px solid #8d124b;} /* セシール */
.cstmreba .kaerebalink-link1 .shoplinkwowma a { background:#ea5404; border: 2px solid #ea5404;} /* Wowma */
.cstmreba .kaerebalink-link1 .shoplinkkakakucom a {background:#314995; border: 2px solid #314995;} /* 価格コム */
/* ヨメレバ */
.cstmreba .booklink-link2 .shoplinkkindle a { background:#007dcd; border: 2px solid #007dcd;} /* Kindle */
.cstmreba .booklink-link2 .shoplinkrakukobo a { background:#bf0000; border: 2px solid #bf0000;} /* 楽天kobo */
.cstmreba .booklink-link2  .shoplinkbk1 a { background:#0085cd; border: 2px solid #0085cd;} /* honto */
.cstmreba .booklink-link2 .shoplinkehon a { background:#2a2c6d; border: 2px solid #2a2c6d;} /* ehon */
.cstmreba .booklink-link2 .shoplinkkino a { background:#003e92; border: 2px solid #003e92;} /* 紀伊國屋書店 */
.cstmreba .booklink-link2 .shoplinkebj a { background:#f8485e; border: 2px solid #f8485e;} /* ebookjapan */
.cstmreba .booklink-link2 .shoplinktoshokan a { background:#333333; border: 2px solid #333333;} /* 図書館 */
/* カエレバ・ヨメレバ共通 */
.cstmreba .kaerebalink-link1 .shoplinkamazon a,
.cstmreba .booklink-link2 .shoplinkamazon a {
	background:#FF9901;
	border: 2px solid #ff9901;
} /* Amazon */
.cstmreba .kaerebalink-link1 .shoplinkrakuten a,
.cstmreba .booklink-link2 .shoplinkrakuten a {
	background: #bf0000;
	border: 2px solid #bf0000;
} /* 楽天 */
.cstmreba .kaerebalink-link1 .shoplinkseven a,
.cstmreba .booklink-link2 .shoplinkseven a {
	background:#225496;
	border: 2px solid #225496;
} /* 7net */
/****** ボタンカラー ここまで *****/

/***** ボタンデザイン　マウスオーバー時ここから *****/
.cstmreba .booklink-link2 a:hover,
.cstmreba .kaerebalink-link1 a:hover,
.cstmreba .tomarebalink-link1 a:hover {
	background: #fff;
}
/* トマレバ */
.cstmreba .tomarebalink-link1 .shoplinkrakuten a:hover { color: #76ae25; }/* 楽天トラベル */
.cstmreba .tomarebalink-link1 .shoplinkjalan a:hover { color: #ff7a15; }/* じゃらん */
.cstmreba .tomarebalink-link1 .shoplinkjtb a:hover { color: #c81528; }/* JTB */
.cstmreba .tomarebalink-link1 .shoplinkknt a:hover { color: #0b499d; }/* KNT */
.cstmreba .tomarebalink-link1 .shoplinkikyu a:hover { color: #bf9500; }/* 一休 */
.cstmreba .tomarebalink-link1 .shoplinkrurubu a:hover { color: #000066; }/* るるぶ */
.cstmreba .tomarebalink-link1 .shoplinkyahoo a:hover { color: #ff0033; }/* Yahoo!トラベル */
.cstmreba .tomarebalink-link1 .shoplinkhis a:hover { color: #004bb0; }/*** HIS ***/
/* カエレバ */
.cstmreba .kaerebalink-link1 .shoplinkyahoo a:hover {color:#ff0033;} /* Yahoo!ショッピング */
.cstmreba .kaerebalink-link1 .shoplinkbellemaison a:hover { color:#84be24 ; }	/* ベルメゾン */
.cstmreba .kaerebalink-link1 .shoplinkcecile a:hover { color:#8d124b; } /* セシール */
.cstmreba .kaerebalink-link1 .shoplinkwowma a:hover { color:#ea5404; } /* Wowma */
.cstmreba .kaerebalink-link1 .shoplinkkakakucom a:hover {color:#314995;} /* 価格コム */
/* ヨメレバ */
.cstmreba .booklink-link2 .shoplinkkindle a:hover { color:#007dcd;} /* Kindle */
.cstmreba .booklink-link2 .shoplinkrakukobo a:hover { color:#bf0000; } /* 楽天kobo */
.cstmreba .booklink-link2 .shoplinkbk1 a:hover { color:#0085cd; } /* honto */
.cstmreba .booklink-link2 .shoplinkehon a:hover { color:#2a2c6d; } /* ehon */
.cstmreba .booklink-link2 .shoplinkkino a:hover { color:#003e92; } /* 紀伊國屋書店 */
.cstmreba .booklink-link2 .shoplinkebj a:hover { color:#f8485e; } /* ebookjapan */
.cstmreba .booklink-link2 .shoplinktoshokan a:hover { color:#333333; } /* 図書館 */
/* カエレバ・ヨメレバ共通 */
.cstmreba .kaerebalink-link1 .shoplinkamazon a:hover,
.cstmreba .booklink-link2 .shoplinkamazon a:hover {
	color:#FF9901; } /* Amazon */
.cstmreba .kaerebalink-link1 .shoplinkrakuten a:hover,
.cstmreba .booklink-link2 .shoplinkrakuten a:hover {
	color: #bf0000; } /* 楽天 */
.cstmreba .kaerebalink-link1 .shoplinkseven a:hover,
.cstmreba .booklink-link2 .shoplinkseven a:hover {
	color:#225496;} /* 7net */
/***** ボタンデザイン　マウスオーバー時ここまで *****/
.cstmreba .booklink-footer {
	clear:both;
}

/*****  解像度768px以下のスタイル *****/
@media screen and (max-width:768px){
	.cstmreba .booklink-image,
	.cstmreba .kaerebalink-image,
	.cstmreba .tomarebalink-image {
		width:100%;
		float:none;
	}
	.cstmreba .booklink-link2>div,
	.cstmreba .kaerebalink-link1>div,
	.cstmreba .tomarebalink-link1>div {
		width: 32.33%;
		margin: 0.5%;
	}
	.cstmreba .booklink-info,
	.cstmreba .kaerebalink-info,
	.cstmreba .tomarebalink-info {
	  text-align:center;
	  padding-bottom: 1px;
	}
}

/*****  解像度480px以下のスタイル *****/
@media screen and (max-width:480px){
	.cstmreba .booklink-link2>div,
	.cstmreba .kaerebalink-link1>div,
	.cstmreba .tomarebalink-link1>div {
		width: 49%;
		margin: 0.5%;
	}
}
/*↓----ヨメレバ・カエレバここまで----↓*/

/* 赤ボタン単一 */
 
.red-btn {
    font-size:16px;
    margin-left: auto;
    margin-right: auto;
    display: block;
    width: 300px;
    margin-bottom: 1em;
}
 
.red-btn a {
    display: block;
    position: relative;
    z-index: 2;
    overflow: hidden;
    width: 100%;
    font-weight: bold ;
    box-shadow:2px 2px 2px #555;  
    border-radius: 5px;
    background-color:#ed254e;
    color: #ffffff !important;
    padding: 12px 0;
    text-align: center;
    text-decoration: none;
    transition: .25s linear;
    -webkit-transition: .25s linear;
    -moz-transition: .25s linear;
}
 
.red-btn a:hover {
    -ms-transform: translateY(4px);
    -webkit-transform: translateY(4px);
    transform: translateY(4px);/*下に動く*/
    border-bottom: none;/*線を消す*/
    box-shadow:none;
}
/* 赤ボタン単一ここまで */

/* 緑ボタン単一ここまで */
.green-btn {
    font-size:16px;
    margin-left: auto;
    margin-right: auto;
    display: block;
    width: 300px;
    margin-bottom: 1em;
}
 
.green-btn a {
    display: block;
    position: relative;
    z-index: 2;
    overflow: hidden;
    width: 100%;
    font-weight: bold ;
    box-shadow:2px 2px 2px #555;  
    border-radius: 5px;
    background-color:#61C1BE;
    color: #ffffff !important;
    padding: 12px 0;
    text-align: center;
    text-decoration: none;
    transition: .25s linear;
    -webkit-transition: .25s linear;
    -moz-transition: .25s linear;
}
 
.green-btn a:hover {
    -ms-transform: translateY(4px);
    -webkit-transform: translateY(4px);
    transform: translateY(4px);/*下に動く*/
    border-bottom: none;/*線を消す*/
    box-shadow:none;
}
/* 緑ボタン単一ここまで */
/* オレンジボタン単一ここから */

.article-btn a{
 display:block;
 text-decoration:none;
 padding:7px 10px;
 border-radius:4px;
 font-weight:bold;
 margin-left: auto;
 margin-right: auto;
 width: 100%;
 position: relative;
 color:white;/* ボタンの文字色 */
 background-color:#f6ad49;/* ボタンの背景色 */
 box-shadow:0 2px #541a0b;/* ボタンの影の色 */
 transition:transform 0.3s;
 text-align:center;
}
.article-btn a:hover{
    transform:scale(1.1);
}
/* オレンジボタン単一ここまで */
/* 左ボタン（横並び） */
.left-btn {
    width: 100%;  /*ボタンの横幅 */
    text-align: center;  /*ボタン内の文字中央寄せ */
    border-radius: 5px;  /*ボタンの角を少し丸く */
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    font-weight: bold;  /*ボタン内文字は太字 */
}
 
.left-btn a {
    display: block;
    position: relative;
    z-index: 2;
    overflow: hidden;
    width: 100%;
    font-weight: bold ;
    box-shadow:2px 2px 2px #555;  
    border-radius: 5px;
    background-color: #1bb4d3;
    color: #ffffff !important;
    padding: 12px 0;
    text-align: center;
    text-decoration: none;
    transition: .25s linear;
    -webkit-transition: .25s linear;
    -moz-transition: .25s linear;
}
 
.left-btn a:hover {
    -ms-transform: translateY(4px);
    -webkit-transform: translateY(4px);
    transform: translateY(4px);/*下に動く*/
    border-bottom: none;/*線を消す*/
 box-shadow:none;
}
 
/* 右ボタン（横並び） */
.right-btn {
    text-align:center;
    width: 100%;
    float:left;
    color:#fff;
    font-weight:bold;
    border-radius: 5px;  
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
}
 
.right-btn a {
    display: block;
    position: relative;
    z-index: 2;
    overflow: hidden;
    width: 100%;
    font-weight: bold ;
    box-shadow:2px 2px 2px #555;  
    border-radius: 5px;
    background-color: #C81C1C;
    color: #ffffff !important;
    padding: 12px 0;
    text-align: center;
    text-decoration: none;
    transition: .25s linear;
    -webkit-transition: .25s linear;
    -moz-transition: .25s linear;
}
 
.right-btn a:hover {
    -ms-transform: translateY(4px);
    -webkit-transform: translateY(4px);
    transform: translateY(4px);/*下に動く*/
    border-bottom: none;/*線を消す*/
    box-shadow:none;
}
 
.box-main {
    text-align:center;
    font-size:15px;
    margin-bottom: 1em;
}
 
.box-main:after {
    content:"";
    display:block;
    clear:both;
}
 
@media screen and (min-width: 600px) {
 
.right-btn {
    width:48%;
    margin-left:10px;
}
 
.left-btn {
    width:48%;
    float:left;
    margin-right: 10px;
    margin-left:0;
}
}
/* 左→ボタン（横並び）ここまで */

/*↓----更新日時表示----↓*/

/*↑----更新日時表示----↑*/

/* 吹き出しの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;
}
}

.rakuda::after {background-image:url(https://cdn-ak.f.st-hatena.com/images/fotolife/b/beef58/20191212/20191212120104.png);}

.ushi::after {background-image:url(https://cdn-ak.f.st-hatena.com/images/fotolife/b/beef58/20191212/20191212110440.png);}
/*↑----吹き出しCSS----↑*/

/*アイコンの枠リスト*/

/*アイコンの枠リストここまで*/

/*↓----ボックスラベルCSS----↓*/
.box28 {
    position: relative;
    margin: 2em 0;
    padding: 25px 10px 7px;
    border: solid 2px #FFC107;
    max-width: auto%;
	max-height:auto%;
}
.box28 .box-title {
    position: absolute;
    display: inline-block;
    top: -2px;
    left: -2px;
    padding: 0 9px;
    height: 25px;
    line-height: 25px;
    font-size: 17px;
    background: #FFC107;
    color: #ffffff;
    font-weight: bold;
}
.box28 p {
    margin: 0; 
    padding: 0;
}

.awaseteyomu {
    position: relative;
    margin: 2em 0;
    padding: 25px 10px 7px;
    border: solid 2px #FFC107;
}
.awaseteyomu .box-title {
    position: absolute;
    display: inline-block;
    top: -2px;
    left: -2px;
    padding: 0 9px;
    height: 25px;
    line-height: 25px;
    font-size: 17px;
    background: #FFC107;
    color: #ffffff;
    font-weight: bold;
}
.awaseteyomu .box-img{
	max-width: 30%;
	}
.awaseteyomu .mgr-10{
    margin-right : 10px;
}
.awaseteyomu p {
    margin: 0; 
    padding: 0;
}


.awaseteyomu .box-title:before {/*疑似要素*/
  font-family: "Font Awesome 5 Free";
  content: "\f518";/*アイコンの種類*/
  position: absolute;
  left : 1em;/*左端からのアイコンまでの距離*/
  color: #ffffff;/*アイコン色*/
}

/*↑----ボックスラベルCSS----↑*/
/*↓----ボックスラベルCSS----↓*/
.box26 {
    position: relative;
    margin: 2em 0;
    padding: 0.5em 1em;
    border: solid 3px #95ccff;
    border-radius: 8px;
}
.box26 .box-title {
    position: absolute;
    display: inline-block;
    top: -13px;
    left: 10px;
    padding: 0 9px;
    line-height: 1;
    font-size: 19px;
    background: #FFF;
    color: #95ccff;
    font-weight: bold;
}
.box26 p {
    margin: 0; 
    padding: 0;
}
/*↑----ボックスラベルCSS----↑*/
/*↓----ボックスラベルCSS----↓*/
.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;
}
/*↑----ボックスラベルCSS----↑*/

/*↓----左ラインボックスラベルCSS----↓*/
.box8 {
    padding: 0.5em 1em;
    margin: 2em 0;
    color: #232323;
    background: #fff8e8;
    border-left: solid 10px #ffc06e;
}
.box8 p {
    margin: 0; 
    padding: 0;
}
/*↑----左ラインボックスラベルCSS----↑*/

/*↓----ピンク枠ボックスラベルCSS----↓*/
.box15 {
    padding: 0.2em 0.5em;
    margin: 2em 0;
    color: #565656;
    background: #ffeaea;
    box-shadow: 0px 0px 0px 10px #ffeaea;
    border: dashed 2px #ffc3c3;
    border-radius: 8px;
}
.box15 p {
    margin: 0; 
    padding: 0;
}
/*↑----ピンク枠ボックスラベルCSS----↑*/

/*↓----シンプル枠ボックスラベルCSS----↓*/
.box3orenge {
    padding: 0.5em 1em;
    margin: 2em 0;
    color: #2c2c2f;
    background: #FFFCDB;/*背景色*/
}
.box3orenge p {
    margin: 0; 
    padding: 0;
}
/*↑----シンプル枠ボックスラベルCSS----↑*/

/*↓----シンプル枠ボックスラベルCSS----↓*/
.box3pink {
    padding: 0.5em 1em;
    margin: 2em 0;
    color: #2c2c2f;
    background: #FFDDEE;/*背景色*/
}
.box3pink p {
    margin: 0; 
    padding: 0;
}
/*↑----シンプル枠ボックスラベルCSS----↑*/

/*↓----シンプル枠ボックスラベルCSS----↓*/
.box3 {
    padding: 0.5em 1em;
    margin: 2em 0;
    color: #2c2c2f;
    background: #e0ffef;/*背景色*/
}
.box3 p {
    margin: 0; 
    padding: 0;
}
/*↑----シンプル枠ボックスラベルCSS----↑*/

/*↓角丸枠↓*/
.box2 {
    padding: 0.5em 1em;
    margin: 2em 0;
    font-weight: bold;
    color: #6091d3;/*文字色*/
    background: #FFF;
    border: solid 3px #6091d3;/*線*/
    border-radius: 10px;/*角の丸み*/
}
.box2 p {
    margin: 0; 
    padding: 0;
}

/*↑角丸枠↑*/

/*↓破線のボックス↓*/
.box6-1 {
    padding: 0.5em 1em;
    margin: 2em 0;
    background: #f0f7ff;
    border: dashed 2px #5b8bd0;/*点線*/
}
.box6-1 p {
    margin: 0; 
    padding: 0;
}
/*↑破線のボックス↑*/

/*↓破線のボックス背景白↓*/
.box6-2 {
    padding: 0.5em 1em;
    margin: 2em 0;
    background: #ffffff;
    border: dashed 2px #5b8bd0;/*点線*/
}
.box6-2 p {
    margin: 0; 
    padding: 0;
}
/*↑破線のボックス↑*/

/* ヘッダー下のスライド*/
/*↓↓はてなユーザーは横幅がMAXにならない場合入れた方が良いかも↓↓ */
	#top-editarea {
	width: 100%;
	margin: 0 auto 0 auto;
	}
	
	/* ↓↓大衆向け↓↓ */
	.recommends {
	margin: 0;
	width: 100%;
	}
	.recommends .carousel {
	list-style-type: none;
	background: #eee;
	padding: 12px;
	width: 100%;
	overflow-x: scroll;
	-webkit-overflow-scrolling: touch;
	white-space: nowrap;
	margin: 0;
	}
	.recommends .carousel li {
	background: #fff;
	margin: 10px;
	text-align: center;
	display: inline-block;
	word-break: break-all;
	}
	.recommends a.recommend-entry {
	display: block;
	width: 250px;
	font-size: 1rem;
	font-weight: 600;
	background: #fbfbf0;
	box-shadow: 0px 0px 3px rgba(0,0,0,0.1);
	position: relative;
	line-height: 1.5;
	}
	.recommends a.recommend-entry:hover {
	box-shadow: 0 15px 30px -5px rgba(0,0,0,.15),0 0 5px rgba(0,0,0,.1);
	transform: translateY(-4px);
	transition: 0.2s;
	background: #fbfbf0;
	}
	.recommend-title {
	display:flex ;
	padding: 0.5em 0.5em;
	word-break: break-all;
	width: 100%;
	white-space: normal;
	text-align: left;
	}
	.recommend-img{
	max-height:200px;
	width: 100%;
	}
	
	/* フッター */
	#bottom-editarea {
	width: 100%;
	margin: 0 auto;
	background: #7f8c8d;
	padding: 0;
	color: #fff;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	}
	#footer {
	text-align: center;
	color: #fff;
	background: #676F74;
	width: 100%;
	margin: 0;
	padding: 2em 40px 1em 40px;
	box-shadow: 0px 0px 3px rgba(0,0,0,0.1);
	text-align: center;
	font-size: 80%;
	}
	#blog-title-content a {
	font-size: 30px;
	font-weight: 100;
	color: #fff;
	}
	.footer-links ul {
	list-style: none;
	padding: 0;
	}
	.footer-links ul li {
	display: inline-block;
	padding: 0 6px;
	font-size: 14.5px;
	box-sizing: border-box;
	}
	.copyright {
	font-size: 10px;
	}

/*上に戻る*/
#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.4);
  text-decoration:none;
  display:block;
  cursor:pointer;
}
#move-page-top:hover{
  color:rgba(0,0,0,0.6);
}
@media only screen and (min-width: 400px){
  #page-top{
    right:50%;
    margin-right: -450px;
  }
}

*, *:before, *:after {
	padding: 0;
	margin: 0;
	box-sizing: border-box;
}
ol, ul {
	list-style: none;
}
a {
	text-decoration: none;
	color: inherit;
}
.cp_cont {
	height: 65vh;
}
/* menu */
.cp_offcm02 {
	position: relative;
	z-index: 5;
	left: 0;
	visibility: visible;
	overflow: auto;
	width: 100%;
	height: auto;
	padding-top: 0;
	text-align: center;
	opacity: 1;
}
.cp_offcm02 nav {
	background: #FFB74D;
}
.cp_offcm02 nav, .cp_offcm02 ul {
	height: 100%;
}
.cp_offcm02 li {
	display: inline-block;
	margin-right: -6px;
	border: none;
	color: #ffffff;
}
.cp_offcm02 a {
	display: block;
	padding: 12px 45px;
	-webkit-transition: background-color .3s ease-in;
					transition: background-color .3s ease-in;
}
.cp_offcm02 a:hover {
	background-color: #FF9800;
}
/* menu toggle */
#cp_toggle02 {
	display: none;
}
.cp_mobilebar {
	display: none;
}
/* content */
.cp_container {
	position: relative;
	top: 0px;
	margin-top: 0;
	padding: 35px auto;
	-webkit-transition: transform .3s ease-in;
	        transition: transform .3s ease-in;
}
.cp_content {
	margin: 0 auto;
	padding: 20px;
	height: 65vh;
	text-align: center;
}
@media (max-width: 767px) {
	/* menu */
	.cp_offcm02 {
		position: fixed;
		z-index: 2;
		top: 0;
		/* overflow-y: scroll; */
		overflow: hidden;
		height: 100%;
		padding-top: 60px;
		-webkit-transition: opacity 0.3s ease-in, visibility 0.3s ease-in 0.3s;
		        transition: opacity 0.3s ease-in, visibility 0.3s ease-in 0.3s;
		opacity: 0;
		background-color: #ffb74d;
	}
	.cp_offcm02 nav {
		background: #FFE0B2;
	}
	.cp_offcm02 li {
		display: block;
		color: #FB8C00;
		border-bottom: 1px solid #FB8C00;
	}
	.cp_offcm02 a {
		padding: 1.2em;
	}
	.cp_offcm02 a:hover {
		background-color: #FFE082;
	}
	/* menu toggle */
	.cp_mobilebar {
		display: block;
		z-index: 10;
		position: fixed;
		top: 0;
		left: 0;
		padding: 0 25px;
		width: 100%;
		height: 60px;
		background-color: #FFB74D;
		-webkit-box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
		        box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
	}
	.cp_menuicon {
		display: block;
		position: relative;
		width: 25px;
		height: 100%;
		cursor: pointer;
		-webkit-transition: transform .3s ease-in;
		        transition: transform .3s ease-in;
	}
	.cp_menuicon > span {
		display: block;
		position: absolute;
		top: 55%;
		margin-top: -0.3em;
		width: 100%;
		height: 0.2em;
		border-radius: 1px;
		background-color: #eeeeee;
		-webkit-transition: transform .3s ease-in;
		        transition: transform .3s ease-in;
	}
	.cp_menuicon > span:before, .cp_menuicon > span:after {
		content: '';
		position: absolute;
		width: 100%;
		height: 100%;
		border-radius: 1px;
		background-color: #eeeeee;
		-webkit-transition: transform .3s ease;
		        transition: transform .3s ease;
	}
	.cp_menuicon > span:before {
		-webkit-transform: translateY(-0.6em);
		        transform: translateY(-0.6em);
	}
	.cp_menuicon > span:after {
		-webkit-transform: translateY(0.6em);
		        transform: translateY(0.6em);
	}
	#cp_toggle02:checked + .cp_mobilebar .cp_menuicon {
		-webkit-transform: rotate(45deg);
		        transform: rotate(45deg);
	}
	#cp_toggle02:checked + .cp_mobilebar span:before,
	#cp_toggle02:checked + .cp_mobilebar span:after {
		-webkit-transform: rotate(90deg);
		        transform: rotate(90deg);
	}
	#cp_toggle02:checked ~ .cp_offcm02 {
		visibility: visible;
		opacity: 1;
		-webkit-transition-delay: 0s;
		        transition-delay: 0s;
	}
	/* content */
	.cp_container {
		top:60px;
	}
}

/*左からメニュー表示*/
header {
  padding:10px;
  background: #FFFFFF;
}

#nav-drawer {
  position: relative;
}

/*チェックボックス等は非表示に*/
.nav-unshown {
  display:none;
}

/*アイコンのスペース*/
#nav-open {
  display: inline-block;
  width: 30px;
  height: 22px;
  vertical-align: middle;
}




/*ハンバーガーアイコンをCSSだけで表現*/
#nav-open span, #nav-open span:before, #nav-open span:after {
  position: absolute;
  height: 3px;/*線の太さ*/
  width: 25px;/*長さ*/
  border-radius: 3px;
  background: #555;
  display: block;
  content: '';
  cursor: pointer;
}
#nav-open span:before {
  bottom: -8px;
}
#nav-open span:after {
  bottom: -16px;
}

/*閉じる用の薄黒カバー*/
#nav-close {
  display: none;/*はじめは隠しておく*/
  position: fixed;
  z-index: 99;
  top: 0;/*全体に広がるように*/
  left: 0;
  width: 100%;
  height: 100%;
  background: black;
  opacity: 0;
  transition: .3s ease-in-out;
}

/*中身*/
#nav-content {
  overflow: auto;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;/*最前面に*/
  width: 90%;/*右側に隙間を作る（閉じるカバーを表示）*/
  max-width: 330px;/*最大幅（調整してください）*/
  height: 100%;
  background: #fff;/*背景色*/
  transition: .3s ease-in-out;/*滑らかに表示*/
  -webkit-transform: translateX(-105%);
  transform: translateX(-105%);/*左に隠しておく*/
}

/*チェックが入ったらもろもろ表示*/
#nav-input:checked ~ #nav-close {
  display: block;/*カバーを表示*/
  opacity: .5;
}

#nav-input:checked ~ #nav-content {
  -webkit-transform: translateX(0%);
  transform: translateX(0%);/*中身を表示（右へスライド）*/
  box-shadow: 6px 0 25px rgba(0,0,0,.15);
}

/*menu中身*/
ul.sidenav {
	list-style-type: none;
	margin: 0;
	padding: 0;
	width: 200px;
	background-color: #00ced1;
	position: relative;
	overflow: auto;
}
ul.sidenav li a {
	display: block;
	color: #000000;
	padding: 8px 16px;
	text-decoration: none;
}
ul.sidenav li a.active {
	background-color: #bdb76b;
	color: white;
}
ul.sidenav li a:hover:not(.active) {
	background-color: #5f9ea0;
	color: white;
}
div.content {
	margin-left: 25%;
	padding: 1px 16px;
	height: 1000px;
}
@media screen and (max-width: 900px) {
	ul.sidenav {
		width: 100%;
		height: auto;
		position: relative;
	}
	ul.sidenav li a {
		float: left;
		padding: 15px;
	}
	div.content {
		margin-left: 0;
	}
}
@media screen and (max-width: 480px) {
	ul.sidenav li a {
		text-align: center;
		float: none;
	}
}



/*SNSシェア*/
.sns-header, .sns-footer {
    padding: 0 24px;
}

.sns-area {
    margin: 30px auto 10px;
    padding: 0;
    overflow: hidden;
    table-layout: fixed;
    display: table;
    width: 100%;
}

.sns-area li {
    list-style-type: none;
    display: table-cell;
    vertical-align: middle;
}

.sns-area li:last-child {
    margin-right: 0
}

.sns-link {
    position: relative;
    display: block;
    color: #fff;
    text-align: center;
    text-decoration: none;
    outline: none;
    overflow: hidden;
    height: 42px;
    line-height: 42px;
}

.sns-link::after {
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: 2;
	display: block;
	content: '';
	width: 0;
	height: 0;
	background-color: rgba(255,255,255,.3);
	border-radius: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	opacity: 0;
}

.sns-link:hover {
    text-decoration: none;
}

.sns-link:hover::after {
	-webkit-animation: circle .75s;
	animation: circle .75s;
}
@-webkit-keyframes circle {
	50% {
		opacity: 1;
	}
	100% {
		width: 300px;
		height: 300px;
	}
}
@keyframes circle {
	50% {
		opacity: 1;
	}
	100% {
		width: 300px;
		height: 300px;
	}
}

.sns-twitter {
    background: #55acee;
}

.sns-facebook {
    background: #3a5795;
}

.sns-bookmark {
    background: #00A5DE;
}

.sns-pocket {
    background: #ED4055;
}

.blogicon-twitter,
.blogicon-facebook,
.blogicon-bookmark,
.blogicon-chevron-down {
    margin-right: 5px;
}

@media only screen and (max-width: 767px) {
    .sns-txt {
       display: none;
    }
   .blogicon-twitter,
   .blogicon-facebook,
   .blogicon-bookmark,
   .blogicon-chevron-down {
       margin-right: 0;
   }
}

