/* <system section="theme" selected="8599973812270629022"> */
/* ===== ここから上は削除しない（はてなのシステム） ===== */
/* <system section="theme" selected="8599973812270629022"> */
@charset "utf-8";
@import url("//maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css");
/*
Theme: Minimalism
Author: Codomisu
Description:
最小限のデザインで最大限の「美」を引き出す


※未だにコードを整理していない　2018/09/09

Licensed under the MIT license.
*/
/*  import normalize */
/*! normalize.css v3.0.1 | MIT License | git.io/normalize */
/**
* 1. Set default font family to sans-serif.
* 2. Prevent iOS text size adjust after orientation change, without disabling
*    user zoom.
*/

/* Responsive:yes */

html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}
/**
* Remove default margin.
*/
body {
  margin: 0;
}
/* HTML5 display definitions
========================================================================== */
/**
* Correct `block` display not defined for any HTML5 element in IE 8/9.
* Correct `block` display not defined for `details` or `summary` in IE 10/11 and Firefox.
* Correct `block` display not defined for `main` in IE 11.
*/
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
  display: block;
}
/**
* 1. Correct `inline-block` display not defined in IE 8/9.
* 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
*/
audio,
canvas,
progress,
video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}
/**
* Prevent modern browsers from displaying `audio` without controls.
* Remove excess height in iOS 5 devices.
*/
audio:not([controls]) {
  display: none;
  height: 0;
}
/**
* Address `[hidden]` styling not present in IE 8/9/10.
* Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
*/
[hidden],
template {
  display: none;
}
/* Links
========================================================================== */
/**
* Remove the gray background color from active links in IE 10.
*/
a {
  background: transparent;
}
/**
* Improve readability when focused and also mouse hovered in all browsers.
*/
a:active,
a:hover {
  outline: 0;
}
/* Text-level semantics
========================================================================== */
/**
* Address styling not present in IE 8/9/10/11, Safari, and Chrome.
*/
abbr[title] {
  border-bottom: 1px dotted;
}
/**
* Address style set to `600er` in Firefox 4+, Safari, and Chrome.
*/
b,
strong {
  font-weight: 600;
}
/**
* Address styling not present in Safari and Chrome.
*/
dfn {
  font-style: italic;
}
/**
* Address variable `h1` font-size and margin within `section` and `article`
* contexts in Firefox 4+, Safari, and Chrome.
*/
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
/**
* Address styling not present in IE 8/9.
*/
mark {
  background: #ff0;
  color: #000;
}
/**
* Address inconsistent and variable font size in all browsers.
*/
small {
  font-size: 80%;
}
/**
* Prevent `sub` and `sup` affecting `line-height` in all browsers.
*/
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sup {
  top: -0.5em;
}
sub {
  bottom: -0.25em;
}
/* Embedded content
========================================================================== */
/**
* Remove border when inside `a` element in IE 8/9/10.
*/
img {
  border: 0;
}
/**
* Correct overflow not hidden in IE 9/10/11.
*/
svg:not(:root) {
  overflow: hidden;
}
/* Grouping content
========================================================================== */
/**
* Address margin not present in IE 8/9 and Safari.
*/
figure {
  margin: 1em 40px;
}
/**
* Address differences between Firefox and other browsers.
*/
hr {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  height: 0;
}
/**
* Contain overflow in all browsers.
*/
pre {
  overflow: auto;
}
/**
* Address odd `em`-unit font size rendering in all browsers.
*/
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}
/* Forms
========================================================================== */
/**
* Known limitation: by default, Chrome and Safari on OS X allow very limited
* styling of `select`, unless a `border` property is set.
*/
/**
* 1. Correct color not being inherited.
*    Known issue: affects color of disabled elements.
* 2. Correct font properties not being inherited.
* 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
*/
button,
input,
optgroup,
select,
textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */
}
/**
* Address `overflow` set to `hidden` in IE 8/9/10/11.
*/
button {
  overflow: visible;
}
/**
* Address inconsistent `text-transform` inheritance for `button` and `select`.
* All other form control elements do not inherit `text-transform` values.
* Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
* Correct `select` style inheritance in Firefox.
*/
button,
select {
  text-transform: none;
}
/**
* 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
*    and `video` controls.
* 2. Correct inability to style clickable `input` types in iOS.
* 3. Improve usability and consistency of cursor style between image-type
*    `input` and others.
*/
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
}
/**
* Re-set default cursor for disabled elements.
*/
button[disabled],
html input[disabled] {
  cursor: default;
}
/**
* Remove inner padding and border in Firefox 4+.
*/
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}
/**
* Address Firefox 4+ setting `line-height` on `input` using `` in
* the UA stylesheet.
*/
input {
  line-height: normal;
}
/**
* It's recommended that you don't attempt to style these elements.
* Firefox's implementation doesn't respect box-sizing, padding, or width.
*
* 1. Address box sizing set to `content-box` in IE 8/9/10.
* 2. Remove excess padding in IE 8/9/10.
*/
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
* Fix the cursor style for Chrome's increment/decrement buttons. For certain
* `font-size` values of the `input`, it causes the cursor style of the
* decrement button to change from `default` to `text`.
*/
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
/**
* 1. Address `appearance` set to `searchfield` in Safari and Chrome.
* 2. Address `box-sizing` set to `border-box` in Safari and Chrome
*    (include `-moz` to future-proof).
*/
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  /* 2 */
  box-sizing: content-box;
}
/**
* Remove inner padding and search cancel button in Safari and Chrome on OS X.
* Safari (but not Chrome) clips the cancel button when the search input has
* padding (and `textfield` appearance).
*/
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
/**
* Define consistent border, margin, and padding.
*/
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}
/**
* 1. Correct `color` not being inherited in IE 8/9/10/11.
* 2. Remove padding so people aren't caught out if they zero out fieldsets.
*/
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
* Remove default vertical scrollbar in IE 8/9/10/11.
*/
textarea {
  overflow: auto;
}
/**
* Don't inherit the `font-weight` (applied by a rule above).
* NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
*/
optgroup {
  font-weight: 600;
}
/* Tables
========================================================================== */
/**
* Remove most spacing between table cells.
*/
table {
  border-collapse: collapse;
  border-spacing: 0;
}
td,
th {
  padding: 0;
}
/*  import mixin */
.clearfix {
  display: block;
  *zoom: 1;
}
.clearfix:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
.inline-block {
  display: inline-block;
  *display: inline;
  *zoom: 1;
}
.ellipsis {
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
/*  import variable */
/* Common */
html,
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック  Medium', meiryo, sans-serif;
  color: #3f3f3f;
  background-color: #ffffff;
}
a {
  color: #1487bd;
}
a:visited {
  color: #789dae;
}
a:hover {
  color: #0f5373;
}
h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a,
h1 a:hover,
h2 a:hover,
h3 a:hover,
h4 a:hover,
h5 a:hover,
h6 a:hover,
h1 a:visited,
h2 a:visited,
h3 a:visited,
h4 a:visited,
h5 a:visited,
h6 a:visited {
  color: #333333;
  text-decoration: none;
}
a.keyword {
  text-decoration: none;
  border-bottom: 1px dotted #ECEEF1;
  color: #3f3f3f;
}
/* Buttons */
.btn {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #3f3f3f;
  background-color: #ffffff;
  text-align: center;
  vertical-align: middle;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 2px;
  background-clip: padding-box;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none ;
}
.btn:hover {
  background-color: #f5f5f5;
  text-decoration: none ;
}
.btn-small {
  padding: 2px 10px ;
  font-size: 11px ;
}
.btn-large {
  padding: 13px 19px;
  font-size: 17px;
  line-height: normal;
  font-weight: 600;
}
/* ヘッダ（グローバルヘッダ）
グローバルヘッダの中はiframeですが、
#globalheader-container に背景色や文字色を指定することでiframeの中にも色が反映されます。
*/
#globalheader-container {
  background-color: #333;
  color: #fff;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
}
/* container */
#container {
  width: 1140px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 0;
  padding-top: 37px;
}
#container #content {
  display: block;
  *zoom: 1;
}
#container #content:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
.globalheader-off #container {
  padding-top: 0;
}
/* 2カラムレイアウト */
#main {
  width: 640px;
  float: left;
}
#box2 {
  width: 290px;
  float: right;
}
/* 1カラムにしたい場合は下記のコメントアウトを外してください ----

#main {
width: 100%;
float: none;
}

#box2 {
width: 100%;
float: none;
}

#box2-inner {
width: 960px;
.clearfix;
overflow: hidden;
}

.hatena-module {
text-align: left;
padding-right: 20px;
width: 300px;
float: left;

&:nth-child(3n+1) {
clear: both;
}
}

---- END 1カラム */
/* header */
#blog-title {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  text-align: center;
  margin: 0;
  padding: 50px 0;
}
#title {
  margin: 0;
}
#title a {
  color: #3f3f3f;
}
#blog-description {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  font-weight: normal;
  font-size: 80%;
  margin: 5px 0 0 0;
}
/* ヘッダ画像を設定したとき */
.header-image-enable #title {
  padding-top: 70px;
}
.header-image-enable #title,
.header-image-enable #blog-description {
  padding-left: 20px;
}
/* パンくず（カテゴリーページで表示されます） */
#top-box {
  margin: 10px auto 20px;
  font-size: 90%;
}
#top-box .breadcrumb {
  border-top: 1px solid #ECEEF1;
  border-bottom: 1px solid #ECEEF1;
  padding: 10px;
}
/* entry */
.entry {
  position: relative;
  margin-bottom: 50px;
}
.entry-header {
  padding: 15px 0;
  margin-bottom: 20px;
  border-bottom: 1px solid #ECEEF1;
  position: relative;
}
.entry-title {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  font-size: 21px;
  font-weight: 600;
  line-height: 35px;
  margin: 15px 0 20px;
}
/* 日付 */
.date {
  font-weight: 600;
  margin-bottom: 15px;
}
.date a {
  color: #1487bd;
  text-decoration: none;
  font-size: 90%;
}
/* カテゴリ */
.categories {
  margin-top: 10px;
  font-size: 80%;
}
.categories a {
  color: #3f3f3f;
}
.categories.no-categories {
  margin: 0;
}
/* 「編集する」ボタン */
.entry-header-menu {
  position: absolute;
  bottom: 0px;
  left: -60px;
}
.entry-header-menu a {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #3f3f3f;
  background-color: #ffffff;
  text-align: center;
  vertical-align: middle;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 2px;
  background-clip: padding-box;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none ;
}
.entry-header-menu a:hover {
  background-color: #f5f5f5;
  text-decoration: none ;
}
/* entry-content の中の書式 */
.entry-content {
  font-size: 15px;
  line-height: 34px;
  padding-bottom: 10px;
  border-bottom: 1px solid #ECEEF1;
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
}
.entry-content p {
  margin: 0 0 1em 0;
}
.entry-content img {
  max-width: 100%;
}
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
  margin: 1.3em 0 0.8em 0;
  line-height: 1.5;
}
.entry-content h1 {
  font-size: 160%;
}
.entry-content h2 {
  font-size: 150%;
}
.entry-content h3 {
  font-size: 140%;
}
.entry-content h4 {
  font-size: 130%;
}
.entry-content h5 {
  font-size: 110%;
}
.entry-content h6 {
  font-size: 100%;
}
.entry-content table {
  border-collapse: collapse;
  border-spacing: 0;
  margin-bottom: 1em;
}
.entry-content table img {
  max-width: none;
}
.entry-content table th,
.entry-content table td {
  border: 1px solid #ddd;
  padding: 5px 10px;
}
.entry-content table th {
  background: #f5f5f5;
}
.entry-content blockquote {
  border: 1px solid #ECEEF1;
  margin: 0 0 10px;
  padding: 20px;
}
.entry-content blockquote p {
  margin-top: 0;
  margin-bottom: 0;
}
.entry-content pre {
  border: 1px solid #ECEEF1;
  margin: 0 0 10px;
  padding: 20px;
  white-space: pre;
}
.entry-content pre > code {
  margin: 0;
  padding: 0;
  white-space: pre;
  border: 0;
  background: transparent;
  font-family: 'Monaco', 'Consolas', 'Courier New', Courier, monospace, sans-serif;
}
.entry-content code {
  font-size: 90%;
  margin: 0 2px;
  padding: 0 5px;
  border: 1px solid #eaeaea;
  background-color: #f8f8f8;
  border-radius: 3px;
  font-family: 'Monaco', 'Consolas', 'Courier New', Courier, monospace, sans-serif;
}
.entry-content .hatena-asin-detail li {
  line-height: 1.4;
}
/* entry-footer */
.entry-footer {
  margin-top: 10px;
}
.entry-footer-section {
  font-size: 80%;
  color: #999999;
}
.entry-footer-section a {
  color: #999999;
}
.social-buttons,
.entry-footer-html {
  margin: 10px 0;
}
/* コメント */
.comment-box ul {
  list-style: none;
  margin: 0 0 15px 0;
  padding: 0;
  font-size: 95%;
  line-height: 1.7;
}
.comment-box li {
  padding: 10px 0 10px 60px;
  border-bottom: 1px solid #ECEEF1;
  position: relative;
}
.comment-box li:first-child {
  border-top: 1px solid #ECEEF1;
}
.comment-box .read-more-comments {
  padding-left: 0;
}
.comment-box .hatena-id-icon {
  position: absolute;
  top: 10px;
  left: 0;
  width: 50px ;
  height: 50px ;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 3px;
  background-clip: padding-box;
}
.comment-user-name {
  margin: 0 0 10px 0;
  font-weight: 600;
}
.comment-content {
  font-size: 90%;
  margin: 0 0 10px 0;
  word-wrap: break-word;
}
.comment-content p {
  margin: 0 0 10px 0;
}
.comment-metadata {
  font-size: 80%;
  color: #999999;
  margin: 0;
}
.comment-metadata a {
  color: #999999;
}
.leave-comment-title {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #3f3f3f;
  background-color: #ffffff;
  text-align: center;
  vertical-align: middle;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 2px;
  background-clip: padding-box;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none ;
}
.leave-comment-title:hover {
  background-color: #f5f5f5;
  text-decoration: none ;
}
/* sidebar */
#box2 {
  font-size: 85%;
  line-height: 1.5;
}
.hatena-module {
  margin-bottom: 60px;
}
.hatena-module-title {
  font-weight: 600;
  margin-bottom: 15px;
  font-size: 120%;
  padding:0 0 5px 5px;
  border-bottom: 1px solid #ECEEF1;
}
.hatena-module-title a {
  color: #3f3f3f;
  text-decoration: none;
}
.hatena-module-title a:hover {
  text-decoration: underline;
}
/* Profile module */
.hatena-module-profile .profile-icon {
  float: left;
  margin: 0 10px 10px 0;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 5px;
  background-clip: padding-box;
}
.hatena-module-profile .id {
  display: block;
  font-weight: 600;
  font-size: 110%;
  margin-bottom: 5px;
}
.hatena-module-profile .profile-description {
  font-size: 90%;
}
.hatena-module-profile .profile-description p {
  margin-top: 0;
}
/* urllist module
リンク・最新記事・最近のコメント・月別アーカイブ・カテゴリモジュールは .hatena-urllist という共通の class が振られます
*/
.hatena-urllist {
  list-style: none;
  margin: 0 0 0 0;
  padding: 0 0 0 0;
}
.hatena-urllist li {
  padding: 8px 0;
  border-bottom: 1px solid #ECEEF1;
  line-height: 1.5;
}
.hatena-urllist li a {
  text-decoration: none;
}
/* Search module */
.hatena-module-search-box .search-form {
  border: 1px solid #ECEEF1;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 3px;
  background-clip: padding-box;
  width: 100%;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
}
.hatena-module-search-box .search-module-input {
  padding: 10px 10px;
  color: #3f3f3f;
  background: none;
  border: none;
  outline: none;
  height: 20px;
  width: 90%;
}
.hatena-module-search-box .search-module-button {
  width: 35px;
  height: 35px;
  background: transparent url(https://cdn.blog.st-hatena.com/images/theme/search.png?version=17d66ae0e3fc0e087ead6e3d21294b) no-repeat right center;
  border: none;
  outline: none;
  text-indent: -9999px;
  position: absolute;
  top: 1px;
  right: 10px;
  opacity: 0.5;
}
.hatena-module-search-box .search-module-button:hover {
  opacity: 0.85;
}
/* Pager */
.pager {
  margin: 1em 0;
  display: block;
  *zoom: 1;
}
.pager:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
.pager .pager-prev {
  float: left;
  text-align: left;
  width: 45%;
}
.pager .pager-next {
  float: right;
  text-align: right;
  width: 45%;
}
/* Footer */
#footer {
  padding: 30px 0;
  text-align: center;
  color: #999999;
  line-height: 1.5;
  font-size: 80%;
}
#footer p {
  margin: 0;
}
#footer a {
  color: #999999;
}
/* About ページ */
.page-about dt {
  font-size: 16px;
  font-weight: 600;
  border-bottom: 1px solid #dfdfdf;
  margin-bottom: 5px;
}
.page-about dd {
  margin-left: 0;
  margin-bottom: 30px;
}
/* archive ページ */
.page-archive .archive-entries .archive-entry {
  margin-bottom: 3em;
}
.page-archive .archive-entries .entry-title {
  font-size: 130%;
  margin: 0 0 .5em;
}
.page-archive .archive-entries .categories {
  margin: 0 0 .5em;
}
.page-archive .archive-entries .entry-description {
  margin: 0 0 1em;
  font-size: 13px;
  line-height: 25px;
}
.page-archive .categories a {
  color: #3f3f3f;
  text-decoration: none;
  display: inline-block;
  *display: inline;
  *zoom: 1;
  margin-bottom:5px;
}

.shrbtn{
  padding:0;
  margin:15px 0;
  width: 100%;
  background:#ECEEF1;
  text-align:center;
  display: inline-flex;
}

.share_btn{
  display: inline-block;
  width: calc(100% / 5);
  margin:4px 6px;
  height: 40px;
  line-height: 40px;
  font-size: 18px;
  color:#3f3f3f;
  border:1px solid #ECEEF1;
  border-radius:0;
  text-align: center;
  vertical-align: middle;
  overflow: hidden;
  font-weight: 600;
  transition: .3s;
  background:#fafafa;
}

.share_btn:first-of-type{
  margin-left:0;
}

.share_btn:last-of-type{
  margin-right:0;
}

.share_btn:hover{
  color:#3f3f3f;
}

.share_btn .fa {line-height:40px}


/* ### スライドメニュー ### */
#gnav {
  border-top: 1px solid #ECEEF1;
  border-bottom: 1px solid #ECEEF1;
  margin: 0 0 10px;
  background: #ffffff;
  font-size: 0;
  padding: 0 0 0;
}

#gnav .menu a {
  display: block;
  color: #3f3f3f;
  font-size: 13px;
  font-weight: 500;
  text-decoration:none;
  text-align: center;
  overflow: hidden;
  box-sizing: border-box;

}


#gnav .gnav-inner {
  width: 100%;
  padding: 12px 20px;
  overflow-x: auto;
  overflow-y: hidden;
  box-sizing: border-box;
  text-align: center;
  white-space: nowrap;
  margin: 0 auto;
  -webkit-font-smoothing: antialiased;
  -webkit-overflow-scrolling: touch;
}

#gnav .menu {
  display: inline-block;
}

/* ### スライドメニューを横いっぱいに広げる ### */
#top-editarea .section {
  width: 100% ;
  margin-left: auto;
  margin-right: auto;

}

#top-editarea{
  margin-bottom: 15px;
}

.id a{
  color: #3f3f3f;
  text-decoration: none;
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
}


.hatena-module-profile .profile-description {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
}

.table-of-contents {
  position: relative;
  background-color: #fafafa;
  border:1px solid #ECEEF1;
  padding: 60px 70px 25px;
  border-radius: 0;
  font-size: 14px;
  line-height: 28px;
}


.table-of-contents::before {
  position: absolute;
  display: block;
  text-align: center;
  top: 15px;
  left: 50%;
  margin-left: -1em;
  font-size: 20px;
  font-weight: 700;
  content: '目次';
  z-index: 2;
}


.table-of-contents li a {
  text-decoration: none;
  line-height: 35px;
  color:#3f3f3f;
}

.archive-header-category{
  margin-bottom:25px;
}

.archive-heading{
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  border-bottom:1px solid #ECEEF1;
  font-weight: 600;
  font-size: 21px;
  line-height: 35px;
  padding-bottom:5px;
  margin-bottom:25px;
}

.footer{
  background:#3f3f3f;
  color:#fff;
  padding:30px 0;
}
.footer ul li{
  text-align:center;
  display: block;
}

.footer .footer-title{
  margin-bottom:10px;
}

.footer .footer-copyright{
  font-size:12px;
}

.footer-list{
  padding: 0;
}

.categories a{
  color: #3f3f3f;
  text-decoration: none;
  padding: 4px 0;
  border-radius: 0;
  font-size:13px;
  vertical-align: middle;
  margin-right: 10px;
}

.categories a:before{
  font-family: FontAwesome;
  content:"\f02b";
  font-size: 16px;
  vertical-align: middle;
  margin-right: 5px;
  color:#2f2f2f;
}

/*  import media queries */
/* Media Queries - Retina Display */
@media screen and (min-width: 1139px){

  #blog-title #title{
    font-size: 37px;
    line-height: 60px;
    font-weight:500;
  }

  .hatena-module-search-box .search-module-button {
    background: transparent url(https://cdn.blog.st-hatena.com/images/theme/search@2x.png?version=17d66ae0e3fc0e087ead6e3d21294b) no-repeat right center;
    background-size: 20px 20px;
  }
  #container {
    border-right: 1px solid #ECEEF1;
    border-left: 1px solid #ECEEF1;
  }
  #content{
    margin: 35px 55px;
  }
  .breadcrumb-inner{
    margin: 0 5%;
  }
  .date a {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 15px;
    padding: 1px;
  }
  .date {
    font-weight: 500;
    margin-bottom: 5px;
  }

  .date:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95%;
    top: 0;
    color: #3f3f3f;
  }

  .page-archive .entry-thumb {
    border-radius: 5px;
    margin-right: 20px;
  }

  #box2 .urllist-image {
    border-radius: 5px;
    margin-right: 15px;
  }

  .urllist-date-link time {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 14px;
    padding: 1px;
  }

  .urllist-date-link time:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95%
    top: 0;
    color: #3f3f3f;
  }


  .shrbtn{
    background:none;
  }

  #box2{
    margin-top: 15px;
  }

  .page-archive .archive-entries .entry-title {
    margin-top:10px;
    font-size: 19px;
  }

  .hatena-urllist li a {
    font-size: 13px;
    line-height: 25px;
    color:#3f3f3f;
  }
  #gnav .menu a {
    padding: 0 15px;
  }
}
/* Media Queries - Tablet */
@media screen and (max-width: 1138px){
  #gnav .menu{
    margin-right:20px;
  }
  #gnav .menu a{
    font-size: 12px;
  }
  #container {
    width: 100% ;
    word-wrap: break-word;
    overflow: hidden;
    padding-top: 0;
  }
  #main {
    width: 93.75% ;
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2 {
    width: 93.75% ;
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2-inner {
    width: 100% ;
  }
  .hatena-module {
    width: 100%;
    float: none;
  }
  .date a {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 15px;
    padding: 1px;
  }
  .date {
    font-weight: 500;
    margin-bottom: 5px;
  }

  .date:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 18px;
    top: 0;
    color: #3f3f3f;
  }

  .page-archive .entry-thumb {
    border-radius: 5px;
  }
  #box2 .urllist-image {
    border-radius: 5px;
  }

  .urllist-date-link time {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 14px ;
    padding: 1px;
  }

  .urllist-date-link time:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95% ;
    top: 0;
    color: #3f3f3f;
  }
  .shrbtn{
    background:none ;
  }
.
  .hatena-urllist li a {
    color:#3f3f3f;
  }
  .entry .entry-title{
    font-size: 22px;
  }
  .categories a{
    color: #3f3f3f;
    text-decoration: none;
    padding: 2px 7px;
    border-radius: 2px;
    margin: 0 2px;
  }
  .page-archive .archive-entries .entry-title {
    font-size: 18px;
  }

}
/* Media Queries - Small Tablet & Smartphone */
@media screen and (max-width:640px){
  #globalheader-container {
    position: static;
  }
  #blog-title #title{
    font-size: 30px;
    font-weight:500;
    font-family: 'Nunito', sans-serif;
  }
  #blog-description {
    font-size:11px;
  }
  #container {
    width: 100%;
    word-wrap: break-word;
    overflow: hidden;
    padding-top: 0;
  }
  #main {
    width: 93.75%;
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2 {
    width: 93.75%
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2-inner {
    width: 100%;
  }
  .hatena-module {
    width: 100%;
    float: none;
  }
  .entry-header-menu {
    top: -30px;
    left: 0px;
  }
  .archive-entry-header{
    width : -webkit-calc(100% -90px);
    width: calc(100% - 90px);
    float: right;
  }
  .page-archive .archive-entries .entry-title {
    font-size:14px;
    line-height: 25px;
    font-weight: 400;
    margin:0;
  }
  .archive-entries .entry-description{
    font-size:11px;
    display:none;
  }
  .page-archive .entry-thumb {
    width: 75px;
    height: 75px;
    border: 1px solid #ECEEF1;
    background-size: 100%;
    float:left;
    border-radius: 3px;
  }

  .page-archive .categories{
    display: none;
  }

  .page-archive .archive-entries .archive-entry {
    margin-bottom: 0;
    padding: 17px 0;
    border-bottom: 1px solid #ECEEF1;
}
  .date a {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 12px;
    padding: 1px;
  }
  .date {
    font-weight: 500;
    margin-bottom: 5px;
  }

  .date:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95%;
    top: 0;
    color: #3f3f3f;
  }

  .page-archive .social-buttons{
    display: none;
  }

  #blog-title {
    text-align: center;
    padding: 35px 0 35px;
    margin:0;
  }

  .entry .entry-title{
    font-size: 18px;
    line-height: 30px;
    margin: 10px 0 15px;
    font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  }

  .entry .entry-header{
    padding: 10px 0 10px 0;
    border:none;
  }

  .table-of-contents {
    position: relative;
    background-color: #fafafa;
    border:1px solid #ECEEF1;
    padding: 60px 45px 25px;
    border-radius: 0;
    font-size: 14px;
    line-height: 28px;
  }

  #box2 .urllist-image {
    max-width: 100%;
    width: 75px;
    border-radius: 5px;
    margin-right: 10px;
    border: 1px solid #ECEEF1;
    height: 75px;
  }
  .hatena-urllist li{
    padding: 10px 0 0px;
  }

  .hatena-urllist li a {
    font-size: 13px ;
    line-height: 20px;
    font-weight: 500;
    color: #3f3f3f;
    text-decoration: none;
  }

  .archive-module-year{
    border:none ;
  }

  .urllist-date-link time {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 12px ;
    padding: 1px;
  }

  .urllist-date-link time:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95% ;
    top: 0;
    color: #3f3f3f;
  }
  .archive-entries{
    margin:0 0 40px;
  }

  .id a{
    font-weight: normal;
    text-decoration: none;
    color: #3f3f3f;
  }

  .entry-content {
    font-size: 14px;
  }
  .hatena-module {
    margin-bottom: 40px;
  }
  .urllist-image{
    width: 70px;
    border-radius: 5px;
  }
  .related-entries .related-entries-entry-body{
    display: none;
  }
  .pager{
    text-align: center;
    margin-bottom: 45px;
  }
  :not(.permalink)>.pager-next{
    float:none ;
    text-align: center ;
  }
  :not(.permalink)>.pager-next a{
    text-decoration: none;
    padding: 10px 100px;
    border-radius: 4px;
    border: 1px solid #ECEEF1;
    background: #fafafa;
    color: #3f3f3f;
  }
  .pager-permalink{
    display:none;
  }
}
/* Media Queries - Smartphone */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&family=Noto+Serif+JP:wght@700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@500&display=swap');

/* スマホでのタイトル白文字 */
#container .title-new a.chappy {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    text-decoration: none !important;
}
/* </system> */
/* <system section="background" selected="fff"> */
body{background:#fff;}
/* </system> */
/* ===== 以下：今のサイト用（重複なし・1本） ===== */
header#blog-title { display: none; }
#container { width: 100%; padding-top: 50px!important; }
@media screen and (min-width: 992px) {
#content-inner { max-width:4000px!important; }
}
@media screen and (min-width: 1139px) {
#container { border-right: 0 solid #ECEEF1; border-left: 0 solid #ECEEF1; }
#content { margin: 35px 0; }
}
@media screen and (min-width: 992px) {
#box2-inner { padding: 0!important; }
}
@media screen and (max-width: 1138px) {
#box2 { width: 100%; }
}
.entry-thumb { max-height: 500px!important; }
@media screen and (min-width:992px) {
#content-inner { flex-wrap: wrap; }
#wrapper { width: 100%; }
#box2 { width: 100%; }
#box2-inner { padding: 0 20px; }
}
.page-index div#main-inner { display: none; }
/* 固定ヘッダー .title-new */
.title-new {
    position: fixed; top: 0!important; left: 0; z-index: 100;
    width: 100%; height: 50px; padding: 0;
    background-color: #000; text-align: center;
    display: flex; justify-content: center; align-items: center;
    font-size: 12px;
}
.title-new a { color: #fff; text-decoration: none; }
.title-new a.chappy { font-size: 24px; font-weight: 700; }
@media screen and (min-width:640px) {
.title-new a.chappy { margin: 0 15px; }
.title-new { display: flex; justify-content: flex-start; }
}
/* 右端アイコン .nexttomenu */
.nexttomenu {
    z-index: 101; position: fixed; top: 0; right: 61px;
    font-size: 20px; height: 50px; display: flex; align-items: center;
}
@media screen and (max-width:640px) { .nexttomenu { display:none; } }
.nexttomenu a.twitter, .nexttomenu a.hatena {
    color: #555!important; text-decoration: none; font-size: 26px;
    margin: 0 10px;
}
.nexttomenu a.hatena { margin: 3px 15px 0 10px; }
.nexttomenu a.twitter:visited, .nexttomenu a.hatena:visited {
    color: #555!important; text-decoration: none;
}
/* グローバルナビ */
.nav-categories.nav-categories { justify-content: space-around; }
.nav-categories li a { font-family: '游ゴシック Medium', meiryo, sans-serif; }
#top-editarea { margin-bottom: 0!important; }
#content { margin-top: 0; }
#box2 { margin-top: 0; }
/* カルーセル .hatena-module-custom-top */
.hatena-module-custom-top { padding-top: 0!important; padding-bottom: 30px; background: #fff; margin-bottom: 0; }
.page-index .hatena-module-custom-top { margin-top: 0!important; }
.hatena-module-custom-top .archive-entries { max-width:1000px; display:block; background:transparent; }
.hatena-module-custom-top li.urllist-item.recent-entries-item {
    width: 50%; height: 400px; margin: 0 2vw 1em 0; border-radius:5px;
    counter-increment: carousel-cell; overflow: hidden; padding: 0;
}
.hatena-module-custom-top ul.recent-entries.hatena-urllist.urllist-with-thumbnails.flickity-enabled.is-draggable { margin: 0; }
.hatena-module-custom-top .flickity-page-dots .dot { padding: 0; }
.hatena-module-custom-top .urllist-categories.recent-entries-categories {
    display:block; position:absolute; top:1vw; left:.5vw; z-index:2;
}
.hatena-module-custom-top a.urllist-category-link.recent-entries-category-link {
    padding:.6vw; font-size:.7em; font-weight:800; letter-spacing:.2vw;
    text-decoration:none; border-radius:20em; color:black; background:white; opacity:.5;
}
.hatena-module-custom-top a.urllist-category-link.recent-entries-category-link:hover {
    background:#f4dde3; transition-duration: 0.3s;
}
.hatena-module-custom-top a.urllist-title-link.recent-entries-title-link.urllist-title.recent-entries-title {
    display: -webkit-box; -webkit-box-orient: vertical; flex: 1 0 auto;
    padding:0 .5vw; font-size: 1em; font-weight: 800; line-height: 1em;
    text-decoration:none; position: absolute; top: 50%; left: 50%;
    transform: translate(-50%, -50%); color: #fff; width: 88%; margin-inline: auto;
}
.hatena-module-custom-top img.urllist-image.recent-entries-image {
    object-fit: cover!important; width: 100%!important; height: 400px!important;
    margin: 0; border-radius: 10px; opacity:0.65;
}
.hatena-module-custom-top img.urllist-image.recent-entries-image:hover { opacity: 0.6; }
.hatena-module-custom-top .urllist-item-inner.recent-entries-item-inner {
    background: #000; border-radius: 10px; width: 100%; height: 400px;
}
.hatena-module-custom-top a.urllist-see-more-link.recent-entries-see-more-link { color:#fff; }
.hatena-module-custom-top .urllist-see-more { text-align: center; margin-top: 40px; border: 1px solid #fff; padding: 1em; }
.page-index .hatena-module-custom-top .hatena-module-title { border-bottom: 0; display:none; }
.hatena-module-custom-top .flickity-page-dots { bottom: -15px; }
.hatena-module-custom-cat .hatena-module-title, .hatena-module-custom-link .hatena-module-title { border-bottom: 0; display:none; }
@media screen and (max-width:640px) {
.hatena-module-custom-top li.urllist-item.recent-entries-item { width:60%; height: 200px; }
.hatena-module-custom-top img.urllist-image.recent-entries-image { height: 200px!important; }
.hatena-module-custom-top { padding-top: 20px!important; }
}
/* ハンバーガー .drawer_menu */
.drawer_menu .drawer_nav_wrapper { transform: translate(0); width: 100%; height: 50px; position: relative; top: auto; right: auto; z-index: 10; background-color: #555; }
.drawer_menu .drawer_nav { max-width: 1000px; padding: 0; margin: 60px auto; display: flex; justify-content: center; list-style-type: none; }
.drawer_menu .drawer_nav li { font-size: 16px; margin: 0; padding: 0; width: 100%; height: 50px; line-height: 50px; background-color: #555; text-align: center; list-style-type: none; }
.drawer_menu .drawer_nav li:hover { background-color: #999; }
.drawer_menu .drawer_nav li a { color: #fff; }
.drawer_title { padding: 10px 0; margin: 40px 0 10px; font-size: 1.3em; font-family: 'Sofia', cursive; background-size: 100%; background-image: url(https://cdn-ak.f.st-hatena.com/images/fotolife/t/travelwz/20221014/20221014163856.png); text-align: center; }
.drawer_menu .drawer_button { color: #fff; display: none; }
.drawer_menu .drawer_button .drawer_bar { background-color: #555; }
@media screen and (max-width:1000px) {
.drawer_menu .drawer_bg { width: 100%; height: 100%; position: fixed; z-index: 999; background-color: rgba(51,51,51,0.5); display: none; top: 0; left: 0; }
.drawer_menu .drawer_button { display: block; background: transparent; color: #555; border: none; padding: 5px; width: 50px; cursor: pointer; position: fixed; top: 0; right: 10px; z-index: 1001; outline: none; }
.drawer_menu .drawer_button.active .drawer_bar { width: 40px; }
.drawer_menu .drawer_button.active .drawer_bar1 { transform: rotate(30deg); }
.drawer_menu .drawer_button.active .drawer_bar2 { opacity: 0; }
.drawer_menu .drawer_button.active .drawer_bar3 { transform: rotate(-30deg); }
.drawer_menu .drawer_button.active .drawer_menu_text { display: none; }
.drawer_menu .drawer_button.active .drawer_close { display: block; }
.drawer_menu .drawer_bar { display: block; height: 2px; margin: 8px 2px; transition: all 0.2s; transform-origin: 0 0; }
.drawer_menu .drawer_close { display: none; }
.drawer_menu .drawer_nav_wrapper { width: 250px; height: 100%; transition: all 0.2s; transform: translate(250px); position: fixed; top: 0; right: 0; z-index: 1000; background: #FFF; overflow-x: hidden; overflow-y: auto; }
.drawer_menu .drawer_nav { display: block; position: relative; }
.drawer_menu .drawer_nav li { background: #fff; height: auto; line-height: 50px; border-bottom: 1px solid #eee; }
.drawer_menu .drawer_nav li a { background: #fff; color: #555; display: block; text-align: left; padding-left: 20px; }
.drawer_menu .drawer_nav_wrapper.open { transform: translate(0); }
.drawer_menu .hatena-urllist li { list-style-type: none; }
.drawer_menu .drawer_nav li ul.second-level { display: none; position: relative; padding: 0; z-index: 1001; }
.drawer_menu .drawer_nav li:hover ul.second-level { display: block; }
.drawer_menu .drawer_nav li ul.second-level li a { padding-left: 40px; }
.drawer_menu ul.hatena-urllist:first-child { padding-top: 45px; padding-bottom: 0; }
.drawer_menu ul.hatena-urllist { padding-top: 45px; padding-bottom: 45px; }
}
@media screen and (min-width:1001px) { .pc-hidden { display: none; } }
/* 検索 */
.hatena-module-custom-search { padding: 30px 20px; background: #fff; margin-bottom: 0; }
@media screen and (max-width: 640px) { .hatena-module-custom-search { padding: 10px!important; } }
/* カード型 最新・WORK・TRAVEL 共通 */
.hatena-module-custom-latest,
.hatena-module-custom-work,
.hatena-module-custom-travel {
    padding: 30px 20px; background: #fff; margin-bottom: 0;
}
@media screen and (max-width: 640px) {
.hatena-module-custom-latest, .hatena-module-custom-work { padding: 30px 10px!important; }
.hatena-module-custom-travel { padding: 30px 10px!important; }
}
.hatena-module-custom-latest ul.recent-entries.hatena-urllist.urllist-with-thumbnails,
.hatena-module-custom-work ul.recent-entries.hatena-urllist.urllist-with-thumbnails,
.hatena-module-custom-travel ul.recent-entries.hatena-urllist.urllist-with-thumbnails {
    display: flex; flex-direction: row; flex-wrap: wrap; justify-content: flex-start;
}
.hatena-module-custom-latest li.urllist-item.recent-entries-item,
.hatena-module-custom-work li.urllist-item.recent-entries-item,
.hatena-module-custom-travel li.urllist-item.recent-entries-item {
    width: 28%; margin: 0 2.6%;
}
.hatena-module-custom-latest a.urllist-category-link.recent-entries-category-link,
.hatena-module-custom-work a.urllist-category-link.recent-entries-category-link,
.hatena-module-custom-travel a.urllist-category-link.recent-entries-category-link {
    background: #b3b1b1; color: #fff; font-size: 0.6rem; padding: 0.4em 0.5em; margin: 0 5px 5px 0;
}
.hatena-module-custom-latest a.urllist-category-link.category-HOT-NEWS,
.hatena-module-custom-work a.urllist-category-link.category-HOT-NEWS,
.hatena-module-custom-travel a.urllist-category-link.category-HOT-NEWS { display: none; }
.hatena-module-custom-latest .urllist-item-inner.recent-entries-item-inner,
.hatena-module-custom-work .urllist-item-inner.recent-entries-item-inner,
.hatena-module-custom-travel .urllist-item-inner.recent-entries-item-inner { position: relative; }
.hatena-module-custom-latest .urllist-categories.recent-entries-categories,
.hatena-module-custom-work .urllist-categories.recent-entries-categories,
.hatena-module-custom-travel .urllist-categories.recent-entries-categories {
    position: absolute; top: 0; left: 0;
}
.hatena-module-custom-latest img.urllist-image.recent-entries-image,
.hatena-module-custom-work img.urllist-image.recent-entries-image,
.hatena-module-custom-travel img.urllist-image.recent-entries-image { border:0; }
@media screen and (max-width:640px) {
.hatena-module-custom-latest li.urllist-item.recent-entries-item,
.hatena-module-custom-work li.urllist-item.recent-entries-item,
.hatena-module-custom-travel li.urllist-item.recent-entries-item { width: 48%; margin: 3px; }
.hatena-module-custom-latest .urllist-image, .hatena-module-custom-work .urllist-image, .hatena-module-custom-travel .urllist-image {
    width: 100%!important; height: auto!important;
}
}
.hatena-module-custom-travel { padding-bottom: 60px; }
.hatena-module.hatena-module-html.hatena-module-custom-profile,
.hatena-module.hatena-module-html.hatena-module-custom-blogmura { margin-bottom: -60px!important; }
.hatena-module-custom-latest { padding-top: 0; }
/* プロフィール */
.profile-img img { position: absolute; top: -50px; left: 50%; transform: translateX(-50%); border-radius: 50%; width: 100px; height: 100px!important; }
.profile { background: #bfcfd8; position: relative; padding: 70px 0 60px; margin-top: 45px; font-size: 0.8em; }
.profile p { text-align: center; margin-top: 5em; }
.profile-description { margin: 30px 0 20px; }
.follow-buttons-profile { width: 100%; display: flex; flex-wrap: wrap; justify-content: center; margin: 30px 0; }
.profile .follow a { display: flex; flex-direction: column; align-items: center; margin: 0 10px; }
.profile .name { font-size: 1.2em; }
.profile p strong { font-size: 1.1em; }
.profile-name, .hatena-module-profile .profile-name a { font-weight: bold; }
/* 記事本文・タイトル */
.entry-content { font-size: 17px!important; }
.entry-content h4 { font-size: 20px; }
.entry-content p { font-size: 16px; }
.page-entry .entry-title { font-size: 36px!important; }
@media screen and (min-width: 640px) {
.entry .entry-title { font-size: 30px; line-height: 1em; }
}
@media screen and (max-width: 640px) {
.entry .entry-title { font-size: 30px; line-height: 1em; letter-spacing: 1px; }
}
.entry-footer-author, .entry-footer-section { display: none; }
.hatena-module.hatena-module-html.hatena-module-custom-share { margin-bottom: 10px; }
/* 記事下シェア */
.share { display: flex; align-items: center; height: 30px; margin-top: 30px; }
.share a { margin: 0 0.5em 0 0; width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; text-decoration: none; }
.share i { font-size: 21px; }
.share i.fa-brands.fa-x-twitter { color: #000; }
.share i.fa-brands.fa-line { color: #00B900; }
.share i.fa-brands.fa-facebook { color: #1877F2; }
.share i.blogicon-bookmark { color: #01A5DF; font-size: 25px; margin-bottom: 2px; }
/* 画像キャプション */
.caption { font-size: 10px!important; text-align: left!important; display: block; margin-top: 5px; }
/* アーカイブページ カード型 */
.page-archive .entry-thumb { border: none!important; }
@media screen and (max-width: 640px) {
.page-archive .entry-thumb { width: 100%!important; height: auto!important; }
}
.page-archive .entry-title, .page-archive .entry-title a { font-size: 16px; line-height: 1.5!important; }
@media screen and (min-width: 640px) {
.page-archive .archive-entries { display: flex; flex-direction: row; flex-wrap: wrap; width: 100%; align-items: flex-start; }
.page-archive section.archive-entry.test-archive-entry.autopagerize_page_element {
    display: flex; flex-direction: column-reverse; position: relative; width: 28%; margin: 0 2.6% 10px 2.6%;
}
.page-archive .archive-entry-header { width: 100%; }
.page-archive a.entry-thumb-link { width: 100%; }
.page-archive .archive-entry-body, .page-archive .date.archive-date, .page-archive .archive-entries .entry-description { display: none; }
.page-archive .archive-entries .categories { position: absolute; top: 0; left: 0; }
.page-archive .entry-thumb { width: 100%; aspect-ratio: 5/3; height: auto; }
.page-archive h1.entry-title { overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; height: 4em; font-size: 110%!important; margin-bottom: 2.5rem!important; height: unset; -webkit-box-orient: unset; }
}
@media screen and (max-width: 640px) {
.page-archive section.archive-entry.test-archive-entry.autopagerize_page_element {
    display: flex; flex-direction: row-reverse; position: relative;
}
.page-archive .archive-entry-header { width: 55%; }
.page-archive a.entry-thumb-link { width: 45%; margin-right: 20px; }
.page-archive .archive-entry-body { position: absolute; bottom: 0; }
.page-archive .archive-entries .categories { position: absolute; bottom: 2em; }
.page-archive .archive-entries .entry-description { display: none; }
.page-archive .entry-thumb { width: 100%; aspect-ratio: 5/3; height: auto; }
.page-archive h1.entry-title { overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; -webkit-box-orient: unset; }
}
/* 目次 */
.entry-content .table-of-contents {
    margin: 30px 0!important; padding: 25px!important; background: #fdfdfd!important;
    border: 1px solid #ddd!important; border-radius: 4px!important; list-style: none!important;
    display: inline-block; min-width: 300px;
}
.entry-content .table-of-contents::before {
    content: "CONTENTS"; display: block; font-size: 16px; font-weight: bold; letter-spacing: 0.1em;
    color: #333; margin-bottom: 15px; padding-bottom: 10px; border-bottom: 1px solid #333;
}
.entry-content .table-of-contents li { list-style-type: none!important; margin: 8px 0!important; }
.entry-content .table-of-contents li a { color: #666!important; text-decoration: none!important; font-size: 14px; }
.entry-content .table-of-contents li a:hover { color: #999!important; text-decoration: underline!important; }
.entry-content .table-of-contents li ul { margin-left: 1.5em!important; }
/* ページネーション */
.pager .pager-prev + .pager-prev { display: none; }
@media screen and (max-width: 640px) {
.pager-prev.pager-prev.pager-prev { float: none; text-align: center; }
.pager-prev a {
    text-decoration: none; padding: 14px 0; width: 240px; display: block; margin: 40px auto;
    border-radius: 100px; border: 1px solid #d1d1d1; background: transparent; color: #1a1a1a;
    font-size: 11px; font-weight: 700; letter-spacing: 0.2em; text-align: center;
}
.pager:has(.pager-prev):has(.pager-next) :is(.pager-prev, .pager-next) { width: fit-content; }
.pager:has(.pager-prev):has(.pager-next) a { padding: 10px 20px; }
.pager:has(.pager-prev):has(.pager-next) .pager-next { float: right; }
.pager:has(.pager-prev):has(.pager-next) .pager-prev { float: left; }
}
/* その他 */
.badge-type-pro { display: none; }
body { -webkit-font-smoothing: antialiased; color: #333!important; }
/* 言語メニュー */
.header-translate-minimal { display: flex; align-items: center; padding: 10px; transform: scale(0.85); margin-inline: auto 0; width: fit-content; gap: 10px; }
.header-translate-minimal span { color: rgb(143,143,143); }
.header-translate-minimal a { color: #222; text-decoration: none!important; font-size: 14px!important; font-weight: 500; padding: 0 4px; }
.header-translate-minimal .divider { color: rgba(255,255,255,0.4)!important; font-size: 12px; margin: 0 2px; }
.header-translate-minimal a:hover { opacity: 0.7; }
@charset "utf-8";
@import url("//maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css");
/*
Theme: Minimalism
Author: Codomisu
Description:
最小限のデザインで最大限の「美」を引き出す


※未だにコードを整理していない　2018/09/09

Licensed under the MIT license.
*/
/*  import normalize */
/*! normalize.css v3.0.1 | MIT License | git.io/normalize */
/**
* 1. Set default font family to sans-serif.
* 2. Prevent iOS text size adjust after orientation change, without disabling
*    user zoom.
*/

/* Responsive:yes */

html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}
/**
* Remove default margin.
*/
body {
  margin: 0;
}
/* HTML5 display definitions
========================================================================== */
/**
* Correct `block` display not defined for any HTML5 element in IE 8/9.
* Correct `block` display not defined for `details` or `summary` in IE 10/11 and Firefox.
* Correct `block` display not defined for `main` in IE 11.
*/
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
  display: block;
}
/**
* 1. Correct `inline-block` display not defined in IE 8/9.
* 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
*/
audio,
canvas,
progress,
video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}
/**
* Prevent modern browsers from displaying `audio` without controls.
* Remove excess height in iOS 5 devices.
*/
audio:not([controls]) {
  display: none;
  height: 0;
}
/**
* Address `[hidden]` styling not present in IE 8/9/10.
* Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
*/
[hidden],
template {
  display: none;
}
/* Links
========================================================================== */
/**
* Remove the gray background color from active links in IE 10.
*/
a {
  background: transparent;
}
/**
* Improve readability when focused and also mouse hovered in all browsers.
*/
a:active,
a:hover {
  outline: 0;
}
/* Text-level semantics
========================================================================== */
/**
* Address styling not present in IE 8/9/10/11, Safari, and Chrome.
*/
abbr[title] {
  border-bottom: 1px dotted;
}
/**
* Address style set to `600er` in Firefox 4+, Safari, and Chrome.
*/
b,
strong {
  font-weight: 600;
}
/**
* Address styling not present in Safari and Chrome.
*/
dfn {
  font-style: italic;
}
/**
* Address variable `h1` font-size and margin within `section` and `article`
* contexts in Firefox 4+, Safari, and Chrome.
*/
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
/**
* Address styling not present in IE 8/9.
*/
mark {
  background: #ff0;
  color: #000;
}
/**
* Address inconsistent and variable font size in all browsers.
*/
small {
  font-size: 80%;
}
/**
* Prevent `sub` and `sup` affecting `line-height` in all browsers.
*/
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sup {
  top: -0.5em;
}
sub {
  bottom: -0.25em;
}
/* Embedded content
========================================================================== */
/**
* Remove border when inside `a` element in IE 8/9/10.
*/
img {
  border: 0;
}
/**
* Correct overflow not hidden in IE 9/10/11.
*/
svg:not(:root) {
  overflow: hidden;
}
/* Grouping content
========================================================================== */
/**
* Address margin not present in IE 8/9 and Safari.
*/
figure {
  margin: 1em 40px;
}
/**
* Address differences between Firefox and other browsers.
*/
hr {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  height: 0;
}
/**
* Contain overflow in all browsers.
*/
pre {
  overflow: auto;
}
/**
* Address odd `em`-unit font size rendering in all browsers.
*/
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}
/* Forms
========================================================================== */
/**
* Known limitation: by default, Chrome and Safari on OS X allow very limited
* styling of `select`, unless a `border` property is set.
*/
/**
* 1. Correct color not being inherited.
*    Known issue: affects color of disabled elements.
* 2. Correct font properties not being inherited.
* 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
*/
button,
input,
optgroup,
select,
textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */
}
/**
* Address `overflow` set to `hidden` in IE 8/9/10/11.
*/
button {
  overflow: visible;
}
/**
* Address inconsistent `text-transform` inheritance for `button` and `select`.
* All other form control elements do not inherit `text-transform` values.
* Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
* Correct `select` style inheritance in Firefox.
*/
button,
select {
  text-transform: none;
}
/**
* 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
*    and `video` controls.
* 2. Correct inability to style clickable `input` types in iOS.
* 3. Improve usability and consistency of cursor style between image-type
*    `input` and others.
*/
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
}
/**
* Re-set default cursor for disabled elements.
*/
button[disabled],
html input[disabled] {
  cursor: default;
}
/**
* Remove inner padding and border in Firefox 4+.
*/
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}
/**
* Address Firefox 4+ setting `line-height` on `input` using `` in
* the UA stylesheet.
*/
input {
  line-height: normal;
}
/**
* It's recommended that you don't attempt to style these elements.
* Firefox's implementation doesn't respect box-sizing, padding, or width.
*
* 1. Address box sizing set to `content-box` in IE 8/9/10.
* 2. Remove excess padding in IE 8/9/10.
*/
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
* Fix the cursor style for Chrome's increment/decrement buttons. For certain
* `font-size` values of the `input`, it causes the cursor style of the
* decrement button to change from `default` to `text`.
*/
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
/**
* 1. Address `appearance` set to `searchfield` in Safari and Chrome.
* 2. Address `box-sizing` set to `border-box` in Safari and Chrome
*    (include `-moz` to future-proof).
*/
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  /* 2 */
  box-sizing: content-box;
}
/**
* Remove inner padding and search cancel button in Safari and Chrome on OS X.
* Safari (but not Chrome) clips the cancel button when the search input has
* padding (and `textfield` appearance).
*/
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
/**
* Define consistent border, margin, and padding.
*/
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}
/**
* 1. Correct `color` not being inherited in IE 8/9/10/11.
* 2. Remove padding so people aren't caught out if they zero out fieldsets.
*/
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
* Remove default vertical scrollbar in IE 8/9/10/11.
*/
textarea {
  overflow: auto;
}
/**
* Don't inherit the `font-weight` (applied by a rule above).
* NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
*/
optgroup {
  font-weight: 600;
}
/* Tables
========================================================================== */
/**
* Remove most spacing between table cells.
*/
table {
  border-collapse: collapse;
  border-spacing: 0;
}
td,
th {
  padding: 0;
}
/*  import mixin */
.clearfix {
  display: block;
  *zoom: 1;
}
.clearfix:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
.inline-block {
  display: inline-block;
  *display: inline;
  *zoom: 1;
}
.ellipsis {
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
/*  import variable */
/* Common */
html,
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック  Medium', meiryo, sans-serif;
  color: #3f3f3f;
  background-color: #ffffff;
}
a {
  color: #1487bd;
}
a:visited {
  color: #789dae;
}
a:hover {
  color: #0f5373;
}
h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a,
h1 a:hover,
h2 a:hover,
h3 a:hover,
h4 a:hover,
h5 a:hover,
h6 a:hover,
h1 a:visited,
h2 a:visited,
h3 a:visited,
h4 a:visited,
h5 a:visited,
h6 a:visited {
  color: #333333;
  text-decoration: none;
}
a.keyword {
  text-decoration: none;
  border-bottom: 1px dotted #ECEEF1;
  color: #3f3f3f;
}
/* Buttons */
.btn {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #3f3f3f;
  background-color: #ffffff;
  text-align: center;
  vertical-align: middle;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 2px;
  background-clip: padding-box;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none ;
}
.btn:hover {
  background-color: #f5f5f5;
  text-decoration: none ;
}
.btn-small {
  padding: 2px 10px ;
  font-size: 11px ;
}
.btn-large {
  padding: 13px 19px;
  font-size: 17px;
  line-height: normal;
  font-weight: 600;
}
/* ヘッダ（グローバルヘッダ）
グローバルヘッダの中はiframeですが、
#globalheader-container に背景色や文字色を指定することでiframeの中にも色が反映されます。
*/
#globalheader-container {
  background-color: #333;
  color: #fff;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
}
/* container */
#container {
  width: 1140px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 0;
  padding-top: 37px;
}
#container #content {
  display: block;
  *zoom: 1;
}
#container #content:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
.globalheader-off #container {
  padding-top: 0;
}
/* 2カラムレイアウト */
#main {
  width: 640px;
  float: left;
}
#box2 {
  width: 290px;
  float: right;
}
/* 1カラムにしたい場合は下記のコメントアウトを外してください ----

#main {
width: 100%;
float: none;
}

#box2 {
width: 100%;
float: none;
}

#box2-inner {
width: 960px;
.clearfix;
overflow: hidden;
}

.hatena-module {
text-align: left;
padding-right: 20px;
width: 300px;
float: left;

&:nth-child(3n+1) {
clear: both;
}
}

---- END 1カラム */
/* header */
#blog-title {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  text-align: center;
  margin: 0;
  padding: 50px 0;
}
#title {
  margin: 0;
}
#title a {
  color: #3f3f3f;
}
#blog-description {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  font-weight: normal;
  font-size: 80%;
  margin: 5px 0 0 0;
}
/* ヘッダ画像を設定したとき */
.header-image-enable #title {
  padding-top: 70px;
}
.header-image-enable #title,
.header-image-enable #blog-description {
  padding-left: 20px;
}
/* パンくず（カテゴリーページで表示されます） */
#top-box {
  margin: 10px auto 20px;
  font-size: 90%;
}
#top-box .breadcrumb {
  border-top: 1px solid #ECEEF1;
  border-bottom: 1px solid #ECEEF1;
  padding: 10px;
}
/* entry */
.entry {
  position: relative;
  margin-bottom: 50px;
}
.entry-header {
  padding: 15px 0;
  margin-bottom: 20px;
  border-bottom: 1px solid #ECEEF1;
  position: relative;
}
.entry-title {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  font-size: 21px;
  font-weight: 600;
  line-height: 35px;
  margin: 15px 0 20px;
}
/* 日付 */
.date {
  font-weight: 600;
  margin-bottom: 15px;
}
.date a {
  color: #1487bd;
  text-decoration: none;
  font-size: 90%;
}
/* カテゴリ */
.categories {
  margin-top: 10px;
  font-size: 80%;
}
.categories a {
  color: #3f3f3f;
}
.categories.no-categories {
  margin: 0;
}
/* 「編集する」ボタン */
.entry-header-menu {
  position: absolute;
  bottom: 0px;
  left: -60px;
}
.entry-header-menu a {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #3f3f3f;
  background-color: #ffffff;
  text-align: center;
  vertical-align: middle;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 2px;
  background-clip: padding-box;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none ;
}
.entry-header-menu a:hover {
  background-color: #f5f5f5;
  text-decoration: none ;
}
/* entry-content の中の書式 */
.entry-content {
  font-size: 15px;
  line-height: 34px;
  padding-bottom: 10px;
  border-bottom: 1px solid #ECEEF1;
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
}
.entry-content p {
  margin: 0 0 1em 0;
}
.entry-content img {
  max-width: 100%;
}
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
  margin: 1.3em 0 0.8em 0;
  line-height: 1.5;
}
.entry-content h1 {
  font-size: 160%;
}
.entry-content h2 {
  font-size: 150%;
}
.entry-content h3 {
  font-size: 140%;
}
.entry-content h4 {
  font-size: 130%;
}
.entry-content h5 {
  font-size: 110%;
}
.entry-content h6 {
  font-size: 100%;
}
.entry-content table {
  border-collapse: collapse;
  border-spacing: 0;
  margin-bottom: 1em;
}
.entry-content table img {
  max-width: none;
}
.entry-content table th,
.entry-content table td {
  border: 1px solid #ddd;
  padding: 5px 10px;
}
.entry-content table th {
  background: #f5f5f5;
}
.entry-content blockquote {
  border: 1px solid #ECEEF1;
  margin: 0 0 10px;
  padding: 20px;
}
.entry-content blockquote p {
  margin-top: 0;
  margin-bottom: 0;
}
.entry-content pre {
  border: 1px solid #ECEEF1;
  margin: 0 0 10px;
  padding: 20px;
  white-space: pre;
}
.entry-content pre > code {
  margin: 0;
  padding: 0;
  white-space: pre;
  border: 0;
  background: transparent;
  font-family: 'Monaco', 'Consolas', 'Courier New', Courier, monospace, sans-serif;
}
.entry-content code {
  font-size: 90%;
  margin: 0 2px;
  padding: 0 5px;
  border: 1px solid #eaeaea;
  background-color: #f8f8f8;
  border-radius: 3px;
  font-family: 'Monaco', 'Consolas', 'Courier New', Courier, monospace, sans-serif;
}
.entry-content .hatena-asin-detail li {
  line-height: 1.4;
}
/* entry-footer */
.entry-footer {
  margin-top: 10px;
}
.entry-footer-section {
  font-size: 80%;
  color: #999999;
}
.entry-footer-section a {
  color: #999999;
}
.social-buttons,
.entry-footer-html {
  margin: 10px 0;
}
/* コメント */
.comment-box ul {
  list-style: none;
  margin: 0 0 15px 0;
  padding: 0;
  font-size: 95%;
  line-height: 1.7;
}
.comment-box li {
  padding: 10px 0 10px 60px;
  border-bottom: 1px solid #ECEEF1;
  position: relative;
}
.comment-box li:first-child {
  border-top: 1px solid #ECEEF1;
}
.comment-box .read-more-comments {
  padding-left: 0;
}
.comment-box .hatena-id-icon {
  position: absolute;
  top: 10px;
  left: 0;
  width: 50px ;
  height: 50px ;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 3px;
  background-clip: padding-box;
}
.comment-user-name {
  margin: 0 0 10px 0;
  font-weight: 600;
}
.comment-content {
  font-size: 90%;
  margin: 0 0 10px 0;
  word-wrap: break-word;
}
.comment-content p {
  margin: 0 0 10px 0;
}
.comment-metadata {
  font-size: 80%;
  color: #999999;
  margin: 0;
}
.comment-metadata a {
  color: #999999;
}
.leave-comment-title {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #3f3f3f;
  background-color: #ffffff;
  text-align: center;
  vertical-align: middle;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 2px;
  background-clip: padding-box;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none ;
}
.leave-comment-title:hover {
  background-color: #f5f5f5;
  text-decoration: none ;
}
/* sidebar */
#box2 {
  font-size: 85%;
  line-height: 1.5;
}
.hatena-module {
  margin-bottom: 60px;
}
.hatena-module-title {
  font-weight: 600;
  margin-bottom: 15px;
  font-size: 120%;
  padding:0 0 5px 5px;
  border-bottom: 1px solid #ECEEF1;
}
.hatena-module-title a {
  color: #3f3f3f;
  text-decoration: none;
}
.hatena-module-title a:hover {
  text-decoration: underline;
}
/* Profile module */
.hatena-module-profile .profile-icon {
  float: left;
  margin: 0 10px 10px 0;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 5px;
  background-clip: padding-box;
}
.hatena-module-profile .id {
  display: block;
  font-weight: 600;
  font-size: 110%;
  margin-bottom: 5px;
}
.hatena-module-profile .profile-description {
  font-size: 90%;
}
.hatena-module-profile .profile-description p {
  margin-top: 0;
}
/* urllist module
リンク・最新記事・最近のコメント・月別アーカイブ・カテゴリモジュールは .hatena-urllist という共通の class が振られます
*/
.hatena-urllist {
  list-style: none;
  margin: 0 0 0 0;
  padding: 0 0 0 0;
}
.hatena-urllist li {
  padding: 8px 0;
  border-bottom: 1px solid #ECEEF1;
  line-height: 1.5;
}
.hatena-urllist li a {
  text-decoration: none;
}
/* Search module */
.hatena-module-search-box .search-form {
  border: 1px solid #ECEEF1;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 3px;
  background-clip: padding-box;
  width: 100%;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
}
.hatena-module-search-box .search-module-input {
  padding: 10px 10px;
  color: #3f3f3f;
  background: none;
  border: none;
  outline: none;
  height: 20px;
  width: 90%;
}
.hatena-module-search-box .search-module-button {
  width: 35px;
  height: 35px;
  background: transparent url(https://cdn.blog.st-hatena.com/images/theme/search.png?version=17d66ae0e3fc0e087ead6e3d21294b) no-repeat right center;
  border: none;
  outline: none;
  text-indent: -9999px;
  position: absolute;
  top: 1px;
  right: 10px;
  opacity: 0.5;
}
.hatena-module-search-box .search-module-button:hover {
  opacity: 0.85;
}
/* Pager */
.pager {
  margin: 1em 0;
  display: block;
  *zoom: 1;
}
.pager:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
.pager .pager-prev {
  float: left;
  text-align: left;
  width: 45%;
}
.pager .pager-next {
  float: right;
  text-align: right;
  width: 45%;
}
/* Footer */
#footer {
  padding: 30px 0;
  text-align: center;
  color: #999999;
  line-height: 1.5;
  font-size: 80%;
}
#footer p {
  margin: 0;
}
#footer a {
  color: #999999;
}
/* About ページ */
.page-about dt {
  font-size: 16px;
  font-weight: 600;
  border-bottom: 1px solid #dfdfdf;
  margin-bottom: 5px;
}
.page-about dd {
  margin-left: 0;
  margin-bottom: 30px;
}
/* archive ページ */
.page-archive .archive-entries .archive-entry {
  margin-bottom: 3em;
}
.page-archive .archive-entries .entry-title {
  font-size: 130%;
  margin: 0 0 .5em;
}
.page-archive .archive-entries .categories {
  margin: 0 0 .5em;
}
.page-archive .archive-entries .entry-description {
  margin: 0 0 1em;
  font-size: 13px;
  line-height: 25px;
}
.page-archive .categories a {
  color: #3f3f3f;
  text-decoration: none;
  display: inline-block;
  *display: inline;
  *zoom: 1;
  margin-bottom:5px;
}

.shrbtn{
  padding:0;
  margin:15px 0;
  width: 100%;
  background:#ECEEF1;
  text-align:center;
  display: inline-flex;
}

.share_btn{
  display: inline-block;
  width: calc(100% / 5);
  margin:4px 6px;
  height: 40px;
  line-height: 40px;
  font-size: 18px;
  color:#3f3f3f;
  border:1px solid #ECEEF1;
  border-radius:0;
  text-align: center;
  vertical-align: middle;
  overflow: hidden;
  font-weight: 600;
  transition: .3s;
  background:#fafafa;
}

.share_btn:first-of-type{
  margin-left:0;
}

.share_btn:last-of-type{
  margin-right:0;
}

.share_btn:hover{
  color:#3f3f3f;
}

.share_btn .fa {line-height:40px}


/* ### スライドメニュー ### */
#gnav {
  border-top: 1px solid #ECEEF1;
  border-bottom: 1px solid #ECEEF1;
  margin: 0 0 10px;
  background: #ffffff;
  font-size: 0;
  padding: 0 0 0;
}

#gnav .menu a {
  display: block;
  color: #3f3f3f;
  font-size: 13px;
  font-weight: 500;
  text-decoration:none;
  text-align: center;
  overflow: hidden;
  box-sizing: border-box;

}


#gnav .gnav-inner {
  width: 100%;
  padding: 12px 20px;
  overflow-x: auto;
  overflow-y: hidden;
  box-sizing: border-box;
  text-align: center;
  white-space: nowrap;
  margin: 0 auto;
  -webkit-font-smoothing: antialiased;
  -webkit-overflow-scrolling: touch;
}

#gnav .menu {
  display: inline-block;
}

/* ### スライドメニューを横いっぱいに広げる ### */
#top-editarea .section {
  width: 100% ;
  margin-left: auto;
  margin-right: auto;

}

#top-editarea{
  margin-bottom: 15px;
}

.id a{
  color: #3f3f3f;
  text-decoration: none;
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
}


.hatena-module-profile .profile-description {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
}

.table-of-contents {
  position: relative;
  background-color: #fafafa;
  border:1px solid #ECEEF1;
  padding: 60px 70px 25px;
  border-radius: 0;
  font-size: 14px;
  line-height: 28px;
}


.table-of-contents::before {
  position: absolute;
  display: block;
  text-align: center;
  top: 15px;
  left: 50%;
  margin-left: -1em;
  font-size: 20px;
  font-weight: 700;
  content: '目次';
  z-index: 2;
}


.table-of-contents li a {
  text-decoration: none;
  line-height: 35px;
  color:#3f3f3f;
}

.archive-header-category{
  margin-bottom:25px;
}

.archive-heading{
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  border-bottom:1px solid #ECEEF1;
  font-weight: 600;
  font-size: 21px;
  line-height: 35px;
  padding-bottom:5px;
  margin-bottom:25px;
}

.footer{
  background:#3f3f3f;
  color:#fff;
  padding:30px 0;
}
.footer ul li{
  text-align:center;
  display: block;
}

.footer .footer-title{
  margin-bottom:10px;
}

.footer .footer-copyright{
  font-size:12px;
}

.footer-list{
  padding: 0;
}

.categories a{
  color: #3f3f3f;
  text-decoration: none;
  padding: 4px 0;
  border-radius: 0;
  font-size:13px;
  vertical-align: middle;
  margin-right: 10px;
}

.categories a:before{
  font-family: FontAwesome;
  content:"\f02b";
  font-size: 16px;
  vertical-align: middle;
  margin-right: 5px;
  color:#2f2f2f;
}

/*  import media queries */
/* Media Queries - Retina Display */
@media screen and (min-width: 1139px){

  #blog-title #title{
    font-size: 37px;
    line-height: 60px;
    font-weight:500;
  }

  .hatena-module-search-box .search-module-button {
    background: transparent url(https://cdn.blog.st-hatena.com/images/theme/search@2x.png?version=17d66ae0e3fc0e087ead6e3d21294b) no-repeat right center;
    background-size: 20px 20px;
  }
  #container {
    border-right: 1px solid #ECEEF1;
    border-left: 1px solid #ECEEF1;
  }
  #content{
    margin: 35px 55px;
  }
  .breadcrumb-inner{
    margin: 0 5%;
  }
  .date a {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 15px;
    padding: 1px;
  }
  .date {
    font-weight: 500;
    margin-bottom: 5px;
  }

  .date:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95%;
    top: 0;
    color: #3f3f3f;
  }

  .page-archive .entry-thumb {
    border-radius: 5px;
    margin-right: 20px;
  }

  #box2 .urllist-image {
    border-radius: 5px;
    margin-right: 15px;
  }

  .urllist-date-link time {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 14px;
    padding: 1px;
  }

  .urllist-date-link time:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95%
    top: 0;
    color: #3f3f3f;
  }


  .shrbtn{
    background:none;
  }

  #box2{
    margin-top: 15px;
  }

  .page-archive .archive-entries .entry-title {
    margin-top:10px;
    font-size: 19px;
  }

  .hatena-urllist li a {
    font-size: 13px;
    line-height: 25px;
    color:#3f3f3f;
  }
  #gnav .menu a {
    padding: 0 15px;
  }
}
/* Media Queries - Tablet */
@media screen and (max-width: 1138px){
  #gnav .menu{
    margin-right:20px;
  }
  #gnav .menu a{
    font-size: 12px;
  }
  #container {
    width: 100% ;
    word-wrap: break-word;
    overflow: hidden;
    padding-top: 0;
  }
  #main {
    width: 93.75% ;
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2 {
    width: 93.75% ;
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2-inner {
    width: 100% ;
  }
  .hatena-module {
    width: 100%;
    float: none;
  }
  .date a {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 15px;
    padding: 1px;
  }
  .date {
    font-weight: 500;
    margin-bottom: 5px;
  }

  .date:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 18px;
    top: 0;
    color: #3f3f3f;
  }

  .page-archive .entry-thumb {
    border-radius: 5px;
  }
  #box2 .urllist-image {
    border-radius: 5px;
  }

  .urllist-date-link time {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 14px ;
    padding: 1px;
  }

  .urllist-date-link time:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95% ;
    top: 0;
    color: #3f3f3f;
  }
  .shrbtn{
    background:none ;
  }
.
  .hatena-urllist li a {
    color:#3f3f3f;
  }
  .entry .entry-title{
    font-size: 22px;
  }
  .categories a{
    color: #3f3f3f;
    text-decoration: none;
    padding: 2px 7px;
    border-radius: 2px;
    margin: 0 2px;
  }
  .page-archive .archive-entries .entry-title {
    font-size: 18px;
  }

}
/* Media Queries - Small Tablet & Smartphone */
@media screen and (max-width:640px){
  #globalheader-container {
    position: static;
  }
  #blog-title #title{
    font-size: 30px;
    font-weight:500;
    font-family: 'Nunito', sans-serif;
  }
  #blog-description {
    font-size:11px;
  }
  #container {
    width: 100%;
    word-wrap: break-word;
    overflow: hidden;
    padding-top: 0;
  }
  #main {
    width: 93.75%;
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2 {
    width: 93.75%
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2-inner {
    width: 100%;
  }
  .hatena-module {
    width: 100%;
    float: none;
  }
  .entry-header-menu {
    top: -30px;
    left: 0px;
  }
  .archive-entry-header{
    width : -webkit-calc(100% -90px);
    width: calc(100% - 90px);
    float: right;
  }
  .page-archive .archive-entries .entry-title {
    font-size:14px;
    line-height: 25px;
    font-weight: 400;
    margin:0;
  }
  .archive-entries .entry-description{
    font-size:11px;
    display:none;
  }
  .page-archive .entry-thumb {
    width: 75px;
    height: 75px;
    border: 1px solid #ECEEF1;
    background-size: 100%;
    float:left;
    border-radius: 3px;
  }

  .page-archive .categories{
    display: none;
  }

  .page-archive .archive-entries .archive-entry {
    margin-bottom: 0;
    padding: 17px 0;
    border-bottom: 1px solid #ECEEF1;
}
  .date a {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 12px;
    padding: 1px;
  }
  .date {
    font-weight: 500;
    margin-bottom: 5px;
  }

  .date:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95%;
    top: 0;
    color: #3f3f3f;
  }

  .page-archive .social-buttons{
    display: none;
  }

  #blog-title {
    text-align: center;
    padding: 35px 0 35px;
    margin:0;
  }

  .entry .entry-title{
    font-size: 18px;
    line-height: 30px;
    margin: 10px 0 15px;
    font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  }

  .entry .entry-header{
    padding: 10px 0 10px 0;
    border:none;
  }

  .table-of-contents {
    position: relative;
    background-color: #fafafa;
    border:1px solid #ECEEF1;
    padding: 60px 45px 25px;
    border-radius: 0;
    font-size: 14px;
    line-height: 28px;
  }

  #box2 .urllist-image {
    max-width: 100%;
    width: 75px;
    border-radius: 5px;
    margin-right: 10px;
    border: 1px solid #ECEEF1;
    height: 75px;
  }
  .hatena-urllist li{
    padding: 10px 0 0px;
  }

  .hatena-urllist li a {
    font-size: 13px ;
    line-height: 20px;
    font-weight: 500;
    color: #3f3f3f;
    text-decoration: none;
  }

  .archive-module-year{
    border:none ;
  }

  .urllist-date-link time {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 12px ;
    padding: 1px;
  }

  .urllist-date-link time:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95% ;
    top: 0;
    color: #3f3f3f;
  }
  .archive-entries{
    margin:0 0 40px;
  }

  .id a{
    font-weight: normal;
    text-decoration: none;
    color: #3f3f3f;
  }

  .entry-content {
    font-size: 14px;
  }
  .hatena-module {
    margin-bottom: 40px;
  }
  .urllist-image{
    width: 70px;
    border-radius: 5px;
  }
  .related-entries .related-entries-entry-body{
    display: none;
  }
  .pager{
    text-align: center;
    margin-bottom: 45px;
  }
  :not(.permalink)>.pager-next{
    float:none ;
    text-align: center ;
  }
  :not(.permalink)>.pager-next a{
    text-decoration: none;
    padding: 10px 100px;
    border-radius: 4px;
    border: 1px solid #ECEEF1;
    background: #fafafa;
    color: #3f3f3f;
  }
  .pager-permalink{
    display:none;
  }
}
/* Media Queries - Smartphone */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&family=Noto+Serif+JP:wght@700&display=swap'); 
/*記事一覧のサムネイルの大きさ*/
.page-archive .entry-thumb {
 border:none !important;
}
@media screen and (max-width: 640px){
.page-archive .entry-thumb {
    width: 100% !important;
    height: auto !important;
}
}
/* 記事一覧のタイトルサイズを修正 */
.page-archive .entry-title, 
.page-archive .entry-title a {
    font-size: 16px; /* 25pxから16pxへ変更 */
    line-height: 1.5 !important;
}
/*グロナビ*/
.nav-categories.nav-categories{
justify-content: space-around;
}
.nav-categories li a{
font-family: '游ゴシック Medium', meiryo, sans-serif;
}
/* 画像キャプションのスタイル変更 */
.caption {
    font-size: 10px !important;
    text-align: left !important;
    display: block; /* 左寄せを確実にするため */
    margin-top: 5px; /* 画像との間隔（お好みで） */
}
#container {
    padding-top: 50px!important;
}
/* スマホでのタイトル青文字を強制修正 */
#container .title-new a.chappy {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    text-decoration: none !important;
}
/* 念のため、記述ミスによるエラーを防ぐための閉じタグ調整 */
/* </system> */
/* <system section="background" selected="fff"> */
body{background:#fff;}
/* </system> */
header#blog-title {
    display: none;
}
@media screen and (min-width: 992px) {
#content-inner { 
max-width:4000px!important;
}}
@media screen and (min-width: 1139px) {
    #container {
        border-right: 0px solid #ECEEF1;
        border-left: 0px solid #ECEEF1;
    }}
#container {
    width: 100%;
}
@media screen and (min-width: 1139px) {
    #content {
        margin: 35px 0px;
    }
}
@media screen and (min-width: 992px) {
    #box2-inner {
        padding: 0!important;
    }
}
@media screen and (max-width: 1138px) {
    #box2 {
        width: 100%;}
        }
.entry-thumb {
    max-height: 500px!important;
}
@media screen and (max-width: 1138px) {
    #box2 {
        width: 100%;
        }
}
/*サイドバーひきのばしpc*/
@media screen and (min-width:992px) {
#content-inner {
    flex-wrap: wrap;
}
#wrapper {
    width: 100%;
}
#box2 {
    width: 100%;
}
#box2-inner {
    padding: 0 20px;
}
}
/*メイン記事非表示*/
.page-index div#main-inner {
    display: none;
}
/* ブログタイトルに画像 */
.header-image-only #blog-title #blog-title-inner {
    height: 76px;
    background-size: contain;
    background-position: center -10px!important;
}
@media screen and (min-width:920px){ 
.header-image-only #blog-title #blog-title-inner {
height: 76px;
background-position: calc(20px + 2.6%) -10px !important;
}}
.title-new {
    position: fixed;
    top: 0 !important;
    left: 0;
    z-index: 100;
    width: 100%;
    height: 50px;
    padding: 0;
    background-color: #000;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
    font-size: 12px;
}
.title-new a{
color: #fff;
text-decoration: none;
}
@media screen and (min-width:640px){
.title-new a.chappy {
    margin: 0 15px;
}
.title-new {
    display: flex;
    justify-content: flex-start;
}}
.nexttomenu {
    z-index: 101;
    position: fixed;
    top: 0px;
    right: 61px;
    font-size: 20px;
    height: 50px;
    display: flex;
    align-items: center;
}
@media screen and (max-width:640px){
.nexttomenu {
display:none;
}
}
.nexttomenu a.twitter {
    color: #555 !important;
    text-decoration: none;
    font-size: 26px;
    margin: 0 10px;
}
.nexttomenu a.twitter:visited {
    color: #555 !important;
    text-decoration: none;
}
.nexttomenu a.hatena {
    color: #555 !important;
    text-decoration: none;
    font-size: 26px;
    margin: 3px 15px 0 10px;
}
.nexttomenu a.hatena:visited {
    color: #555 !important;
    text-decoration: none;
}
/*カルーセル*/
.hatena-module-custom-top .archive-entries {
max-width:1000px
display:block;
background:transparent;
}
.hatena-module-custom-top li.urllist-item.recent-entries-item {
width: 50%;
height: 400px;
margin-top:0em;
margin-right:2vw;
margin-bottom:1em;
border-radius:5px;
counter-increment: carousel-cell;
overflow: hidden;
padding: 0;
}
.hatena-module-custom-top ul.recent-entries.hatena-urllist.urllist-with-thumbnails.flickity-enabled.is-draggable {
    margin: 0px;
}
.hatena-module-custom-top .flickity-page-dots .dot {
    padding: 0;
}
.hatena-module-custom-top .urllist-categories.recent-entries-categories{
display:block;
position:absolute;
top:1vw;
left:.5vw;
z-index:2;
}
.hatena-module-custom-top a.urllist-category-link.recent-entries-category-link{
padding:.6vw;
font-size:.7em;
font-weight:800;
letter-spacing:.2vw;
text-decoration:none;
border-radius:20em;
color:black;
background:white;
opacity:.5;}
.hatena-module-custom-top a.urllist-category-link.recent-entries-category-link:hover{
background:#f4dde3;
transition-duration: 0.3s;}
.hatena-module-custom-top a.urllist-title-link.recent-entries-title-link.urllist-title.recent-entries-title{
display: -webkit-box;
-webkit-box-orient: vertical;
flex: 1 0 auto;
padding:0 0.5vw;
font-size: 1em;
font-weight: 800;
line-height: 1em;
text-decoration:none;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
color: #fff;
width: 88%;
margin-inline: auto;
max-inline-size: max-content;}
.hatena-module-custom-top img.urllist-image.recent-entries-image {
    object-fit: cover !important;
    width: 100% !important;
    height: 400px !important;
    margin: 0;
    border-radius: 10px;
    opacity:0.65;
}
.hatena-module-custom-top img.urllist-image.recent-entries-image:hover{
opacity: 0.6;
}
.hatena-module-custom-top .urllist-item-inner.recent-entries-item-inner {
    background: #000;
    border-radius: 10px;
    width: 100%;
    height: 400px;
}
@media screen and (max-width:640px){ 
.hatena-module-custom-top li.urllist-item.recent-entries-item {
width:60%;
height: 200px;
}
.hatena-module-custom-top img.urllist-image.recent-entries-image {
    object-fit: cover !important;
    width: 100% !important;
    height: 200px !important;
    margin: 0;
    border-radius: 10px;
}
.hatena-module-custom-top{
padding-top: 20px!important;
}
}
.hatena-module-custom-top a.urllist-see-more-link.recent-entries-see-more-link {
color:#fff;
}
.hatena-module-custom-top .urllist-see-more {
text-align: center;
margin-top: 40px;
border: 1px solid #fff;
padding: 1em;
}
.page-index .hatena-module-custom-top .hatena-module-title {
    border-bottom: 0px;
    display:none;
}
.hatena-module-custom-top .flickity-page-dots {
    bottom: -15px;
    }
.hatena-module-custom-cat .hatena-module-title {
    border-bottom: 0px;
    display:none;
}
.hatena-module-custom-link .hatena-module-title {
    border-bottom: 0px;
    display:none;
}
.hatena-module-custom-top {
    padding-bottom: 30px;
    padding-top: 10px;
    background: #fff; /*★*/
    margin-bottom: 0;
}
.page-index .hatena-module-custom-top {
margin-top: 0px!important;
}
.hatena-module-custom-top .hatena-module-title a {
    color: #3f3f3f;
}
/* ハンバーガーメニュー */
.drawer_menu .drawer_nav_wrapper {
transform: translate(0);
width: 100%;
height: 50px;
/* PC用メニュー高さ */
position: relative;
top: auto;
right: auto;
z-index: 10;
background-color: #555;
/* PC用メニュー背景色 */
}
.drawer_menu .drawer_nav {
max-width: 1000px;
/* コンテンツ幅に合わせる */
padding: 0;
margin: 60px auto;
display: -webkit-flex;
display: flex;
-webkit-justify-content: center;
justify-content: center;
list-style-type: none;
}
.drawer_menu .drawer_nav li {
font-size: 16px;
margin: 0;
padding: 0;
width: 100%;
height: 50px;
/* PC用メニュー高さ */
line-height: 50px;
/* PC用メニュー高さ */
background-color: #555;
/* PC用メニューボタン背景色 */
text-align: center;
list-style-type: none;
}
.drawer_menu .drawer_nav li:hover {
background-color: #999;
/* PC用メニューボタンマウスオーバー背景色 */
}
.drawer_menu .drawer_nav li a {
color: #fff;
/* PC用メニューボタン文字色 */
}
.drawer_title {
padding: 10px 0 10px 0;
margin: 40px 0 10px 0;
font-size: 1.3em;
font-family: 'Sofia', cursive;
background-size: 100%;
background-image: url(https://cdn-ak.f.st-hatena.com/images/fotolife/t/travelwz/20221014/20221014163856.png);
text-align: center;
}
/* PC非表示 */
@media screen and (min-width:1001px) {
.pc-hidden {
display: none;
text-align: center;
}
}
/*+++ Default Button Color +++*/
.drawer_menu .drawer_button {
color: #fff;
/* ハンバーガーメニュー文字色 */
display: none;
}
.drawer_menu .drawer_button .drawer_bar {
background-color: #555;
/* ハンバーガーメニュー三本線の色 */
}
/* 1000px以下 */
.drawer_menu .drawer_bg {
width: 100%;
height: 100%;
position: fixed;
z-index: 999;
background-color: rgba(51, 51, 51, 0.5);
display: none;
top: 0;
left: 0;
}
.drawer_menu .drawer_button {
display: block;
background-color: transparent;
color: #555;
border: none;
padding: 5px;
width: 50px;
letter-spacing: 0.1em;
cursor: pointer;
position: fixed;
top: 0px;
right: 10px;
z-index: 1001;
text-align: center;
outline: none;
}
.drawer_menu .drawer_button.active .drawer_bar {
width: 40px;
}
.drawer_menu .drawer_button.active .drawer_bar1 {
transform: rotate(30deg);
}
.drawer_menu .drawer_button.active .drawer_bar2 {
opacity: 0;
}
.drawer_menu .drawer_button.active .drawer_bar3 {
transform: rotate(-30deg);
}
.drawer_menu .drawer_button.active .drawer_menu_text {
display: none;
}
.drawer_menu .drawer_button.active .drawer_close {
display: block;
}
.drawer_menu .drawer_bar {
display: block;
height: 2px;
margin: 8px 2px;
transition: all 0.2s;
transform-origin: 0 0;
}
.drawer_menu .drawer_text {
text-align: center;
font-size: 10px;
}
.drawer_menu .drawer_close {
letter-spacing: 0.08em;
display: none;
}
.drawer_menu .drawer_menu_text {
display: block;
}
.drawer_menu .drawer_nav_wrapper {
width: 250px;
height: 100%;
transition: all 0.2s;
transform: translate(250px);
position: fixed;
top: 0;
right: 0;
z-index: 1000;
background-color: #FFF;
/* ドロワーメニュー内背景色 */
overflow-x: hidden;
overflow-y: auto;
}
.drawer_menu .drawer_nav {
display: block;
position: relative;
}
.drawer_menu .drawer_nav li {
background-color: #fff;
height: auto;
line-height: 50px;
/*  ドロワーメニューリスト項目高さ */
position: relative;
border-bottom: 1px solid #eee;
}
.drawer_menu .drawer_nav li a {
background-color: #fff;
/* ドロワーメニューリスト背景色 */
color: #555;
/* ドロワーメニューリスト文字色 */
display: block;
text-align: left;
padding-left: 20px;
}
.drawer_menu .hatena-urllist li {
    list-style-type: none;
}
/* スマートフォン2階層目 */
.drawer_menu .drawer_nav li:hover ul.second-level {
display: block;
}
.drawer_menu .drawer_nav li ul.second-level {
display: none;
position: relative;
padding: 0;
z-index: 1001;
}
.drawer_menu .drawer_nav li ul.second-level li a {
padding-left: 40px;
}
.drawer_menu .drawer_nav_wrapper.open {
transform: translate(0);
}
.drawer_menu.left .drawer_button {
right: auto;
left: 32px;
}
.drawer_menu.left .drawer_nav_wrapper {
transform: translate(-250px);
right: auto;
left: 0;
}
.drawer_menu.left .drawer_nav_wrapper.open {
transform: translate(0);
}
.pc-hidden {
text-align: center;
}
.touch-btn {
color: #555;
position: absolute;
top: .25rem;
right: 2%;
display: block;
z-index: 10;
width: 50px;
height: 50px;
text-align: center;
vertical-align: middle;
}
.fixed {
position: fixed;
top: 0;
left: 0;
width: 100%;
z-index: 10;
}
.drawer_menu ul.hatena-urllist:first-child {
    padding-top: 45px;
    padding-bottom: 0px;
}
.drawer_menu ul.hatena-urllist {
    padding-top: 45px;
    padding-bottom: 45px;
}
.hatena-breadcrumb-plus-child2 li {
    text-align: left;
    margin-left: 3em;
}
/*検索*/
.hatena-module-custom-search {
    padding: 30px 20px 30px 20px;
    background: #fff; /*★*/
    margin-bottom: 0;
}
@media screen and (max-width: 640px) {
.hatena-module-custom-search {
    padding: 10px 10px 10px 10px!important;}
}
/*カルーセルc 雑誌風*/
.hatena-module-custom-pickup .flickity-page-dots {
width: 100%;
bottom:-25px!important;
}
.hatena-module-custom-pickup .flickity-page-dots .dot {
    display: inline-block;
    width: 4px;
    height: 4px;
    margin: 0 6px;
    background: transparent;
    border-radius: 50%;
    opacity: 1;
    cursor: pointer;
    border: 1px solid #fff;
}
.hatena-module-custom-pickup .flickity-page-dots .dot.is-selected {
    opacity: 1;
    background: #fff;
}
.hatena-module-custom-pickup .recent-entries {
max-width:1000px;
display:block;
padding:1em;
background:transparent;
height: 350px}
.hatena-module-custom-pickup .flickity-enabled.is-draggable {
    margin: 0 -14px;
}
.hatena-module-custom-pickup li.urllist-item.entries-access-ranking-item {
width: 210px;
height: 300px;
margin-right:2vw;
counter-increment: carousel-cell;
overflow: hidden;
background: transparent;
}
.hatena-module-custom-pickup img.urllist-image.entries-access-ranking-image {
    height: 300px!important;
    width: 100%;
    object-fit: cover;
}
.hatena-module-custom-pickup a.urllist-title-link.entries-access-ranking-title-link.urllist-title.entries-access-ranking-title {
    position: absolute;
    bottom: 0;
    left: 0;
    color: #fff;
    margin: 0;
    background: linear-gradient(180deg, transparent, #000000b5);
    padding: 7em 1em 1em 1em;
}
.hatena-module-custom-pickup .urllist-categories.entries-access-ranking-categories {
    position: absolute;
    top: 0;
    left: 0;
    margin: 0;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}
.hatena-module-custom-pickup .urllist-category-link {
    background: #ffffffe3;
    color: #555;
    font-size: 0.6rem;
    padding: 0.5em;
}
.hatena-module-custom-pickup .hatena-urllist li {
    padding: 0;
}
@media screen and (max-width: 640px) {
.hatena-module-custom-pickup .urllist-image {
width: 100%!important;}
}
.hatena-module-custom-pickup {
    padding: 30px 20px 30px 20px;
    background: #fff; /*★*/
    margin-bottom: 0;
}
@media screen and (max-width: 640px) {
.hatena-module-custom-pickup {
    padding: 30px 10px 30px 10px!important;}
}
.hatena-module-custom-pickup li.urllist-item.entries-access-ranking-item.rank-1:before {
    content: "1";
    display: flex;
    position: absolute;
    color: #fff;
    background: #000;
    font-size: 1.1em;
    width: 1.5em;
    height: 1.5em;
    border-radius: 50%;
    justify-content: center;
    align-items: center;
}
.hatena-module-custom-pickup li.urllist-item.entries-access-ranking-item.rank-2:before {
    content: "2";
    display: flex;
    position: absolute;
    color: #fff;
    background: #000;
    font-size: 1.1em;
    width: 1.5em;
    height: 1.5em;
    border-radius: 50%;
    justify-content: center;
    align-items: center;
}
.hatena-module-custom-pickup li.urllist-item.entries-access-ranking-item.rank-3:before {
    content: "3";
    display: flex;
    position: absolute;
    color: #fff;
    background: #000;
    font-size: 1.1em;
    width: 1.5em;
    height: 1.5em;
    border-radius: 50%;
    justify-content: center;
    align-items: center;
}
.hatena-module-custom-pickup li.urllist-item.entries-access-ranking-item.rank-4:before {
    content: "4";
    display: flex;
    position: absolute;
    color: #fff;
    background: #000;
    font-size: 1.1em;
    width: 1.5em;
    height: 1.5em;
    border-radius: 50%;
    justify-content: center;
    align-items: center;
}
.hatena-module-custom-pickup li.urllist-item.entries-access-ranking-item.rank-5:before {
    content: "5";
    display: flex;
    position: absolute;
    color: #fff;
    background: #000;
    font-size: 1.1em;
    width: 1.5em;
    height: 1.5em;
    border-radius: 50%;
    justify-content: center;
    align-items: center;
}
/* 今の a.urllist-see-more-link と ::before の2ブロックを、この下で置き換えて保存 */

.urllist-see-more {
  text-align: center;
  margin-top: 24px;
  margin-bottom: 8px;
}

a.urllist-see-more-link.recent-entries-see-more-link {
  text-decoration: none;
  float: none;
  display: inline-block;
  font-size: 0;
  color: #fff;
  background: #000;
  border: 2px solid #fff;
  border-radius: 50px;
  padding: 12px 28px;
  text-align: center;
}

a.urllist-see-more-link.recent-entries-see-more-link::before {
  content: "LOAD MORE";
  font-size: 12px;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.1em;
}

/*プロフィール*/
.profile-img img {
position: absolute;
top: -50px;
left: 50%;
transform: translateX(-50%);
border-radius: 50%;
width: 100px;
height: 100px !important;
}
.profile {
    background: #bfcfd8;
    position: relative;
    padding: 70px 0 60px 0;
    margin-top: 45px;
    font-size: 0.8em;
}
.profile p {
    text-align: center;
    margin-top: 5em;
}
.profile-description {
    margin: 30px 0 20px 0;
}
.follow-buttons-profile {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: CENTER;
    margin: 30px 0;
}
a.prof {
margin: 0 10px;
}
.follow {
    display: flex;
    justify-content: center;
    margin: 10px 0;
}
.profile .follow a {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin: 0 10px;
}
.profile .name {
font-size:1.2em;
}
/*カード型　最新記事*/
@media screen and (max-width: 640px) {
    .hatena-module {
        width: auto;
        }
}
@media screen and (max-width: 1138px) {
    .hatena-module {
        width: auto;
        }
}
.hatena-module-custom-latest {
    padding: 30px 20px 30px 20px;
    background: #fff; /*★*/
    margin-bottom: 0;
}
@media screen and (max-width: 640px) {
.hatena-module-custom-latest {
    padding: 30px 10px 30px 10px!important;}
}
.hatena-module-custom-latest ul.recent-entries.hatena-urllist.urllist-with-thumbnails {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
}
.hatena-module-custom-latest li.urllist-item.recent-entries-item {
    width: 28%;
    margin: 0 2.6%;
}
/* ★カテゴリ背景色*/
.hatena-module-custom-latest a.urllist-category-link.recent-entries-category-link {
    background: #b3b1b1;
    color: #fff;
    font-size: 0.6rem;
    padding: 0.4em;
    margin: 0 5px 5px 0;
}
@media screen and (max-width:640px){ 
.hatena-module-custom-latest li.urllist-item.recent-entries-item {
    width: 48%;
    margin: 3px;
}}
.hatena-module-custom-latest a.urllist-category-link.recent-entries-category-link.category-HOT-NEWS {
    display: none;
}
@media screen and (max-width: 640px) {
    .hatena-module-custom-latest .urllist-image {
        width: 100%!important;
        height: auto!important;
    }
}
.hatena-module-custom-latest img.urllist-image.recent-entries-image {
border:0;
}
/* ★カテゴリを左上にする */
.hatena-module-custom-latest .urllist-item-inner.recent-entries-item-inner {
    position: relative;
}
.hatena-module-custom-latest .urllist-categories.recent-entries-categories {
    position: absolute;
    top: 0;
    left: 0;
}
@media screen and (max-width: 640px) {
    #box2 .hatena-module-custom-latest .urllist-image {
        border: 0px solid #ECEEF1;
        }
}
/*カード型　WORK*/
.hatena-module-custom-work ul.recent-entries.hatena-urllist.urllist-with-thumbnails {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
}
.hatena-module-custom-work li.urllist-item.recent-entries-item {
    width: 28%;
    margin: 0 2.6%;
}
.hatena-module-custom-work a.urllist-category-link.recent-entries-category-link {
    background: #b3b1b1;
    color: #fff;
    font-size: 0.6rem;
    padding: 0.5em;
    margin: 0 5px 5px 0;
}
@media screen and (max-width:640px){ 
.hatena-module-custom-work li.urllist-item.recent-entries-item {
    width: 48%;
    margin: 3px;
}}
.hatena-module-custom-work a.urllist-category-link.recent-entries-category-link.category-HOT-NEWS {
    display: none;
}
@media screen and (max-width: 640px) {
    .hatena-module-custom-work .urllist-image {
        width: 100%!important;
        height: auto!important;
    }
}
.hatena-module-custom-work {
    padding: 30px 20px 30px 20px;
    background: #fff; /*★*/
    margin-bottom: 0;
}
@media screen and (max-width: 640px) {
.hatena-module-custom-work {
    padding: 30px 10px 30px 10px!important;}
}
/*カード型　TRAVEL*/
.hatena-module-custom-travel ul.recent-entries.hatena-urllist.urllist-with-thumbnails {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
}
.hatena-module-custom-travel li.urllist-item.recent-entries-item {
    width: 28%;
    margin: 0 2.6%;
}
.hatena-module-custom-travel a.urllist-category-link.recent-entries-category-link {
    background: #b3b1b1;
    color: #fff;
    font-size: 0.6rem;
    padding: 0.5em;
    margin: 0 5px 5px 0;
}
@media screen and (max-width:640px){ 
.hatena-module-custom-travel li.urllist-item.recent-entries-item {
    width: 48%;
    margin: 3px;
}}
.hatena-module-custom-travel a.urllist-category-link.recent-entries-category-link.category-HOT-NEWS {
    display: none;
}
@media screen and (max-width: 640px) {
    .hatena-module-custom-travel .urllist-image {
        width: 100%!important;
        height: auto!important;
    }
}
.hatena-module-custom-travel {
    padding: 30px 20px 60px 20px;
    background: #fff; /*★*/
    margin-bottom: 0;
}
@media screen and (max-width: 640px) {
.hatena-module-custom-travel {
    padding: 30px 10px 30px 10px!important;}
}
.hatena-module.hatena-module-html.hatena-module-custom-profile {
    margin-bottom: -60px !important;
}
.hatena-module.hatena-module-html.hatena-module-custom-blogmura {
    margin-bottom: -60px !important;
}
.title-new .chappy {
    font-size: 24px;  /* フォントサイズを大きく */
    font-weight:1000; /* フォントを太く */
}
  /* 本文フォントサイズ */　
.entry-content {
    font-size: 17px !important;
}
/* 記事下シェアボタン */
.share {
    display: flex;
    align-items: center;
    height: 30px;
    margin-top: 30px;
}
.share a {
    margin: 0 0.5em 0 0;
    width: 30px;
    height: 30px;
    position: relative;
    display: flex;
    align-items: center;
    text-decoration: none;
    justify-content: center;
}
.share i {
    font-size: 21px;
}
.share i.fa-brands.fa-x-twitter {
    color: #000000;
}
.share i.fa-brands.fa-line {
    color: #00B900;
}
.share i.fa-brands.fa-facebook {
    color: #1877F2;
}
.share i.blogicon-bookmark {
    color: #01A5DF;
    font-size: 25px;
    margin-bottom: 2px;
}
/* アーカイブページカード型 */
@media screen and (min-width: 640px) {
.page-archive .archive-entries {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    width: 100%;
}
.page-archive section.archive-entry.test-archive-entry.autopagerize_page_element {
    display: flex;
    flex-direction: column-reverse;
    position: relative;
    width: 28%;
    margin: 0 2.6% 10px 2.6%;
}
.page-archive .archive-entry-header {
    width: 100%;
}
.page-archive a.entry-thumb-link {
    width: 100%;
}
.page-archive .archive-entry-body {
    display: none;
}
.page-archive .date.archive-date {
    display: none;
}
.page-archive .archive-entries .categories {
    position: absolute;
    top: 0;
    left: 0;
}
.page-archive .categories a {
    color: #fff;
    background: #b3b1b1;
    text-decoration: none;
    font-size: 0.6rem;
    padding: 0.4em;
    display: inline;
    margin: 0;
}
.page-archive .categories a:before {
display: none;
}
.page-archive .archive-entries .entry-description {
display:none;
}
.page-archive .entry-thumb {
    width: 100%;
    aspect-ratio: 5 / 3;
    height:auto;
    }
.page-archive h1.entry-title {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    height: 4em;
    font-size: 110%!important;
}}
@media screen and (max-width: 640px) {
.page-archive section.archive-entry.test-archive-entry.autopagerize_page_element {
    display: flex;
    flex-direction: row-reverse;
    position: relative;
}
.page-archive .archive-entry-header {
    width: 55%;
}
.page-archive a.entry-thumb-link {
    width: 45%;
    margin-right: 20px;
}
.page-archive .archive-entry-body {
    position: absolute;
    bottom: 0;
}
.page-archive .archive-entries .categories {
    position: absolute;
    bottom: 2em;
}
.page-archive .archive-entries .entry-description {
display:none;
}
.page-archive .entry-thumb {
    width: 100%;
    aspect-ratio: 5 / 3;
    height:auto;
    }
.page-archive h1.entry-title {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}
}
.entry-content h4 {
font-size: 20px;
}
.entry-content p {
    font-size: 16px;
}
.entry-footer-author {
  display: none;
}
/* 記事ページ　記事タイトル */
/* pc */
@media screen and (min-width: 640px) {
    .entry .entry-title {
        font-size: 30px;
        line-height: 1em;
    }}
/* スマホ */
@media screen and (max-width: 640px) {
    .entry .entry-title {
        font-size: 30px;
        line-height: 1em;
        letter-spacing: 1px;
    }}
@media screen and (min-width: 1138px) {
    #main {
        width: 93.75%;
        margin-left: auto;
        margin-right: auto;
        float: none;
    }
}
.profile p strong {
    font-size: 1.1em; /* プロフィール文字のサイズに変更 */
}
.entry-footer-section {
    display: none;
}
.hatena-module.hatena-module-html.hatena-module-custom-share {
    margin-bottom: 10px;
}
#top-editarea{
margin-bottom: 0 !important;
}
#content{
margin-top: 0;
}
.hatena-module-custom-top{
padding-top: 0;
padding-top: 0 !important;
}
#box2{
margin-top: 0;
}
.pager{
    .pager-prev + .pager-prev{
        display: none;
    }
}
@media screen and (max-width: 640px) {
    .pager-prev.pager-prev.pager-prev {
        float: none;
        text-align: center;
    }
}
@media screen and (max-width: 640px) {
    .pager-prev a {
        text-decoration: none;
        padding: 14px 0;
        width: 240px; /* カプセル型にする */
        display: block;
        margin: 40px auto;
        border-radius: 100px; /* 丸くする */
        border: 1px solid #d1d1d1;
        background: transparent; /* 白（透明）にする */
        color: #1a1a1a;
        font-size: 11px;
        font-weight: 700;
        letter-spacing: 0.2em;
        text-align: center;
    }
}
@media screen and (max-width: 640px) {
    .pager:has(.pager-prev):has(.pager-next){
        :is(.pager-prev, .pager-next){
            width: fit-content;
            a{
                padding: 10px 20px;
            }
        }
        .pager-next{
            float: right;
        }
        .pager-prev{
            float: left;
        }
    }
}
.badge-type-pro {
    display: none;
}
@media screen and (max-width: 767px) {
    .badge-type-pro {
        display: none;
    }
}
.profile-name, .hatena-module-profile .profile-name a {
    font-weight: bold;
}
@media screen and (max-width: 767px) {
    .profile-name, .hatena-module-profile .profile-name a {
        font-weight: bold;
    }
}
@media screen and (min-width: 640px) {
    .page-archive h1.entry-title {
        -webkit-box-orient: unset;
        margin-bottom:2.5rem !important;
        height:unset;
    }
}
@media screen and (min-width: 640px) {
    .page-archive .archive-entries {
        align-items: flex-start;
    }
}
@media screen and (max-width: 640px) {
    .page-archive h1.entry-title {
        -webkit-box-orient: unset;
    }
}
.hatena-module-custom-pickup{
opacity:1 !important;
}
.hatena-module-custom-pickup a.urllist-title-link.entries-access-ranking-title-link.urllist-title.entries-access-ranking-title {
background:none;
}
.hatena-module-custom-pickup li.urllist-item.entries-access-ranking-item{
background:#333;
img{
opacity:0.65;
}
}
.urllist-category-link:not(:first-of-type) {
  display: none;
}
.top-banner-wrapper{
width:100%;
margin-top:0px;
display:flex;
justify-content:space-between;
align-items:center;
.top-banner{
width:100%;
img{
width:100%;
height:auto;
}
}
}
.hatena-module-custom-latest{
padding-top:0px;
}
.hatena-module:has(.top-banner-wrapper){
margin-bottom:0px;
}
.entries-access-ranking-item::before{
z-index:100 !important;
}
.entries-access-ranking{
opacity:0;
animation:showDelay 100ms 2000ms forwards;
}
@keyframes showDelay{
0%{
opacity:0;
}
100%{
opacity:1;
}
}
@media screen and (max-width: 640px) {
    .hatena-module-custom-latest {
        padding: 0px 10px 30px 10px !important;
    }
}
/* 個別記事のタイトルサイズだけを変更 */
.page-entry .entry-title {
    font-size: 36px !important;
}
/* ヘッダー翻訳：背景透明・白文字・ミニマルスタイル */
.header-translate-minimal {
    display: flex;
    align-items: center;
    padding: 10px 10px;
    transform: scale(0.85); /* 全体を少し小ぶりに */
    vertical-align: middle;
    margin-inline: auto 0;
    width: fit-content;
    gap:10px;
    span{
        color: rgb(143, 143, 143);
    }
}
/* 各言語のリンク */
.header-translate-minimal a {
    color: #222;
    text-decoration: none !important;
    font-size: 14px !important;
    font-weight: 500;
    transition: opacity 0.2s;
    padding: 0 4px;
}
/* 仕切り線（少し透過させた白） */
.header-translate-minimal .divider {
    color: rgba(255, 255, 255, 0.4) !important; 
    font-size: 12px;
    margin: 0 2px;
}
/* ホバーした時に少し薄くして反応を示す */
.header-translate-minimal a:hover {
    opacity: 0.7;
}
/* ===== 記事一覧 全体調整（スマホ） ===== */
@media screen and (max-width: 768px) {
/* ② タイトルを小さく・読みやすく */
.entry-title {
font-size: 10px;
line-height: 1.4;
font-weight: 500;
letter-spacing: 0.02em;
/* ⑤ フォントをiOS寄りに */
font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", sans-serif;
/* ③ 日付を小さく・控えめに */
.entry-date {
font-size: 12px;
color: #999;
}
/* ⑥ 画像を主役に（余白調整） */
.entry-thumb {
margin-bottom: 8px;
}
}

.title-new { ... font-family: -apple-system, BlinkMacSystemFont... ; } .title-new a.chappy { font-weight: 700; }
　　/* <system section="theme" selected="8599973812270629022"> */
@charset "utf-8";
@import url("//maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css");
/*
Theme: Minimalism
Author: Codomisu
Description:
最小限のデザインで最大限の「美」を引き出す


※未だにコードを整理していない　2018/09/09

Licensed under the MIT license.
*/
/*  import normalize */
/*! normalize.css v3.0.1 | MIT License | git.io/normalize */
/**
* 1. Set default font family to sans-serif.
* 2. Prevent iOS text size adjust after orientation change, without disabling
*    user zoom.
*/

/* Responsive:yes */

html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}
/**
* Remove default margin.
*/
body {
  margin: 0;
}
/* HTML5 display definitions
========================================================================== */
/**
* Correct `block` display not defined for any HTML5 element in IE 8/9.
* Correct `block` display not defined for `details` or `summary` in IE 10/11 and Firefox.
* Correct `block` display not defined for `main` in IE 11.
*/
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
  display: block;
}
/**
* 1. Correct `inline-block` display not defined in IE 8/9.
* 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
*/
audio,
canvas,
progress,
video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}
/**
* Prevent modern browsers from displaying `audio` without controls.
* Remove excess height in iOS 5 devices.
*/
audio:not([controls]) {
  display: none;
  height: 0;
}
/**
* Address `[hidden]` styling not present in IE 8/9/10.
* Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
*/
[hidden],
template {
  display: none;
}
/* Links
========================================================================== */
/**
* Remove the gray background color from active links in IE 10.
*/
a {
  background: transparent;
}
/**
* Improve readability when focused and also mouse hovered in all browsers.
*/
a:active,
a:hover {
  outline: 0;
}
/* Text-level semantics
========================================================================== */
/**
* Address styling not present in IE 8/9/10/11, Safari, and Chrome.
*/
abbr[title] {
  border-bottom: 1px dotted;
}
/**
* Address style set to `600er` in Firefox 4+, Safari, and Chrome.
*/
b,
strong {
  font-weight: 600;
}
/**
* Address styling not present in Safari and Chrome.
*/
dfn {
  font-style: italic;
}
/**
* Address variable `h1` font-size and margin within `section` and `article`
* contexts in Firefox 4+, Safari, and Chrome.
*/
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
/**
* Address styling not present in IE 8/9.
*/
mark {
  background: #ff0;
  color: #000;
}
/**
* Address inconsistent and variable font size in all browsers.
*/
small {
  font-size: 80%;
}
/**
* Prevent `sub` and `sup` affecting `line-height` in all browsers.
*/
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sup {
  top: -0.5em;
}
sub {
  bottom: -0.25em;
}
/* Embedded content
========================================================================== */
/**
* Remove border when inside `a` element in IE 8/9/10.
*/
img {
  border: 0;
}
/**
* Correct overflow not hidden in IE 9/10/11.
*/
svg:not(:root) {
  overflow: hidden;
}
/* Grouping content
========================================================================== */
/**
* Address margin not present in IE 8/9 and Safari.
*/
figure {
  margin: 1em 40px;
}
/**
* Address differences between Firefox and other browsers.
*/
hr {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  height: 0;
}
/**
* Contain overflow in all browsers.
*/
pre {
  overflow: auto;
}
/**
* Address odd `em`-unit font size rendering in all browsers.
*/
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}
/* Forms
========================================================================== */
/**
* Known limitation: by default, Chrome and Safari on OS X allow very limited
* styling of `select`, unless a `border` property is set.
*/
/**
* 1. Correct color not being inherited.
*    Known issue: affects color of disabled elements.
* 2. Correct font properties not being inherited.
* 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
*/
button,
input,
optgroup,
select,
textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */
}
/**
* Address `overflow` set to `hidden` in IE 8/9/10/11.
*/
button {
  overflow: visible;
}
/**
* Address inconsistent `text-transform` inheritance for `button` and `select`.
* All other form control elements do not inherit `text-transform` values.
* Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
* Correct `select` style inheritance in Firefox.
*/
button,
select {
  text-transform: none;
}
/**
* 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
*    and `video` controls.
* 2. Correct inability to style clickable `input` types in iOS.
* 3. Improve usability and consistency of cursor style between image-type
*    `input` and others.
*/
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
}
/**
* Re-set default cursor for disabled elements.
*/
button[disabled],
html input[disabled] {
  cursor: default;
}
/**
* Remove inner padding and border in Firefox 4+.
*/
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}
/**
* Address Firefox 4+ setting `line-height` on `input` using `` in
* the UA stylesheet.
*/
input {
  line-height: normal;
}
/**
* It's recommended that you don't attempt to style these elements.
* Firefox's implementation doesn't respect box-sizing, padding, or width.
*
* 1. Address box sizing set to `content-box` in IE 8/9/10.
* 2. Remove excess padding in IE 8/9/10.
*/
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
* Fix the cursor style for Chrome's increment/decrement buttons. For certain
* `font-size` values of the `input`, it causes the cursor style of the
* decrement button to change from `default` to `text`.
*/
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
/**
* 1. Address `appearance` set to `searchfield` in Safari and Chrome.
* 2. Address `box-sizing` set to `border-box` in Safari and Chrome
*    (include `-moz` to future-proof).
*/
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  /* 2 */
  box-sizing: content-box;
}
/**
* Remove inner padding and search cancel button in Safari and Chrome on OS X.
* Safari (but not Chrome) clips the cancel button when the search input has
* padding (and `textfield` appearance).
*/
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
/**
* Define consistent border, margin, and padding.
*/
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}
/**
* 1. Correct `color` not being inherited in IE 8/9/10/11.
* 2. Remove padding so people aren't caught out if they zero out fieldsets.
*/
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
* Remove default vertical scrollbar in IE 8/9/10/11.
*/
textarea {
  overflow: auto;
}
/**
* Don't inherit the `font-weight` (applied by a rule above).
* NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
*/
optgroup {
  font-weight: 600;
}
/* Tables
========================================================================== */
/**
* Remove most spacing between table cells.
*/
table {
  border-collapse: collapse;
  border-spacing: 0;
}
td,
th {
  padding: 0;
}
/*  import mixin */
.clearfix {
  display: block;
  *zoom: 1;
}
.clearfix:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
.inline-block {
  display: inline-block;
  *display: inline;
  *zoom: 1;
}
.ellipsis {
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
/*  import variable */
/* Common */
html,
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック  Medium', meiryo, sans-serif;
  color: #3f3f3f;
  background-color: #ffffff;
}
a {
  color: #1487bd;
}
a:visited {
  color: #789dae;
}
a:hover {
  color: #0f5373;
}
h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a,
h1 a:hover,
h2 a:hover,
h3 a:hover,
h4 a:hover,
h5 a:hover,
h6 a:hover,
h1 a:visited,
h2 a:visited,
h3 a:visited,
h4 a:visited,
h5 a:visited,
h6 a:visited {
  color: #333333;
  text-decoration: none;
}
a.keyword {
  text-decoration: none;
  border-bottom: 1px dotted #ECEEF1;
  color: #3f3f3f;
}
/* Buttons */
.btn {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #3f3f3f;
  background-color: #ffffff;
  text-align: center;
  vertical-align: middle;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 2px;
  background-clip: padding-box;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none ;
}
.btn:hover {
  background-color: #f5f5f5;
  text-decoration: none ;
}
.btn-small {
  padding: 2px 10px ;
  font-size: 11px ;
}
.btn-large {
  padding: 13px 19px;
  font-size: 17px;
  line-height: normal;
  font-weight: 600;
}
/* ヘッダ（グローバルヘッダ）
グローバルヘッダの中はiframeですが、
#globalheader-container に背景色や文字色を指定することでiframeの中にも色が反映されます。
*/
#globalheader-container {
  background-color: #333;
  color: #fff;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
}
/* container */
#container {
  width: 1140px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 0;
  padding-top: 37px;
}
#container #content {
  display: block;
  *zoom: 1;
}
#container #content:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
.globalheader-off #container {
  padding-top: 0;
}
/* 2カラムレイアウト */
#main {
  width: 640px;
  float: left;
}
#box2 {
  width: 290px;
  float: right;
}
/* 1カラムにしたい場合は下記のコメントアウトを外してください ----

#main {
width: 100%;
float: none;
}

#box2 {
width: 100%;
float: none;
}

#box2-inner {
width: 960px;
.clearfix;
overflow: hidden;
}

.hatena-module {
text-align: left;
padding-right: 20px;
width: 300px;
float: left;

&:nth-child(3n+1) {
clear: both;
}
}

---- END 1カラム */
/* header */
#blog-title {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  text-align: center;
  margin: 0;
  padding: 50px 0;
}
#title {
  margin: 0;
}
#title a {
  color: #3f3f3f;
}
#blog-description {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  font-weight: normal;
  font-size: 80%;
  margin: 5px 0 0 0;
}
/* ヘッダ画像を設定したとき */
.header-image-enable #title {
  padding-top: 70px;
}
.header-image-enable #title,
.header-image-enable #blog-description {
  padding-left: 20px;
}
/* パンくず（カテゴリーページで表示されます） */
#top-box {
  margin: 10px auto 20px;
  font-size: 90%;
}
#top-box .breadcrumb {
  border-top: 1px solid #ECEEF1;
  border-bottom: 1px solid #ECEEF1;
  padding: 10px;
}
/* entry */
.entry {
  position: relative;
  margin-bottom: 50px;
}
.entry-header {
  padding: 15px 0;
  margin-bottom: 20px;
  border-bottom: 1px solid #ECEEF1;
  position: relative;
}
.entry-title {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  font-size: 21px;
  font-weight: 600;
  line-height: 35px;
  margin: 15px 0 20px;
}
/* 日付 */
.date {
  font-weight: 600;
  margin-bottom: 15px;
}
.date a {
  color: #1487bd;
  text-decoration: none;
  font-size: 90%;
}
/* カテゴリ */
.categories {
  margin-top: 10px;
  font-size: 80%;
}
.categories a {
  color: #3f3f3f;
}
.categories.no-categories {
  margin: 0;
}
/* 「編集する」ボタン */
.entry-header-menu {
  position: absolute;
  bottom: 0px;
  left: -60px;
}
.entry-header-menu a {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #3f3f3f;
  background-color: #ffffff;
  text-align: center;
  vertical-align: middle;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 2px;
  background-clip: padding-box;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none ;
}
.entry-header-menu a:hover {
  background-color: #f5f5f5;
  text-decoration: none ;
}
/* entry-content の中の書式 */
.entry-content {
  font-size: 15px;
  line-height: 34px;
  padding-bottom: 10px;
  border-bottom: 1px solid #ECEEF1;
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
}
.entry-content p {
  margin: 0 0 1em 0;
}
.entry-content img {
  max-width: 100%;
}
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
  margin: 1.3em 0 0.8em 0;
  line-height: 1.5;
}
.entry-content h1 {
  font-size: 160%;
}
.entry-content h2 {
  font-size: 150%;
}
.entry-content h3 {
  font-size: 140%;
}
.entry-content h4 {
  font-size: 130%;
}
.entry-content h5 {
  font-size: 110%;
}
.entry-content h6 {
  font-size: 100%;
}
.entry-content table {
  border-collapse: collapse;
  border-spacing: 0;
  margin-bottom: 1em;
}
.entry-content table img {
  max-width: none;
}
.entry-content table th,
.entry-content table td {
  border: 1px solid #ddd;
  padding: 5px 10px;
}
.entry-content table th {
  background: #f5f5f5;
}
.entry-content blockquote {
  border: 1px solid #ECEEF1;
  margin: 0 0 10px;
  padding: 20px;
}
.entry-content blockquote p {
  margin-top: 0;
  margin-bottom: 0;
}
.entry-content pre {
  border: 1px solid #ECEEF1;
  margin: 0 0 10px;
  padding: 20px;
  white-space: pre;
}
.entry-content pre > code {
  margin: 0;
  padding: 0;
  white-space: pre;
  border: 0;
  background: transparent;
  font-family: 'Monaco', 'Consolas', 'Courier New', Courier, monospace, sans-serif;
}
.entry-content code {
  font-size: 90%;
  margin: 0 2px;
  padding: 0 5px;
  border: 1px solid #eaeaea;
  background-color: #f8f8f8;
  border-radius: 3px;
  font-family: 'Monaco', 'Consolas', 'Courier New', Courier, monospace, sans-serif;
}
.entry-content .hatena-asin-detail li {
  line-height: 1.4;
}
/* entry-footer */
.entry-footer {
  margin-top: 10px;
}
.entry-footer-section {
  font-size: 80%;
  color: #999999;
}
.entry-footer-section a {
  color: #999999;
}
.social-buttons,
.entry-footer-html {
  margin: 10px 0;
}
/* コメント */
.comment-box ul {
  list-style: none;
  margin: 0 0 15px 0;
  padding: 0;
  font-size: 95%;
  line-height: 1.7;
}
.comment-box li {
  padding: 10px 0 10px 60px;
  border-bottom: 1px solid #ECEEF1;
  position: relative;
}
.comment-box li:first-child {
  border-top: 1px solid #ECEEF1;
}
.comment-box .read-more-comments {
  padding-left: 0;
}
.comment-box .hatena-id-icon {
  position: absolute;
  top: 10px;
  left: 0;
  width: 50px ;
  height: 50px ;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 3px;
  background-clip: padding-box;
}
.comment-user-name {
  margin: 0 0 10px 0;
  font-weight: 600;
}
.comment-content {
  font-size: 90%;
  margin: 0 0 10px 0;
  word-wrap: break-word;
}
.comment-content p {
  margin: 0 0 10px 0;
}
.comment-metadata {
  font-size: 80%;
  color: #999999;
  margin: 0;
}
.comment-metadata a {
  color: #999999;
}
.leave-comment-title {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #3f3f3f;
  background-color: #ffffff;
  text-align: center;
  vertical-align: middle;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 2px;
  background-clip: padding-box;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none ;
}
.leave-comment-title:hover {
  background-color: #f5f5f5;
  text-decoration: none ;
}
/* sidebar */
#box2 {
  font-size: 85%;
  line-height: 1.5;
}
.hatena-module {
  margin-bottom: 60px;
}
.hatena-module-title {
  font-weight: 600;
  margin-bottom: 15px;
  font-size: 120%;
  padding:0 0 5px 5px;
  border-bottom: 1px solid #ECEEF1;
}
.hatena-module-title a {
  color: #3f3f3f;
  text-decoration: none;
}
.hatena-module-title a:hover {
  text-decoration: underline;
}
/* Profile module */
.hatena-module-profile .profile-icon {
  float: left;
  margin: 0 10px 10px 0;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 5px;
  background-clip: padding-box;
}
.hatena-module-profile .id {
  display: block;
  font-weight: 600;
  font-size: 110%;
  margin-bottom: 5px;
}
.hatena-module-profile .profile-description {
  font-size: 90%;
}
.hatena-module-profile .profile-description p {
  margin-top: 0;
}
/* urllist module
リンク・最新記事・最近のコメント・月別アーカイブ・カテゴリモジュールは .hatena-urllist という共通の class が振られます
*/
.hatena-urllist {
  list-style: none;
  margin: 0 0 0 0;
  padding: 0 0 0 0;
}
.hatena-urllist li {
  padding: 8px 0;
  border-bottom: 1px solid #ECEEF1;
  line-height: 1.5;
}
.hatena-urllist li a {
  text-decoration: none;
}
/* Search module */
.hatena-module-search-box .search-form {
  border: 1px solid #ECEEF1;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 3px;
  background-clip: padding-box;
  width: 100%;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
}
.hatena-module-search-box .search-module-input {
  padding: 10px 10px;
  color: #3f3f3f;
  background: none;
  border: none;
  outline: none;
  height: 20px;
  width: 90%;
}
.hatena-module-search-box .search-module-button {
  width: 35px;
  height: 35px;
  background: transparent url(https://cdn.blog.st-hatena.com/images/theme/search.png?version=17d66ae0e3fc0e087ead6e3d21294b) no-repeat right center;
  border: none;
  outline: none;
  text-indent: -9999px;
  position: absolute;
  top: 1px;
  right: 10px;
  opacity: 0.5;
}
.hatena-module-search-box .search-module-button:hover {
  opacity: 0.85;
}
/* Pager */
.pager {
  margin: 1em 0;
  display: block;
  *zoom: 1;
}
.pager:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
.pager .pager-prev {
  float: left;
  text-align: left;
  width: 45%;
}
.pager .pager-next {
  float: right;
  text-align: right;
  width: 45%;
}
/* Footer */
#footer {
  padding: 30px 0;
  text-align: center;
  color: #999999;
  line-height: 1.5;
  font-size: 80%;
}
#footer p {
  margin: 0;
}
#footer a {
  color: #999999;
}
/* About ページ */
.page-about dt {
  font-size: 16px;
  font-weight: 600;
  border-bottom: 1px solid #dfdfdf;
  margin-bottom: 5px;
}
.page-about dd {
  margin-left: 0;
  margin-bottom: 30px;
}
/* archive ページ */
.page-archive .archive-entries .archive-entry {
  margin-bottom: 3em;
}
.page-archive .archive-entries .entry-title {
  font-size: 130%;
  margin: 0 0 .5em;
}
.page-archive .archive-entries .categories {
  margin: 0 0 .5em;
}
.page-archive .archive-entries .entry-description {
  margin: 0 0 1em;
  font-size: 13px;
  line-height: 25px;
}
.page-archive .categories a {
  color: #3f3f3f;
  text-decoration: none;
  display: inline-block;
  *display: inline;
  *zoom: 1;
  margin-bottom:5px;
}

.shrbtn{
  padding:0;
  margin:15px 0;
  width: 100%;
  background:#ECEEF1;
  text-align:center;
  display: inline-flex;
}

.share_btn{
  display: inline-block;
  width: calc(100% / 5);
  margin:4px 6px;
  height: 40px;
  line-height: 40px;
  font-size: 18px;
  color:#3f3f3f;
  border:1px solid #ECEEF1;
  border-radius:0;
  text-align: center;
  vertical-align: middle;
  overflow: hidden;
  font-weight: 600;
  transition: .3s;
  background:#fafafa;
}

.share_btn:first-of-type{
  margin-left:0;
}

.share_btn:last-of-type{
  margin-right:0;
}

.share_btn:hover{
  color:#3f3f3f;
}

.share_btn .fa {line-height:40px}


/* ### スライドメニュー ### */
#gnav {
  border-top: 1px solid #ECEEF1;
  border-bottom: 1px solid #ECEEF1;
  margin: 0 0 10px;
  background: #ffffff;
  font-size: 0;
  padding: 0 0 0;
}

#gnav .menu a {
  display: block;
  color: #3f3f3f;
  font-size: 13px;
  font-weight: 500;
  text-decoration:none;
  text-align: center;
  overflow: hidden;
  box-sizing: border-box;

}


#gnav .gnav-inner {
  width: 100%;
  padding: 12px 20px;
  overflow-x: auto;
  overflow-y: hidden;
  box-sizing: border-box;
  text-align: center;
  white-space: nowrap;
  margin: 0 auto;
  -webkit-font-smoothing: antialiased;
  -webkit-overflow-scrolling: touch;
}

#gnav .menu {
  display: inline-block;
}

/* ### スライドメニューを横いっぱいに広げる ### */
#top-editarea .section {
  width: 100% ;
  margin-left: auto;
  margin-right: auto;

}

#top-editarea{
  margin-bottom: 15px;
}

.id a{
  color: #3f3f3f;
  text-decoration: none;
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
}


.hatena-module-profile .profile-description {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
}

.table-of-contents {
  position: relative;
  background-color: #fafafa;
  border:1px solid #ECEEF1;
  padding: 60px 70px 25px;
  border-radius: 0;
  font-size: 14px;
  line-height: 28px;
}


.table-of-contents::before {
  position: absolute;
  display: block;
  text-align: center;
  top: 15px;
  left: 50%;
  margin-left: -1em;
  font-size: 20px;
  font-weight: 700;
  content: '目次';
  z-index: 2;
}


.table-of-contents li a {
  text-decoration: none;
  line-height: 35px;
  color:#3f3f3f;
}

.archive-header-category{
  margin-bottom:25px;
}

.archive-heading{
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  border-bottom:1px solid #ECEEF1;
  font-weight: 600;
  font-size: 21px;
  line-height: 35px;
  padding-bottom:5px;
  margin-bottom:25px;
}

.footer{
  background:#3f3f3f;
  color:#fff;
  padding:30px 0;
}
.footer ul li{
  text-align:center;
  display: block;
}

.footer .footer-title{
  margin-bottom:10px;
}

.footer .footer-copyright{
  font-size:12px;
}

.footer-list{
  padding: 0;
}

.categories a{
  color: #3f3f3f;
  text-decoration: none;
  padding: 4px 0;
  border-radius: 0;
  font-size:13px;
  vertical-align: middle;
  margin-right: 10px;
}

.categories a:before{
  font-family: FontAwesome;
  content:"\f02b";
  font-size: 16px;
  vertical-align: middle;
  margin-right: 5px;
  color:#2f2f2f;
}

/*  import media queries */
/* Media Queries - Retina Display */
@media screen and (min-width: 1139px){

  #blog-title #title{
    font-size: 37px;
    line-height: 60px;
    font-weight:500;
  }

  .hatena-module-search-box .search-module-button {
    background: transparent url(https://cdn.blog.st-hatena.com/images/theme/search@2x.png?version=17d66ae0e3fc0e087ead6e3d21294b) no-repeat right center;
    background-size: 20px 20px;
  }
  #container {
    border-right: 1px solid #ECEEF1;
    border-left: 1px solid #ECEEF1;
  }
  #content{
    margin: 35px 55px;
  }
  .breadcrumb-inner{
    margin: 0 5%;
  }
  .date a {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 15px;
    padding: 1px;
  }
  .date {
    font-weight: 500;
    margin-bottom: 5px;
  }

  .date:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95%;
    top: 0;
    color: #3f3f3f;
  }

  .page-archive .entry-thumb {
    border-radius: 5px;
    margin-right: 20px;
  }

  #box2 .urllist-image {
    border-radius: 5px;
    margin-right: 15px;
  }

  .urllist-date-link time {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 14px;
    padding: 1px;
  }

  .urllist-date-link time:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95%
    top: 0;
    color: #3f3f3f;
  }


  .shrbtn{
    background:none;
  }

  #box2{
    margin-top: 15px;
  }

  .page-archive .archive-entries .entry-title {
    margin-top:10px;
    font-size: 19px;
  }

  .hatena-urllist li a {
    font-size: 13px;
    line-height: 25px;
    color:#3f3f3f;
  }
  #gnav .menu a {
    padding: 0 15px;
  }
}
/* Media Queries - Tablet */
@media screen and (max-width: 1138px){
  #gnav .menu{
    margin-right:20px;
  }
  #gnav .menu a{
    font-size: 12px;
  }
  #container {
    width: 100% ;
    word-wrap: break-word;
    overflow: hidden;
    padding-top: 0;
  }
  #main {
    width: 93.75% ;
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2 {
    width: 93.75% ;
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2-inner {
    width: 100% ;
  }
  .hatena-module {
    width: 100%;
    float: none;
  }
  .date a {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 15px;
    padding: 1px;
  }
  .date {
    font-weight: 500;
    margin-bottom: 5px;
  }

  .date:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 18px;
    top: 0;
    color: #3f3f3f;
  }

  .page-archive .entry-thumb {
    border-radius: 5px;
  }
  #box2 .urllist-image {
    border-radius: 5px;
  }

  .urllist-date-link time {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 14px ;
    padding: 1px;
  }

  .urllist-date-link time:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95% ;
    top: 0;
    color: #3f3f3f;
  }
  .shrbtn{
    background:none ;
  }
.
  .hatena-urllist li a {
    color:#3f3f3f;
  }
  .entry .entry-title{
    font-size: 22px;
  }
  .categories a{
    color: #3f3f3f;
    text-decoration: none;
    padding: 2px 7px;
    border-radius: 2px;
    margin: 0 2px;
  }
  .page-archive .archive-entries .entry-title {
    font-size: 18px;
  }

}
/* Media Queries - Small Tablet & Smartphone */
@media screen and (max-width:640px){
  #globalheader-container {
    position: static;
  }
  #blog-title #title{
    font-size: 30px;
    font-weight:500;
    font-family: 'Nunito', sans-serif;
  }
  #blog-description {
    font-size:11px;
  }
  #container {
    width: 100%;
    word-wrap: break-word;
    overflow: hidden;
    padding-top: 0;
  }
  #main {
    width: 93.75%;
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2 {
    width: 93.75%
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2-inner {
    width: 100%;
  }
  .hatena-module {
    width: 100%;
    float: none;
  }
  .entry-header-menu {
    top: -30px;
    left: 0px;
  }
  .archive-entry-header{
    width : -webkit-calc(100% -90px);
    width: calc(100% - 90px);
    float: right;
  }
  .page-archive .archive-entries .entry-title {
    font-size:14px;
    line-height: 25px;
    font-weight: 400;
    margin:0;
  }
  .archive-entries .entry-description{
    font-size:11px;
    display:none;
  }
  .page-archive .entry-thumb {
    width: 75px;
    height: 75px;
    border: 1px solid #ECEEF1;
    background-size: 100%;
    float:left;
    border-radius: 3px;
  }

  .page-archive .categories{
    display: none;
  }

  .page-archive .archive-entries .archive-entry {
    margin-bottom: 0;
    padding: 17px 0;
    border-bottom: 1px solid #ECEEF1;
}
  .date a {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 12px;
    padding: 1px;
  }
  .date {
    font-weight: 500;
    margin-bottom: 5px;
  }

  .date:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95%;
    top: 0;
    color: #3f3f3f;
  }

  .page-archive .social-buttons{
    display: none;
  }

  #blog-title {
    text-align: center;
    padding: 35px 0 35px;
    margin:0;
  }

  .entry .entry-title{
    font-size: 18px;
    line-height: 30px;
    margin: 10px 0 15px;
    font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  }

  .entry .entry-header{
    padding: 10px 0 10px 0;
    border:none;
  }

  .table-of-contents {
    position: relative;
    background-color: #fafafa;
    border:1px solid #ECEEF1;
    padding: 60px 45px 25px;
    border-radius: 0;
    font-size: 14px;
    line-height: 28px;
  }

  #box2 .urllist-image {
    max-width: 100%;
    width: 75px;
    border-radius: 5px;
    margin-right: 10px;
    border: 1px solid #ECEEF1;
    height: 75px;
  }
  .hatena-urllist li{
    padding: 10px 0 0px;
  }

  .hatena-urllist li a {
    font-size: 13px ;
    line-height: 20px;
    font-weight: 500;
    color: #3f3f3f;
    text-decoration: none;
  }

  .archive-module-year{
    border:none ;
  }

  .urllist-date-link time {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 12px ;
    padding: 1px;
  }

  .urllist-date-link time:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95% ;
    top: 0;
    color: #3f3f3f;
  }
  .archive-entries{
    margin:0 0 40px;
  }

  .id a{
    font-weight: normal;
    text-decoration: none;
    color: #3f3f3f;
  }

  .entry-content {
    font-size: 14px;
  }
  .hatena-module {
    margin-bottom: 40px;
  }
  .urllist-image{
    width: 70px;
    border-radius: 5px;
  }
  .related-entries .related-entries-entry-body{
    display: none;
  }
  .pager{
    text-align: center;
    margin-bottom: 45px;
  }
  :not(.permalink)>.pager-next{
    float:none ;
    text-align: center ;
  }
  :not(.permalink)>.pager-next a{
    text-decoration: none;
    padding: 10px 100px;
    border-radius: 4px;
    border: 1px solid #ECEEF1;
    background: #fafafa;
    color: #3f3f3f;
  }
  .pager-permalink{
    display:none;
  }
}
/* Media Queries - Smartphone */

/* </system> */
/* <system section="background" selected="fff"> */
body{background:#fff;}
/* </system> */
.hatena-module-custom-pickup {
  display:none;
}
header#blog-title {
    display: none;
}
@media screen and (min-width: 992px) {
#content-inner { 
max-width:4000px!important;
}}
@media screen and (min-width: 1139px) {
/* --- ナビ下の隙間をさらに追い込む修正 --- */
/* 1. ナビの外枠自体の余白を消す */
#custom-grid-nav {
    margin-bottom: 0px !important;
}
/* 2. ナビの下線を消してさらに詰めたい場合はここ（お好みで） */
.nav-categories {
    margin-bottom: 0px !important;
    border-bottom: none !important; /* 下線を消すとさらに数ピクセル詰まります */
}
/* 3. 画像が入っている箱（モジュール）の上の余白を強制排除 */
.hatena-module-custom-top, 
.hatena-module-custom-latest,
.hatena-module {
    margin-top: -10px !important; /* マイナス指定で上に引っ張り上げます */
    padding-top: 0px !important;
}
/* 4. カルーセル内のリスト自体の余白 */
.hatena-module-custom-top ul.recent-entries {
    margin-top: 0px !important;
}
/* --- 目次のおしゃれカスタマイズ --- */
/* --- 強力版：目次カスタマイズ --- */
/* .entry-content をつけることで優先順位を上げています */
.entry-content .table-of-contents {
    margin: 30px 0 !important;
    padding: 25px !important;
    background: #fdfdfd !important; /* ほぼ白に近いグレー */
    border: 1px solid #ddd !important;
    border-radius: 4px !important;
    list-style: none !important;
    display: inline-block; /* 中身の長さに合わせる */
    min-width: 300px;
}
/* タイトル部分 */
.entry-content .table-of-contents::before {
    content: "CONTENTS";
    display: block;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.1em;
    color: #333;
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 1px solid #333;
}
/* 箇条書きのドットを消す */
.entry-content .table-of-contents li {
    list-style-type: none !important;
    margin: 8px 0 !important;
}
/* リンクの見た目 */
.entry-content .table-of-contents li a {
    color: #666 !important;
    text-decoration: none !important;
    font-size: 14px;
}
.entry-content .table-of-contents li a:hover {
    color: #999 !important;
    text-decoration: underline !important;
}
/* 2階層目の字下げ */
.entry-content .table-of-contents li ul {
    margin-left: 1.5em !important;
}
* <system section="theme" selected="8599973812270629022"> */
@charset "utf-8";
@import url("//maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css");
/*
Theme: Minimalism
Author: Codomisu
Description:
最小限のデザインで最大限の「美」を引き出す


※未だにコードを整理していない　2018/09/09

Licensed under the MIT license.
*/
/*  import normalize */
/*! normalize.css v3.0.1 | MIT License | git.io/normalize */
/**
* 1. Set default font family to sans-serif.
* 2. Prevent iOS text size adjust after orientation change, without disabling
*    user zoom.
*/

/* Responsive:yes */

html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}
/**
* Remove default margin.
*/
body {
  margin: 0;
}
/* HTML5 display definitions
========================================================================== */
/**
* Correct `block` display not defined for any HTML5 element in IE 8/9.
* Correct `block` display not defined for `details` or `summary` in IE 10/11 and Firefox.
* Correct `block` display not defined for `main` in IE 11.
*/
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
  display: block;
}
/**
* 1. Correct `inline-block` display not defined in IE 8/9.
* 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
*/
audio,
canvas,
progress,
video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}
/**
* Prevent modern browsers from displaying `audio` without controls.
* Remove excess height in iOS 5 devices.
*/
audio:not([controls]) {
  display: none;
  height: 0;
}
/**
* Address `[hidden]` styling not present in IE 8/9/10.
* Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
*/
[hidden],
template {
  display: none;
}
/* Links
========================================================================== */
/**
* Remove the gray background color from active links in IE 10.
*/
a {
  background: transparent;
}
/**
* Improve readability when focused and also mouse hovered in all browsers.
*/
a:active,
a:hover {
  outline: 0;
}
/* Text-level semantics
========================================================================== */
/**
* Address styling not present in IE 8/9/10/11, Safari, and Chrome.
*/
abbr[title] {
  border-bottom: 1px dotted;
}
/**
* Address style set to `600er` in Firefox 4+, Safari, and Chrome.
*/
b,
strong {
  font-weight: 600;
}
/**
* Address styling not present in Safari and Chrome.
*/
dfn {
  font-style: italic;
}
/**
* Address variable `h1` font-size and margin within `section` and `article`
* contexts in Firefox 4+, Safari, and Chrome.
*/
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
/**
* Address styling not present in IE 8/9.
*/
mark {
  background: #ff0;
  color: #000;
}
/**
* Address inconsistent and variable font size in all browsers.
*/
small {
  font-size: 80%;
}
/**
* Prevent `sub` and `sup` affecting `line-height` in all browsers.
*/
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sup {
  top: -0.5em;
}
sub {
  bottom: -0.25em;
}
/* Embedded content
========================================================================== */
/**
* Remove border when inside `a` element in IE 8/9/10.
*/
img {
  border: 0;
}
/**
* Correct overflow not hidden in IE 9/10/11.
*/
svg:not(:root) {
  overflow: hidden;
}
/* Grouping content
========================================================================== */
/**
* Address margin not present in IE 8/9 and Safari.
*/
figure {
  margin: 1em 40px;
}
/**
* Address differences between Firefox and other browsers.
*/
hr {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  height: 0;
}
/**
* Contain overflow in all browsers.
*/
pre {
  overflow: auto;
}
/**
* Address odd `em`-unit font size rendering in all browsers.
*/
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}
/* Forms
========================================================================== */
/**
* Known limitation: by default, Chrome and Safari on OS X allow very limited
* styling of `select`, unless a `border` property is set.
*/
/**
* 1. Correct color not being inherited.
*    Known issue: affects color of disabled elements.
* 2. Correct font properties not being inherited.
* 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
*/
button,
input,
optgroup,
select,
textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */
}
/**
* Address `overflow` set to `hidden` in IE 8/9/10/11.
*/
button {
  overflow: visible;
}
/**
* Address inconsistent `text-transform` inheritance for `button` and `select`.
* All other form control elements do not inherit `text-transform` values.
* Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
* Correct `select` style inheritance in Firefox.
*/
button,
select {
  text-transform: none;
}
/**
* 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
*    and `video` controls.
* 2. Correct inability to style clickable `input` types in iOS.
* 3. Improve usability and consistency of cursor style between image-type
*    `input` and others.
*/
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
}
/**
* Re-set default cursor for disabled elements.
*/
button[disabled],
html input[disabled] {
  cursor: default;
}
/**
* Remove inner padding and border in Firefox 4+.
*/
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}
/**
* Address Firefox 4+ setting `line-height` on `input` using `` in
* the UA stylesheet.
*/
input {
  line-height: normal;
}
/**
* It's recommended that you don't attempt to style these elements.
* Firefox's implementation doesn't respect box-sizing, padding, or width.
*
* 1. Address box sizing set to `content-box` in IE 8/9/10.
* 2. Remove excess padding in IE 8/9/10.
*/
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
* Fix the cursor style for Chrome's increment/decrement buttons. For certain
* `font-size` values of the `input`, it causes the cursor style of the
* decrement button to change from `default` to `text`.
*/
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
/**
* 1. Address `appearance` set to `searchfield` in Safari and Chrome.
* 2. Address `box-sizing` set to `border-box` in Safari and Chrome
*    (include `-moz` to future-proof).
*/
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  /* 2 */
  box-sizing: content-box;
}
/**
* Remove inner padding and search cancel button in Safari and Chrome on OS X.
* Safari (but not Chrome) clips the cancel button when the search input has
* padding (and `textfield` appearance).
*/
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
/**
* Define consistent border, margin, and padding.
*/
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}
/**
* 1. Correct `color` not being inherited in IE 8/9/10/11.
* 2. Remove padding so people aren't caught out if they zero out fieldsets.
*/
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
* Remove default vertical scrollbar in IE 8/9/10/11.
*/
textarea {
  overflow: auto;
}
/**
* Don't inherit the `font-weight` (applied by a rule above).
* NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
*/
optgroup {
  font-weight: 600;
}
/* Tables
========================================================================== */
/**
* Remove most spacing between table cells.
*/
table {
  border-collapse: collapse;
  border-spacing: 0;
}
td,
th {
  padding: 0;
}
/*  import mixin */
.clearfix {
  display: block;
  *zoom: 1;
}
.clearfix:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
.inline-block {
  display: inline-block;
  *display: inline;
  *zoom: 1;
}
.ellipsis {
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
/*  import variable */
/* Common */
html,
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック  Medium', meiryo, sans-serif;
  color: #3f3f3f;
  background-color: #ffffff;
}
a {
  color: #1487bd;
}
a:visited {
  color: #789dae;
}
a:hover {
  color: #0f5373;
}
h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a,
h1 a:hover,
h2 a:hover,
h3 a:hover,
h4 a:hover,
h5 a:hover,
h6 a:hover,
h1 a:visited,
h2 a:visited,
h3 a:visited,
h4 a:visited,
h5 a:visited,
h6 a:visited {
  color: #333333;
  text-decoration: none;
}
a.keyword {
  text-decoration: none;
  border-bottom: 1px dotted #ECEEF1;
  color: #3f3f3f;
}
/* Buttons */
.btn {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #3f3f3f;
  background-color: #ffffff;
  text-align: center;
  vertical-align: middle;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 2px;
  background-clip: padding-box;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none ;
}
.btn:hover {
  background-color: #f5f5f5;
  text-decoration: none ;
}
.btn-small {
  padding: 2px 10px ;
  font-size: 11px ;
}
.btn-large {
  padding: 13px 19px;
  font-size: 17px;
  line-height: normal;
  font-weight: 600;
}
/* ヘッダ（グローバルヘッダ）
グローバルヘッダの中はiframeですが、
#globalheader-container に背景色や文字色を指定することでiframeの中にも色が反映されます。
*/
#globalheader-container {
  background-color: #333;
  color: #fff;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
}
/* container */
#container {
  width: 1140px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 0;
  padding-top: 37px;
}
#container #content {
  display: block;
  *zoom: 1;
}
#container #content:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
.globalheader-off #container {
  padding-top: 0;
}
/* 2カラムレイアウト */
#main {
  width: 640px;
  float: left;
}
#box2 {
  width: 290px;
  float: right;
}
/* 1カラムにしたい場合は下記のコメントアウトを外してください ----

#main {
width: 100%;
float: none;
}

#box2 {
width: 100%;
float: none;
}

#box2-inner {
width: 960px;
.clearfix;
overflow: hidden;
}

.hatena-module {
text-align: left;
padding-right: 20px;
width: 300px;
float: left;

&:nth-child(3n+1) {
clear: both;
}
}

---- END 1カラム */
/* header */
#blog-title {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  text-align: center;
  margin: 0;
  padding: 50px 0;
}
#title {
  margin: 0;
}
#title a {
  color: #3f3f3f;
}
#blog-description {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  font-weight: normal;
  font-size: 80%;
  margin: 5px 0 0 0;
}
/* ヘッダ画像を設定したとき */
.header-image-enable #title {
  padding-top: 70px;
}
.header-image-enable #title,
.header-image-enable #blog-description {
  padding-left: 20px;
}
/* パンくず（カテゴリーページで表示されます） */
#top-box {
  margin: 10px auto 20px;
  font-size: 90%;
}
#top-box .breadcrumb {
  border-top: 1px solid #ECEEF1;
  border-bottom: 1px solid #ECEEF1;
  padding: 10px;
}
/* entry */
.entry {
  position: relative;
  margin-bottom: 50px;
}
.entry-header {
  padding: 15px 0;
  margin-bottom: 20px;
  border-bottom: 1px solid #ECEEF1;
  position: relative;
}
.entry-title {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  font-size: 21px;
  font-weight: 600;
  line-height: 35px;
  margin: 15px 0 20px;
}
/* 日付 */
.date {
  font-weight: 600;
  margin-bottom: 15px;
}
.date a {
  color: #1487bd;
  text-decoration: none;
  font-size: 90%;
}
/* カテゴリ */
.categories {
  margin-top: 10px;
  font-size: 80%;
}
.categories a {
  color: #3f3f3f;
}
.categories.no-categories {
  margin: 0;
}
/* 「編集する」ボタン */
.entry-header-menu {
  position: absolute;
  bottom: 0px;
  left: -60px;
}
.entry-header-menu a {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #3f3f3f;
  background-color: #ffffff;
  text-align: center;
  vertical-align: middle;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 2px;
  background-clip: padding-box;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none ;
}
.entry-header-menu a:hover {
  background-color: #f5f5f5;
  text-decoration: none ;
}
/* entry-content の中の書式 */
.entry-content {
  font-size: 15px;
  line-height: 34px;
  padding-bottom: 10px;
  border-bottom: 1px solid #ECEEF1;
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
}
.entry-content p {
  margin: 0 0 1em 0;
}
.entry-content img {
  max-width: 100%;
}
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
  margin: 1.3em 0 0.8em 0;
  line-height: 1.5;
}
.entry-content h1 {
  font-size: 160%;
}
.entry-content h2 {
  font-size: 150%;
}
.entry-content h3 {
  font-size: 140%;
}
.entry-content h4 {
  font-size: 130%;
}
.entry-content h5 {
  font-size: 110%;
}
.entry-content h6 {
  font-size: 100%;
}
.entry-content table {
  border-collapse: collapse;
  border-spacing: 0;
  margin-bottom: 1em;
}
.entry-content table img {
  max-width: none;
}
.entry-content table th,
.entry-content table td {
  border: 1px solid #ddd;
  padding: 5px 10px;
}
.entry-content table th {
  background: #f5f5f5;
}
.entry-content blockquote {
  border: 1px solid #ECEEF1;
  margin: 0 0 10px;
  padding: 20px;
}
.entry-content blockquote p {
  margin-top: 0;
  margin-bottom: 0;
}
.entry-content pre {
  border: 1px solid #ECEEF1;
  margin: 0 0 10px;
  padding: 20px;
  white-space: pre;
}
.entry-content pre > code {
  margin: 0;
  padding: 0;
  white-space: pre;
  border: 0;
  background: transparent;
  font-family: 'Monaco', 'Consolas', 'Courier New', Courier, monospace, sans-serif;
}
.entry-content code {
  font-size: 90%;
  margin: 0 2px;
  padding: 0 5px;
  border: 1px solid #eaeaea;
  background-color: #f8f8f8;
  border-radius: 3px;
  font-family: 'Monaco', 'Consolas', 'Courier New', Courier, monospace, sans-serif;
}
.entry-content .hatena-asin-detail li {
  line-height: 1.4;
}
/* entry-footer */
.entry-footer {
  margin-top: 10px;
}
.entry-footer-section {
  font-size: 80%;
  color: #999999;
}
.entry-footer-section a {
  color: #999999;
}
.social-buttons,
.entry-footer-html {
  margin: 10px 0;
}
/* コメント */
.comment-box ul {
  list-style: none;
  margin: 0 0 15px 0;
  padding: 0;
  font-size: 95%;
  line-height: 1.7;
}
.comment-box li {
  padding: 10px 0 10px 60px;
  border-bottom: 1px solid #ECEEF1;
  position: relative;
}
.comment-box li:first-child {
  border-top: 1px solid #ECEEF1;
}
.comment-box .read-more-comments {
  padding-left: 0;
}
.comment-box .hatena-id-icon {
  position: absolute;
  top: 10px;
  left: 0;
  width: 50px ;
  height: 50px ;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 3px;
  background-clip: padding-box;
}
.comment-user-name {
  margin: 0 0 10px 0;
  font-weight: 600;
}
.comment-content {
  font-size: 90%;
  margin: 0 0 10px 0;
  word-wrap: break-word;
}
.comment-content p {
  margin: 0 0 10px 0;
}
.comment-metadata {
  font-size: 80%;
  color: #999999;
  margin: 0;
}
.comment-metadata a {
  color: #999999;
}
.leave-comment-title {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #3f3f3f;
  background-color: #ffffff;
  text-align: center;
  vertical-align: middle;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 2px;
  background-clip: padding-box;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none ;
}
.leave-comment-title:hover {
  background-color: #f5f5f5;
  text-decoration: none ;
}
/* sidebar */
#box2 {
  font-size: 85%;
  line-height: 1.5;
}
.hatena-module {
  margin-bottom: 60px;
}
.hatena-module-title {
  font-weight: 600;
  margin-bottom: 15px;
  font-size: 120%;
  padding:0 0 5px 5px;
  border-bottom: 1px solid #ECEEF1;
}
.hatena-module-title a {
  color: #3f3f3f;
  text-decoration: none;
}
.hatena-module-title a:hover {
  text-decoration: underline;
}
/* Profile module */
.hatena-module-profile .profile-icon {
  float: left;
  margin: 0 10px 10px 0;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 5px;
  background-clip: padding-box;
}
.hatena-module-profile .id {
  display: block;
  font-weight: 600;
  font-size: 110%;
  margin-bottom: 5px;
}
.hatena-module-profile .profile-description {
  font-size: 90%;
}
.hatena-module-profile .profile-description p {
  margin-top: 0;
}
/* urllist module
リンク・最新記事・最近のコメント・月別アーカイブ・カテゴリモジュールは .hatena-urllist という共通の class が振られます
*/
.hatena-urllist {
  list-style: none;
  margin: 0 0 0 0;
  padding: 0 0 0 0;
}
.hatena-urllist li {
  padding: 8px 0;
  border-bottom: 1px solid #ECEEF1;
  line-height: 1.5;
}
.hatena-urllist li a {
  text-decoration: none;
}
/* Search module */
.hatena-module-search-box .search-form {
  border: 1px solid #ECEEF1;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 3px;
  background-clip: padding-box;
  width: 100%;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
}
.hatena-module-search-box .search-module-input {
  padding: 10px 10px;
  color: #3f3f3f;
  background: none;
  border: none;
  outline: none;
  height: 20px;
  width: 90%;
}
.hatena-module-search-box .search-module-button {
  width: 35px;
  height: 35px;
  background: transparent url(https://cdn.blog.st-hatena.com/images/theme/search.png?version=17d66ae0e3fc0e087ead6e3d21294b) no-repeat right center;
  border: none;
  outline: none;
  text-indent: -9999px;
  position: absolute;
  top: 1px;
  right: 10px;
  opacity: 0.5;
}
.hatena-module-search-box .search-module-button:hover {
  opacity: 0.85;
}
/* Pager */
.pager {
  margin: 1em 0;
  display: block;
  *zoom: 1;
}
.pager:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
.pager .pager-prev {
  float: left;
  text-align: left;
  width: 45%;
}
.pager .pager-next {
  float: right;
  text-align: right;
  width: 45%;
}
/* Footer */
#footer {
  padding: 30px 0;
  text-align: center;
  color: #999999;
  line-height: 1.5;
  font-size: 80%;
}
#footer p {
  margin: 0;
}
#footer a {
  color: #999999;
}
/* About ページ */
.page-about dt {
  font-size: 16px;
  font-weight: 600;
  border-bottom: 1px solid #dfdfdf;
  margin-bottom: 5px;
}
.page-about dd {
  margin-left: 0;
  margin-bottom: 30px;
}
/* archive ページ */
.page-archive .archive-entries .archive-entry {
  margin-bottom: 3em;
}
.page-archive .archive-entries .entry-title {
  font-size: 130%;
  margin: 0 0 .5em;
}
.page-archive .archive-entries .categories {
  margin: 0 0 .5em;
}
.page-archive .archive-entries .entry-description {
  margin: 0 0 1em;
  font-size: 13px;
  line-height: 25px;
}
.page-archive .categories a {
  color: #3f3f3f;
  text-decoration: none;
  display: inline-block;
  *display: inline;
  *zoom: 1;
  margin-bottom:5px;
}

.shrbtn{
  padding:0;
  margin:15px 0;
  width: 100%;
  background:#ECEEF1;
  text-align:center;
  display: inline-flex;
}

.share_btn{
  display: inline-block;
  width: calc(100% / 5);
  margin:4px 6px;
  height: 40px;
  line-height: 40px;
  font-size: 18px;
  color:#3f3f3f;
  border:1px solid #ECEEF1;
  border-radius:0;
  text-align: center;
  vertical-align: middle;
  overflow: hidden;
  font-weight: 600;
  transition: .3s;
  background:#fafafa;
}

.share_btn:first-of-type{
  margin-left:0;
}

.share_btn:last-of-type{
  margin-right:0;
}

.share_btn:hover{
  color:#3f3f3f;
}

.share_btn .fa {line-height:40px}


/* ### スライドメニュー ### */
#gnav {
  border-top: 1px solid #ECEEF1;
  border-bottom: 1px solid #ECEEF1;
  margin: 0 0 10px;
  background: #ffffff;
  font-size: 0;
  padding: 0 0 0;
}

#gnav .menu a {
  display: block;
  color: #3f3f3f;
  font-size: 13px;
  font-weight: 500;
  text-decoration:none;
  text-align: center;
  overflow: hidden;
  box-sizing: border-box;

}


#gnav .gnav-inner {
  width: 100%;
  padding: 12px 20px;
  overflow-x: auto;
  overflow-y: hidden;
  box-sizing: border-box;
  text-align: center;
  white-space: nowrap;
  margin: 0 auto;
  -webkit-font-smoothing: antialiased;
  -webkit-overflow-scrolling: touch;
}

#gnav .menu {
  display: inline-block;
}

/* ### スライドメニューを横いっぱいに広げる ### */
#top-editarea .section {
  width: 100% ;
  margin-left: auto;
  margin-right: auto;

}

#top-editarea{
  margin-bottom: 15px;
}

.id a{
  color: #3f3f3f;
  text-decoration: none;
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
}


.hatena-module-profile .profile-description {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
}

.table-of-contents {
  position: relative;
  background-color: #fafafa;
  border:1px solid #ECEEF1;
  padding: 60px 70px 25px;
  border-radius: 0;
  font-size: 14px;
  line-height: 28px;
}


.table-of-contents::before {
  position: absolute;
  display: block;
  text-align: center;
  top: 15px;
  left: 50%;
  margin-left: -1em;
  font-size: 20px;
  font-weight: 700;
  content: '目次';
  z-index: 2;
}


.table-of-contents li a {
  text-decoration: none;
  line-height: 35px;
  color:#3f3f3f;
}

.archive-header-category{
  margin-bottom:25px;
}

.archive-heading{
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  border-bottom:1px solid #ECEEF1;
  font-weight: 600;
  font-size: 21px;
  line-height: 35px;
  padding-bottom:5px;
  margin-bottom:25px;
}

.footer{
  background:#3f3f3f;
  color:#fff;
  padding:30px 0;
}
.footer ul li{
  text-align:center;
  display: block;
}

.footer .footer-title{
  margin-bottom:10px;
}

.footer .footer-copyright{
  font-size:12px;
}

.footer-list{
  padding: 0;
}

.categories a{
  color: #3f3f3f;
  text-decoration: none;
  padding: 4px 0;
  border-radius: 0;
  font-size:13px;
  vertical-align: middle;
  margin-right: 10px;
}

.categories a:before{
  font-family: FontAwesome;
  content:"\f02b";
  font-size: 16px;
  vertical-align: middle;
  margin-right: 5px;
  color:#2f2f2f;
}

/*  import media queries */
/* Media Queries - Retina Display */
@media screen and (min-width: 1139px){

  #blog-title #title{
    font-size: 37px;
    line-height: 60px;
    font-weight:500;
  }

  .hatena-module-search-box .search-module-button {
    background: transparent url(https://cdn.blog.st-hatena.com/images/theme/search@2x.png?version=17d66ae0e3fc0e087ead6e3d21294b) no-repeat right center;
    background-size: 20px 20px;
  }
  #container {
    border-right: 1px solid #ECEEF1;
    border-left: 1px solid #ECEEF1;
  }
  #content{
    margin: 35px 55px;
  }
  .breadcrumb-inner{
    margin: 0 5%;
  }
  .date a {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 15px;
    padding: 1px;
  }
  .date {
    font-weight: 500;
    margin-bottom: 5px;
  }

  .date:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95%;
    top: 0;
    color: #3f3f3f;
  }

  .page-archive .entry-thumb {
    border-radius: 5px;
    margin-right: 20px;
  }

  #box2 .urllist-image {
    border-radius: 5px;
    margin-right: 15px;
  }

  .urllist-date-link time {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 14px;
    padding: 1px;
  }

  .urllist-date-link time:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95%
    top: 0;
    color: #3f3f3f;
  }


  .shrbtn{
    background:none;
  }

  #box2{
    margin-top: 15px;
  }

  .page-archive .archive-entries .entry-title {
    margin-top:10px;
    font-size: 19px;
  }

  .hatena-urllist li a {
    font-size: 13px;
    line-height: 25px;
    color:#3f3f3f;
  }
  #gnav .menu a {
    padding: 0 15px;
  }
}
/* Media Queries - Tablet */
@media screen and (max-width: 1138px){
  #gnav .menu{
    margin-right:20px;
  }
  #gnav .menu a{
    font-size: 12px;
  }
  #container {
    width: 100% ;
    word-wrap: break-word;
    overflow: hidden;
    padding-top: 0;
  }
  #main {
    width: 93.75% ;
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2 {
    width: 93.75% ;
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2-inner {
    width: 100% ;
  }
  .hatena-module {
    width: 100%;
    float: none;
  }
  .date a {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 15px;
    padding: 1px;
  }
  .date {
    font-weight: 500;
    margin-bottom: 5px;
  }

  .date:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 18px;
    top: 0;
    color: #3f3f3f;
  }

  .page-archive .entry-thumb {
    border-radius: 5px;
  }
  #box2 .urllist-image {
    border-radius: 5px;
  }

  .urllist-date-link time {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 14px ;
    padding: 1px;
  }

  .urllist-date-link time:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95% ;
    top: 0;
    color: #3f3f3f;
  }
  .shrbtn{
    background:none ;
  }
.
  .hatena-urllist li a {
    color:#3f3f3f;
  }
  .entry .entry-title{
    font-size: 22px;
  }
  .categories a{
    color: #3f3f3f;
    text-decoration: none;
    padding: 2px 7px;
    border-radius: 2px;
    margin: 0 2px;
  }
  .page-archive .archive-entries .entry-title {
    font-size: 18px;
  }

}
/* Media Queries - Small Tablet & Smartphone */
@media screen and (max-width:640px){
  #globalheader-container {
    position: static;
  }
  #blog-title #title{
    font-size: 30px;
    font-weight:500;
    font-family: 'Nunito', sans-serif;
  }
  #blog-description {
    font-size:11px;
  }
  #container {
    width: 100%;
    word-wrap: break-word;
    overflow: hidden;
    padding-top: 0;
  }
  #main {
    width: 93.75%;
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2 {
    width: 93.75%
    margin-left: auto;
    margin-right: auto;
    float: none;
  }
  #box2-inner {
    width: 100%;
  }
  .hatena-module {
    width: 100%;
    float: none;
  }
  .entry-header-menu {
    top: -30px;
    left: 0px;
  }
  .archive-entry-header{
    width : -webkit-calc(100% -90px);
    width: calc(100% - 90px);
    float: right;
  }
  .page-archive .archive-entries .entry-title {
    font-size:14px;
    line-height: 25px;
    font-weight: 400;
    margin:0;
  }
  .archive-entries .entry-description{
    font-size:11px;
    display:none;
  }
  .page-archive .entry-thumb {
    width: 75px;
    height: 75px;
    border: 1px solid #ECEEF1;
    background-size: 100%;
    float:left;
    border-radius: 3px;
  }

  .page-archive .categories{
    display: none;
  }

  .page-archive .archive-entries .archive-entry {
    margin-bottom: 0;
    padding: 17px 0;
    border-bottom: 1px solid #ECEEF1;
}
  .date a {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 12px;
    padding: 1px;
  }
  .date {
    font-weight: 500;
    margin-bottom: 5px;
  }

  .date:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95%;
    top: 0;
    color: #3f3f3f;
  }

  .page-archive .social-buttons{
    display: none;
  }

  #blog-title {
    text-align: center;
    padding: 35px 0 35px;
    margin:0;
  }

  .entry .entry-title{
    font-size: 18px;
    line-height: 30px;
    margin: 10px 0 15px;
    font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
  }

  .entry .entry-header{
    padding: 10px 0 10px 0;
    border:none;
  }

  .table-of-contents {
    position: relative;
    background-color: #fafafa;
    border:1px solid #ECEEF1;
    padding: 60px 45px 25px;
    border-radius: 0;
    font-size: 14px;
    line-height: 28px;
  }

  #box2 .urllist-image {
    max-width: 100%;
    width: 75px;
    border-radius: 5px;
    margin-right: 10px;
    border: 1px solid #ECEEF1;
    height: 75px;
  }
  .hatena-urllist li{
    padding: 10px 0 0px;
  }

  .hatena-urllist li a {
    font-size: 13px ;
    line-height: 20px;
    font-weight: 500;
    color: #3f3f3f;
    text-decoration: none;
  }

  .archive-module-year{
    border:none ;
  }

  .urllist-date-link time {
    color: #3f3f3f;
    text-decoration: none;
    font-size: 12px ;
    padding: 1px;
  }

  .urllist-date-link time:before {
    font-family: FontAwesome;
    content: "\f272";
    left: 0;
    font-size: 95% ;
    top: 0;
    color: #3f3f3f;
  }
  .archive-entries{
    margin:0 0 40px;
  }

  .id a{
    font-weight: normal;
    text-decoration: none;
    color: #3f3f3f;
  }

  .entry-content {
    font-size: 14px;
  }
  .hatena-module {
    margin-bottom: 40px;
  }
  .urllist-image{
    width: 70px;
    border-radius: 5px;
  }
  .related-entries .related-entries-entry-body{
    display: none;
  }
  .pager{
    text-align: center;
    margin-bottom: 45px;
  }
  :not(.permalink)>.pager-next{
    float:none ;
    text-align: center ;
  }
  :not(.permalink)>.pager-next a{
    text-decoration: none;
    padding: 10px 100px;
    border-radius: 4px;
    border: 1px solid #ECEEF1;
    background: #fafafa;
    color: #3f3f3f;
  }
  .pager-permalink{
    display:none;
  }
}
/* Media Queries - Smartphone */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&family=Noto+Serif+JP:wght@700&display=swap'); 
/* スマホでのタイトル青文字を強制修正 */
#container .title-new a,
#container .title-new a.chappy {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    text-decoration: none !important;
}
/* 念のため、記述ミスによるエラーを防ぐための閉じタグ調整 */
/* </system> */
/* <system section="background" selected="fff"> */
body{background:#fff;}
/* </system> */
}
header#blog-title {
    display: none;
}
@media screen and (min-width: 992px) {
#content-inner { 
max-width:4000px!important;
}}
@media screen and (min-width: 1139px) {
    #container {
        border-right: 0px solid #ECEEF1;
        border-left: 0px solid #ECEEF1;
    }}
#container {
    width: 100%;}
@media screen and (min-width: 1139px) {
    #content {
        margin: 35px 0px;
    }
}
@media screen and (min-width: 992px) {
    #box2-inner {
        padding: 0!important;
    }
}
@media screen and (max-width: 1138px) {
    #box2 {
        width: 100%;}
        }
.entry-thumb {
    max-height: 500px!important;
}
@media screen and (max-width: 1138px) {
    #box2 {
        width: 100%;
        }
}
/*サイドバーひきのばしpc*/
@media screen and (min-width:992px) {
#content-inner {
    flex-wrap: wrap;
}
#wrapper {
    width: 100%;
}
#box2 {
    width: 100%;
}
#box2-inner {
    padding: 0 20px;
}
}
/*メイン記事非表示*/
.page-index div#main-inner {
    display: none;
}
/* ブログタイトルに画像 */
.header-image-only #blog-title #blog-title-inner {
    height: 76px;
    background-size: contain;
    background-position: center -10px!important;
}
@media screen and (min-width:920px){ 
.header-image-only #blog-title #blog-title-inner {
height: 76px;
background-position: calc(20px + 2.6%) -10px !important;
}}
.title-new {
    position: fixed;
    top: 0 !important;
    left: 0;
    z-index: 100;
    width: 100%;
    height: 50px;
    padding: 0;
    background-color: #000;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック Medium', meiryo, sans-serif;
    font-size: 12px;
}
.title-new a{
color: #fff;
text-decoration: none;}
.title-new a.chappy {
    font-size: 2em;
    font-weight: 700; /* 太字 */
}
.title-new img {
    height: auto;
}
#container {
    padding-top: 50px!important;
}
@media screen and (min-width:640px){
.title-new a.chappy {
    margin: 0 15px;
}
.title-new {
    display: flex;
    justify-content: flex-start;
}}
.nexttomenu {
    z-index: 101;
    position: fixed;
    top: 0px;
    right: 61px;
    font-size: 20px;
    height: 50px;
    display: flex;
    align-items: center;
}
@media screen and (max-width:640px){
.nexttomenu {
display:none;
}
}
.nexttomenu a.twitter {
    color: #555 !important;
    text-decoration: none;
    font-size: 26px;
    margin: 0 10px;
}
.nexttomenu a.twitter:visited {
    color: #555 !important;
    text-decoration: none;
}
.nexttomenu a.hatena {
    color: #555 !important;
    text-decoration: none;
    font-size: 26px;
    margin: 3px 15px 0 10px;
}
.nexttomenu a.hatena:visited {
    color: #555 !important;
    text-decoration: none;
}
/*カルーセル*/
.hatena-module-custom-top .archive-entries {
max-width:1000px;
display:block;
background:transparent;
}
.hatena-module-custom-top li.urllist-item.recent-entries-item {
width: 50%;
height: 400px;
margin-top:0em;
margin-right:2vw;
margin-bottom:1em;
border-radius:5px;
counter-increment: carousel-cell;
overflow: hidden;
padding: 0;
}
.hatena-module-custom-top ul.recent-entries.hatena-urllist.urllist-with-thumbnails.flickity-enabled.is-draggable {
    margin: 0px;
}
.hatena-module-custom-top .flickity-page-dots .dot {
    padding: 0;
}
.hatena-module-custom-top .urllist-categories.recent-entries-categories{
display:block;
position:absolute;
top:1vw;
left:.5vw;
z-index:2;
}
.hatena-module-custom-top a.urllist-category-link.recent-entries-category-link{
padding:.6vw;
font-size:.7em;
font-weight:800;
letter-spacing:.2vw;
text-decoration:none;
border-radius:20em;
color:black;
background:white;
opacity:.5;}
.hatena-module-custom-top a.urllist-category-link.recent-entries-category-link:hover{
background:#f4dde3;
transition-duration: 0.3s;}
.hatena-module-custom-top a.urllist-title-link.recent-entries-title-link.urllist-title.recent-entries-title{
display: -webkit-box;
-webkit-box-orient: vertical;
flex: 1 0 auto;
padding:0 0.5vw;
font-size: 1em;
font-weight: 800;
line-height: 1em;
text-decoration:none;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
color: #fff;
width: 88%;
margin-inline: auto;
max-inline-size: max-content;}
.hatena-module-custom-top img.urllist-image.recent-entries-image {
    object-fit: cover !important;
    width: 100% !important;
    height: 400px !important;
    margin: 0;
    border-radius: 10px;
    opacity:0.65;
}
.hatena-module-custom-top img.urllist-image.recent-entries-image:hover{
opacity: 0.6;
}
.hatena-module-custom-top .urllist-item-inner.recent-entries-item-inner {
    background: #000;
    border-radius: 10px;
    width: 100%;
    height: 400px;
}
@media screen and (max-width:640px){ 
.hatena-module-custom-top li.urllist-item.recent-entries-item {
width:60%;
height: 200px;
}
.hatena-module-custom-top img.urllist-image.recent-entries-image {
    object-fit: cover !important;
    width: 100% !important;
    height: 200px !important;
    margin: 0;
    border-radius: 10px;
}
.hatena-module-custom-top{
padding-top: 20px!important;
}
}
.hatena-module-custom-top a.urllist-see-more-link.recent-entries-see-more-link {
color:#fff;
}
.hatena-module-custom-top .urllist-see-more {
text-align: center;
margin-top: 40px;
border: 1px solid #fff;
padding: 1em;
}
.page-index .hatena-module-custom-top .hatena-module-title {
    border-bottom: 0px;
    display:none;
}
.hatena-module-custom-top .flickity-page-dots {
    bottom: -15px;
    }
.hatena-module-custom-cat .hatena-module-title {
    border-bottom: 0px;
    display:none;
}


.footer-tag-cloud {
  margin: 2.5rem 0 2rem;
  padding: 0;
}

.footer-tag-cloud .tag-items {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.5rem 1rem;
  max-width: 720px;
  margin: 0 auto;
}

.footer-tag-cloud .tag-items a {
  display: inline-block;
  padding: 0.35em 0.85em;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #1a1a1a;
  text-decoration: none;
  border: 1px solid #ddd;
  background: transparent;
  transition: color 0.2s, border-color 0.2s, background 0.2s;
}

.footer-tag-cloud .tag-items a:hover {
  color: #000;
  border-color: #1a1a1a;
  background: #f8f8f8;
}

@media screen and (max-width: 640px) {
  .footer-tag-cloud {
    margin: 2rem 1rem 1.5rem;
  }
  .footer-tag-cloud .tag-items {
    gap: 0.4rem 0.75rem;
  }
  .footer-tag-cloud .tag-items a {
    font-size: 10px;
    letter-spacing: 0.08em;
    padding: 0.3em 0.65em;
  }
}



<!-- この1ブロックで「横スライド＋サムネ・タイトル＋ランキング表示」。サイドバー「HTML」でこのまま貼る -->
<style>
/* 横スライド（他CSSより強く効かせる） */
#box2 .hatena-module-custom-work ul.recent-entries.hatena-urllist.urllist-with-thumbnails,
#box2 .hatena-module-custom-travel ul.recent-entries.hatena-urllist.urllist-with-thumbnails,
#box2 [class*="hatena-module-custom-work"] ul.recent-entries.hatena-urllist {
  display: flex !important; flex-direction: row !important; flex-wrap: nowrap !important;
  overflow-x: auto !important; overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch; scroll-snap-type: x mandatory !important;
  gap: 0 20px !important; padding-bottom: 12px !important;
  width: 100% !important; box-sizing: border-box !important;
}
#box2 .hatena-module-custom-work li.urllist-item.recent-entries-item,
#box2 .hatena-module-custom-travel li.urllist-item.recent-entries-item,
#box2 [class*="hatena-module-custom-work"] li.urllist-item {
  flex: 0 0 auto !important; width: 280px !important; min-width: 280px !important;
  margin: 0 !important; padding: 0 !important; box-sizing: border-box !important;
  scroll-snap-align: start; overflow: visible !important;
}
/* サムネイル・タイトルを確実に表示（flexで潰れないように） */
#box2 .hatena-module-custom-work .urllist-item-inner,
#box2 .hatena-module-custom-travel .urllist-item-inner {
  display: block !important; visibility: visible !important; width: 100% !important; min-height: 0 !important;
}
#box2 .hatena-module-custom-work .urllist-image,
#box2 .hatena-module-custom-travel .urllist-image {
  display: block !important; visibility: visible !important; width: 100% !important; min-height: 80px !important;
}
#box2 .hatena-module-custom-work img.urllist-image,
#box2 .hatena-module-custom-travel img.urllist-image,
#box2 .hatena-module-custom-work img.recent-entries-image,
#box2 .hatena-module-custom-travel img.recent-entries-image,
#box2 .hatena-module-custom-work .urllist-image img,
#box2 .hatena-module-custom-travel .urllist-image img {
  display: block !important; visibility: visible !important; opacity: 1 !important;
  width: 100% !important; height: auto !important; max-width: 100% !important;
}
#box2 .hatena-module-custom-work .urllist-title-link,
#box2 .hatena-module-custom-travel .urllist-title-link {
  display: block !important; visibility: visible !important;
}
/* WORK専用：他CSSより強く（リンク・li直下・imgを全部表示） */
body #box2 .hatena-module-custom-work li a {
  display: block !important; visibility: visible !important; opacity: 1 !important;
}
body #box2 .hatena-module-custom-work li > * {
  display: block !important; visibility: visible !important;
}
body #box2 .hatena-module-custom-work li img {
  display: block !important; visibility: visible !important; opacity: 1 !important;
  width: 100% !important; height: auto !important; max-width: 100% !important;
}
body #box2 .hatena-module-custom-work .urllist-item-inner,
body #box2 .hatena-module-custom-work .urllist-image {
  display: block !important; visibility: visible !important; width: 100% !important;
}
body #box2 .hatena-module-custom-work .urllist-title-link,
body #box2 .hatena-module-custom-work a.urllist-title-link {
  display: block !important; visibility: visible !important;
}
/* WORKだけサムネ・タイトルが出ない場合用（クラス名が custom-work2 等でも効く） */
#box2 [class*="hatena-module-custom-work"] .urllist-item-inner,
#box2 [class*="hatena-module-custom-work"] .urllist-image,
#box2 [class*="hatena-module-custom-work"] .urllist-title-link {
  display: block !important; visibility: visible !important; opacity: 1 !important;
}
#box2 [class*="hatena-module-custom-work"] .urllist-image,
#box2 [class*="hatena-module-custom-work"] img.urllist-image,
#box2 [class*="hatena-module-custom-work"] img.recent-entries-image,
#box2 [class*="hatena-module-custom-work"] .urllist-image img,
#box2 [class*="hatena-module-custom-work"] li img {
  display: block !important; visibility: visible !important; opacity: 1 !important;
  width: 100% !important; height: auto !important; max-width: 100%
