/* <system section="theme" selected="10328537792370034204"> */
@charset "utf-8";
/*
  Theme: Spirea
  Author: Shun
  Description:
    はてなブログのカスタマイズしやすいシンプルなテーマです。シンプルなデザインの中には、時にはポップに、時にはシックに魅せる工夫があります。
  Responsive: yes
*/

/* install font */
@import url("https://maxcdn.bootstrapcdn.com/font-awesome/4.5.0/css/font-awesome.min.css");

html {
  font-family: sans-serif;
  /* 1 */

  -ms-text-size-adjust: 100%;
  -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 `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
  font-weight: bold;
}
/**
 * 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 `!important` 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: bold;
}
/* 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: YuGothic, 'Yu Gothic', 游ゴシック体, 游ゴシック, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', Osaka, 'MS PGothic', Arial, Helvetica, Verdana, sans-serif;
  color: #454545;
  background-color: #ffffff;
}
a, a:visited {
  color: #1487bd;
}
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 #dddddd;
  color: #454545;
}
/* Buttons */
.btn {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #454545;
  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: bold;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none !important;
}
.btn:hover {
  background-color: #f5f5f5;
  text-decoration: none !important;
}
.btn-small {
  padding: 2px 10px !important;
  font-size: 11px !important;
}
.btn-large {
  padding: 13px 19px;
  font-size: 17px;
  line-height: normal;
  font-weight: bold;
}
/* container */
#container {
  width: 100%;
  position: relative;
}
#container #content {
  display: block;
  width: 1024px;
  margin: 0 auto;
  margin-top: 20px;
  *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: 700px;
  float: left;
}
#box2 {
  width: 280px;
  float: right;
}
/* header */
#blog-title {
  position: relative;
  z-index: 1;
}
#blog-title-inner {
    margin: 0 auto;
    padding: 30px 0px;
    width: 1024px;
}
#blog-title-content {
    margin: 0 auto;
}
#title {
  margin: 0;
}
#title a {
  color: #454545;
  font-weight: 300;
  font-size: 1.3em;
}
#blog-description {
  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: 1px solid #dddddd;
  padding: 10px;
}
#top-editarea {
    margin-bottom: 35px;
}
/*グローバル検索バー*/
/* Search module */
.global-module {
    position: absolute;
    top: 0px;
    width: 100%;
    height: 46px;
    z-index:1;
}
.global-module-inner {
    position: relative;
    width: 1024px;
    height: 100%;
    margin: auto;
}
.global-search-module {
    position: absolute;
    top: 8px;
    right: 10px;
}
.global-search-module .search-form {
    font-size: 12px;
    border: 1px solid #dddddd;
    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: 250px;
    height: 30px;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
    background: #ffffff;
}
.global-search-module .search-module-input {
    padding: 5px;
    color: #454545;
    background: none;
    border: none;
    outline: none;
    width: 75%;
    line-height: 19px;
}
.global-search-module .search-module-button {
    width: 45px;
    height: 29px;
    background: transparent url(https://cdn.blog.st-hatena.com/images/theme/search.png) no-repeat center center;
    border: none;
    outline: none;
    text-indent: -9999px;
    position: absolute;
    /* top: 9px; */
    right: 0px;
    opacity: 0.5;
    border-left: 1px solid #dddddd;
}
.global-search-module .search-module-button:hover {
  opacity: 0.85;
}
@media (max-width: 767px) {
  .global-search-module .search-form {
    width:150px;
  }
}
.global-follow-buttons {
  position: absolute;
  top: 8px;
  right: 270px;
}
.global-follow-buttons a {
  display: block;
  float: left;
  width: 30px;
  height: 30px;
  background-color: #fff;
  border: 1px solid #dddddd;
  border-radius: 3px;
  text-align: center;
  margin-right: 5px;
  line-height: 33px;
}
.global-follow-buttons:after {
  content:"";
  display: block;
  clear: left;
}
.global-follow-buttons .hatena {
  color: #38393C;
}
.global-follow-buttons .facebook {
  color: #305097;
}
.global-follow-buttons .twitter {
  color: #55acee;
}
@media (max-width: 767px) {
  .global-follow-buttons {
    right: 170px;
  }
}
/*グローバルナビゲーションメニュー（通常バージョン）*/
nav.global-menu-normal {
  display: inline-block;
  width: 100%;
  background: #333;
  color:#fff;
}
.global-area > .menu-instance {
  width: 1024px;
  margin: 0 auto;
}
.global-menu-normal ul {
    padding-left: 0;
    list-style: none;
    margin: 0;
}
.global-menu-normal a {
    display: block;
    text-decoration: none;
    padding: 0px 30px;
    height: 100%;
    line-height: 50px;
    color: #fff;
    background: #333;
}
@media (max-width: 767px) {
  .global-menu-normal > .menu-instance > ul {
    display: none;
  }
  .global-menu-normal li {
    width: 100%;
    display: block;
  }
  .global-menu-normal li a {
    border-top: 1px solid #999;
  }
  .global-menu-normal #toggle {
    display: block;
    position: relative;
    width: 75px;
    font-size: 13px;
    text-align: center;
    border: 1px solid #CCC;
    margin: 5px 0;
  }
  .global-menu-normal ul ul a {
    padding-left: 45px;
  }
  .global-menu-normal ul ul a:before {
    content: "- "
  }
  .global-menu-normal ul ul ul a {
    padding-left: 60px;
  }
  .global-menu-normal  > .menu-instance > ul:after {
    content: "";
    display: block;
    height: 5px;
    border-top: 1px solid #999;
  }
}
@media (min-width: 768px) {
  .global-menu-normal li {
      height: 50px;
  }
  .global-menu-normal > .menu-instance > ul > li {
      position:relative;
      display: block;
      float: left;
      overflow: visible;
  }
  .global-menu-normal > .menu-instance > ul:after {
      content: "";
      display: block;
      clear: left;
  }
  .global-menu-normal a:hover {
      background: #545252;
  }
  .global-menu-normal li ul a {
      border-top: 1px solid #999;
  }
  .global-menu-normal > .menu-instance > ul > li > ul {
      position: absolute;
      top: 100%;
      left:0;
      width: 250px;
      opacity: 0;
      visibility: hidden;
      overflow: hidden;
      transition: all 0.3s;
      z-index: 100;
  }
  .global-menu-normal > .menu-instance > ul > li:hover > ul {
      background: #333;
      opacity: 1;
      visibility: visible;
      overflow: visible;
      transition: all 0.3s;
  }
  .global-menu-normal > .menu-instance > ul > li > ul > li {
      position: relative;
  }
  .global-menu-normal > .menu-instance > ul > li > ul > li > ul {
    position: absolute;
    top: 1px;
    left:100%;
    width: 250px;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    transition: all 0.3s;
    z-index: 100;
  }
  .global-menu-normal > .menu-instance > ul > li > ul > li:hover > ul {
      background: #333;
      opacity: 1;
      visibility: visible;
      overflow: visible;
      transition: all 0.3s;
  }
  .global-menu-normal > .menu-instance > ul > li > .dropdown:after {
    content: "\f107";
    font: normal normal normal 14px/1 FontAwesome;
    display: inline-block;
    padding-left: 10px;
  }
  .global-menu-normal > .menu-instance > ul > li > ul .dropdown:after {
    content: "\f105";
    font: normal normal normal 14px/1 FontAwesome;
    display: inline-block;
    padding-left: 10px;
  }
  .global-menu-normal #toggle {
    display: none;
  }
}
/*グローバルナビゲーションメニュー（下から上へ上がるバージョン）*/
nav.global-menu-rise {
  display: inline-block;
  width: 100%;
}
.global-menu-rise ul {
    padding-left: 0;
    list-style: none;
}
.global-menu-rise a {
    display: block;
    text-decoration: none;
    padding: 10px 20px 10px 0px;
    color: #333;
}
.global-menu-rise a:hover {
    color: #ccc;
}
@media (max-width: 767px) {
  .global-menu-rise > .menu-instance > ul {
    display: none;
  }
  .global-menu-rise li {
    width: 100%;
    display: block;
  }
  .global-menu-rise li a {
    border-top: 1px solid #999;
  }
  .global-menu-rise #toggle {
    display: block;
    position: relative;
    width: 75px;
    font-size: 13px;
    text-align: center;
    border: 1px solid #CCC;
    margin: 5px 0;
  }
  .global-menu-rise ul a {
    padding-left: 20px;
  }
  .global-menu-rise ul ul a {
    padding-left: 40px;
  }
  .global-menu-rise ul ul a:before {
    content: "- "
  }
  .global-menu-rise  > .menu-instance > ul:after {
    content: "";
    display: block;
    height: 5px;
    border-top: 1px solid #999;
  }
}
@media (min-width: 768px) {
  .global-menu-rise > .menu-instance > ul > li {
      position:relative;
      display: block;
      float: left;
      margin-right: 20px;
      height: 53px;
      overflow: visible;
  }
  .global-menu-rise > .menu-instance > ul:after {
      content: "";
      display: block;
      clear: left;
  }
  .global-menu-rise > .menu-instance > ul > li > ul {
      position: absolute;
      left: -10px;
      top: 40px;
      width: 250px;
      opacity: 0;
      visibility: hidden;
      overflow: hidden;
      transition: all 0.3s;
      transform: translateY(16px);
      z-index: 100;
      padding-top: 10px;
  }
  .global-menu-rise > .menu-instance > ul > li:hover > ul {
      background: #FFF;
      opacity: 1;
      visibility: visible;
      overflow: visible;
      transition: all 0.3s;
      transform: translateY(0px);
  }
  .global-menu-rise > .menu-instance > ul > li > ul:before {
      content: "";
      display: block;
      height: 5px;
      background: #ccc;
  }
  .global-menu-rise > .menu-instance > ul > li > ul:last-child {
      border-bottom:1px solid #CCC;
  }
  .global-menu-rise > .menu-instance > ul > li > ul > li {
      background: #FFF;
      height: 50px;
      text-align: left;
      border-left: 1px solid #CCC;
      border-right: 1px solid #CCC;
  }
  .global-menu-rise li ul li {
      overflow: hidden;
      height: 0;
  }
  .global-menu-rise li:hover ul li {
      overflow: visible;
      height: 38px;
  }
  .global-menu-rise > .menu-instance > ul > li > ul > li > a {
      padding-left: 20px;
  }
  .global-menu-rise .dropdown:after {
    content: "\f107";
    font: normal normal normal 14px/1 FontAwesome;
    display: inline-block;
    padding-left: 10px;
  }
  .global-menu-rise #toggle {
    display: none;
  }
}
/* entry */
.entry {
  position: relative;
  margin-bottom: 100px;
}
.entry-header {
  padding: 0 0 10px 0;
  margin-bottom: 20px;
  position: relative;
}
.entry-title {
  margin: 0;
  line-height: 1.3;
  font-size: 190%;
}
/* 日付 */
.date {
  margin-bottom: 10px;
}
.date a {
  color: #333;
  text-decoration: none;
  font-size: 90%;
  font-style: italic;
}
.date .hyphen {
    display: none;
}
.date-month:before {
    content: ".";
}
.date-day:before {
    content: ".";
}
/* カテゴリ */
.categories {
  margin-top: 10px;
  font-size: 90%;
}
.categories a {
  padding: 4px 5px;
  font-size: 80%;
  text-decoration: none;
  border-radius: 2px;
}
.categories.no-categories {
  margin: 0;
}
.categories a {
  color: #333; /* 文字色 */
  background-color: #ccc; /* 背景色 */
}
.categories a:hover {
  color: #333; /* ホバー時の文字色 */
  background-color: #ddd; /* ホバー時の背景色 */
}
/* 「編集する」ボタン */
.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: #454545;
  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: bold;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none !important;
}
.entry-header-menu a:hover {
  background-color: #f5f5f5;
  text-decoration: none !important;
}
/* entry-content の中の書式 */
.entry-content {
  font-size: 95%;
  line-height: 1.7;
  padding-bottom: 10px;
  border-bottom: 1px solid #dddddd;
}
.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 #dddddd;
  margin: 0 0 10px;
  padding: 20px;
}
.entry-content blockquote p {
  margin-top: 0;
  margin-bottom: 0;
}
.entry-content pre {
  border: 1px solid #dddddd;
  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;
}
/* 目次 */
.table-of-contents li,
.table-of-contents ul{
    list-style-type: decimal;
}
.table-of-contents:before{
    font-size: 130%;
}
.table-of-contents{
    padding: 20px 10px 20px 40px !important;
    border:1px solid #CCC;
    margin-left: 0px !important;
}
.table-of-contents ul{
    font-size: 90%;
}
.table-of-contents a {
    color:blue;
    text-decoration: underline;
}
.table-of-contents a:hover {
    color:#4eacd1;
}
/* 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 #dddddd;
  position: relative;
}
.comment-box li:first-child {
  border-top: 1px solid #dddddd;
}
.comment-box .read-more-comments {
  padding-left: 0;
}
.comment-box .hatena-id-icon {
  position: absolute;
  top: 10px;
  left: 0;
  width: 50px !important;
  height: 50px !important;
  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: bold;
}
.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: #454545;
  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: bold;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none !important;
}
.leave-comment-title:hover {
  background-color: #f5f5f5;
  text-decoration: none !important;
}
/* sidebar */
#box2 {
  font-size: 85%;
  line-height: 1.5;
}
.hatena-module {
  margin-bottom: 60px;
}
.hatena-module-title {
  font-weight: bold;
  margin-bottom: 15px;
  font-size: 120%;
}
.hatena-module-title a {
  color: #454545;
  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: bold;
  font-size: 110%;
  margin-bottom: 5px;
  min-height: 70px;
}
.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 #dddddd;
  line-height: 1.5;
}
.hatena-urllist li a {
  text-decoration: none;
}
/* Search module */
.hatena-module-search-box .search-form {
    border: 1px solid #dddddd;
    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%;
    height: 40px;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
}
.hatena-module-search-box .search-module-input {
    padding: 5px;
    color: #454545;
    background: none;
    border: none;
    outline: none;
    width: 75%;
}
.hatena-module-search-box .search-module-button {
    width: 45px;
    height: 39px;
    background: transparent url(https://cdn.blog.st-hatena.com/images/theme/search.png) no-repeat center center;
    border: none;
    outline: none;
    text-indent: -9999px;
    position: absolute;
    /* top: 9px; */
    right: 0px;
    opacity: 0.5;
    border-left: 1px solid #dddddd;
}
.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: bold;
  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;
  line-height: 1.7em;
  font-size: 95%;
}
.page-archive .categories a {
  color: #fff;
  font-size: 70%;
  background: #aaa;
  padding: 3px 5px;
  border-radius: 3px;
  text-decoration: none;
  display: inline-block;
  *display: inline;
  *zoom: 1;
  margin-right: 2px;
}
/*  import media queries */
/* Media Queries - Retina Display */
@media (-webkit-min-device-pixel-ratio: 2) {
  .hatena-module-search-box .search-module-button {
    background: transparent url(https://cdn.blog.st-hatena.com/images/theme/search@2x.png) no-repeat right center;
    background-size: 20px 20px;
  }
}
/* Media Queries - Small PC, Large Tablet */
@media (min-width: 901px) and (max-width: 1100px) {
  #container {
    width: 100%;
  }
  #container #content {
    width: 90%;
    margin: 0 auto;
  }
  #blog-title-content {
    width: 90%;
  }
  .global-area > .menu-instance {
    width: 90%;
    margin: auto;
  }
  #main {
    width: 64%;
  }
  #box2 {
    width: 30%;
    min-width: 240px;
  }
  .global-module-inner {
    width: 90%;
    margin: 0 auto;
  }
  /* 1カラムにしたい場合は下記のコメントアウトを外してください ----
      #main,
      #box2 {
          width: 100%;
      }

      #box2-inner {
          width: 744px;

      }

      .hatena-module {
          width: 228px;
      }
  ---- END 1カラム */
}
/* Media Queries - Tablet */
@media (min-width: 768px) and (max-width: 900px) {
  #container {
    width: 100%;
  }
  #container #content {
    width: 90%;
    margin: 0 auto;
  }
  #blog-title-inner {
    width: 90%;
  }
  .global-area > .menu-instance {
    width: 90%;
    margin: auto;
  }
  #main, #box2 {
      width: 100%;
  }
  .global-module-inner {
    width: 90%;
    margin: 0 auto;
  }
  #box2-inner {
  }

  .hatena-module {
  }

  .entry-header-menu {
    top: -30px;
    left: 0px;
  }

}
/* Media Queries - Small Tablet & Smartphone */
@media (max-width: 767px) {
  #globalheader-container {
    position: static;
  }
  #title a {
    font-size:100%;
  }
  .entry-title {
    font-size:140%;
  }
  #container {
    width: 100%;
    word-wrap: break-word;
    overflow: hidden;
  }
  #container #content {
    width: 90%;
    margin: 0 auto;
  }
  #blog-title-inner {
    width: 90%;
  }
  .global-area > .menu-instance {
    width: 90%;
    margin: auto;
  }
  #main, #box2 {
      width: 100%;
  }
  .global-module-inner {
    width: 90%;
    margin: 0 auto;
  }
  .entry-header-menu {
    top: -30px;
    left: 0px;
  }
}

/* </system> */

/* <system section="background" selected="fff"> */
body{background:#fff;}
/* </system> */

body {
        font-family: "Avenir Next", 'Helvetica Neue', Helvetica, Arial, YuGothic, 'Yu Gothic', 游ゴシック体, '游ゴシック', 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, 'MS ゴシック', 'MS Gothic', sans-serif;
        
}


/* SNSフォロー */
.follow-btn{
width: 100%;
}
.follow-btn a {
display: block;
height: 50px;
line-height: 50px;
width: 100%;
font-size: 14px;
text-align: center;
text-decoration: none;

}
.follow-btn .hatena {
color: #ffffff;
background: #3D3F44; 

}
.follow-btn .twitter {
color: #ffffff;
background: #00ACEE; 
}
.follow-btn .feedly { 
color: #ffffff;
background:#6cc655;
}
.follow-btn a:hover{
opacity: 0.5;
}



#title {
    font-family: 'Roboto', sans-serif;
    font-weight: 500;
    font-size: 28px;
    color: #FFF;
}

#blog-title-content #blog-description{
    font-size: 18px;
}

#blog-title, #title a {
  background-color: black;
  color:#ffffff;
  font-weight: bold;
}

nav.global-menu-normal, .global-menu-normal a {
  color: #ffffff; /* 文字色 */
  font-family: 'Roboto', sans-serif;
  font-weight: bold;
  background-color: rgb(34, 34, 34); /* 背景色 */
}
.global-menu-normal a:hover {
    background-color: #264673; /* マウスオーバー時の色 */
}



.entry {
    border: 1px solid #CCC;
    padding: 48px 64px;
}


.entry-header {
    border-bottom: 1px solid #dddddd;
}

a.entry-title-link.bookmark:hover {
    background: linear-gradient(transparent 60%, #a8dadc 40%);
}

.categories a {
  color: #ffffff; /* 文字色 */
  background-color: #286da8; /* 背景色 */
}
.categories a:hover {
  color: #ffffff; /* ホバー時の文字色 */
  background-color: #a8dadc; /* ホバー時の背景色 */
}

.entry-content p {
    font-size: 16px;
    line-height: 2em;
    margin-top: 12px;
    margin-bottom: 32px;
}

.entry-content h3{
    color: #3f3f3f; 
    padding: 10px 15px; 
    border-bottom: 3px solid #286da8;
    font-size: 30px;
}

.entry-content h4 {
  color: #353535; /* 文字色 */
  background: #f7f7f7; /* 背景色 */
  border-left: 9px solid #286da8; /* 左のボーダー */
  padding: 15px; /* 内側の余白 */
  font-size: 24px;
}

.entry-content h5 {
    margin-bottom: 10px!important;
    color: #256198;
    display: block;
    -webkit-margin-before: 1.33em;
    -webkit-margin-after: 1.33em;
    -webkit-margin-start: 0px;
    -webkit-margin-end: 0px;
    font-weight: bold;
}

.entry-content h5:before {
    content: "\f029";
    font-family: "blogicon";
    position: relative;
    padding-right: 10px;
    color: #256198;
}

/*影*/
.shadow {
    margin-top: 5px; /* 画像の上の余白*/
    display: inline-block; 
    box-shadow: 0px 5px 15px -5px rgba(0, 0, 0, 0.8); /*横方向　下方向　ぼかし　広がり　色 */
}

/* 太字、下線 */
article strong{
    margin:0 0.1em;
    padding:0.1em 0.2em;
    background:#fcfc60 !important;
    background:linear-gradient(to bottom, transparent 60%, rgba(252,252,84,0.8) 60%) !important;
}
/* bタグは太字 */
article b{
    margin:0 0.1em;
    padding:0.1em 0.2em;
    background:#fcfc60 !important;
    background:linear-gradient(to bottom, transparent 60%, rgba(252,252,84,0.8) 60%) !important;
}

.entry-content ol, .entry-content ul {
    max-width: 98%;
    margin: 0!important;
    padding: 1em 1em 1em 3.5em!important;
    color: #256198;
    border: solid 2px #256198;
}

/* 引用のデザイン1 */.entry-content blockquote {
    padding: 20px 55px;
    background: rgba(245,245,245,0.8);
    color: #222;
    position: relative;
    border: solid 1px #fff;
    margin: 0.8em 0;
}/* 引用のデザイン2 */.entry-content blockquote:before {
    color: rgba(200, 200, 200, 1);
    content: "“";
    font-family: serif;
    font-size: 600%;
    left: 0;
    line-height: 1em;
    position: absolute;
    top: 0;
}/* 引用のデザイン3 */.entry-content blockquote:after {
    content: "”";
    font-family: serif;
    position: absolute;
    bottom: 0;
    right: 0;
    font-size: 600%;
    color: rgba(200,200,200,1);
    line-height: 0;
}

/*続きを読むボタン*/
.entry-see-more {
  display: block;
  width: 200px;
  height: 40px;
  line-height: 40px;
  text-align: center;
  text-decoration: none;
  font-weight:bold;
  background-color: #333;
  color: #fff;
  border: 2px solid #333;
  border-radius: 3px;
}

/*続きを読む*/
.entry-see-more:hover {
  background-color: #545252;
  border-color: #545252;
  color: #fff;
}

/*サイドバー*/
.hatena-module-title, .hatena-module-title a {
  color: #333333; /* 文字色 */
}
.hatena-module-title {
  border-bottom: 3px solid #286da8; /* 下のボーダー */
  padding: 3px 0px; /* 余白 */
}

/*シェアボタン行間(数値のみ)*/
.hatena-module-body p{
    margin: 0px;
}

/*--------------------------------------
  ヨメレバ・カエレバ（PC）
--------------------------------------*/
.booklink-box, .kaerebalink-box{
    width:90%;
    margin:20px auto;
    padding:20px;
    border:double #CCC;
    overflow: hidden;
    font-size:small;
}

.booklink-image, .kaerebalink-image{
    margin:0 15px 0 0;
    float:left;
}

.booklink-image img, .kaerebalink-image img{
    margin:0 auto;
    text-align:center;
}
 
.booklink-info, .kaerebalink-info{
    margin:0;
        text-align:left;
    line-height:120%;
    overflow: hidden;
}
 
.booklink-name, .kaerebalink-name{
    font-size:16px;
    margin-bottom:24px;
    line-height:1.5em;
}
 
.booklink-powered-date, .kaerebalink-powered-date{
     font-size:8pt;
     margin-top:10px;
     font-family:verdana;
     line-height:120%;
}
.booklink-powered-date, .kaerebalink-detail{
    margin-bottom:15px;
}
 
.booklink-link2, .kaerebalink-link1{
    margin-top:10px;
}
 
.shoplinkamazon, .shoplinkrakuten, .shoplinkkindle, .shoplinkyahoo, .shoplinkkakakucom {
        width:30%;
    background:-webkit-gradient(linear, left top, left bottom, color-stop(0.05, #ffffff), color-stop(1, #f6f6f6));
    background:-moz-linear-gradient(top, #ffffff 5%, #f6f6f6 100%);
    background:-webkit-linear-gradient(top, #ffffff 5%, #f6f6f6 100%);
    background:-o-linear-gradient(top, #ffffff 5%, #f6f6f6 100%);
    background:-ms-linear-gradient(top, #ffffff 5%, #f6f6f6 100%);
    background:linear-gradient(to bottom, #ffffff 5%, #f6f6f6 100%);
    filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#f6f6f6',GradientType=0);
    background-color:#ffffff;
    -moz-border-radius:6px;
    -webkit-border-radius:6px;
    border-radius:6px;
    border:1px solid #dcdcdc;
    display:inline-block;
    cursor:pointer;
    margin:15px 2px 0 auto;
    padding:8px 1px;
    text-align:center;
        float:left;
    }
    
.shoplinkamazon:hover, .shoplinkrakuten:hover, .shoplinkkindle:hover, .shoplinkyahoo:hover,  .shoplinkkakakucom:hover{
    background:-webkit-gradient(linear, left top, left bottom, color-stop(0.05, #f6f6f6), color-stop(1, #ffffff));
    background:-moz-linear-gradient(top, #f6f6f6 5%, #ffffff 100%);
    background:-webkit-linear-gradient(top, #f6f6f6 5%, #ffffff 100%);
    background:-o-linear-gradient(top, #f6f6f6 5%, #ffffff 100%);
    background:-ms-linear-gradient(top, #f6f6f6 5%, #ffffff 100%);
    background:linear-gradient(to bottom, #f6f6f6 5%, #ffffff 100%);
    filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#f6f6f6', endColorstr='#ffffff',GradientType=0);
    background-color:#f6f6f6;
}
 
.shoplinkamazon:active, .shoplinkrakuten:active, .shoplinkkindle:active, .shoplinkyahoo:active  .shoplinkkakakucom:active {
    position:relative;
    top:1px;
}
 
.shoplinkamazon a, .shoplinkrakuten a, .shoplinkyahoo a, .shoplinkkindle a, .shoplinkkakakucom a{
    text-decoration:none;
    font-weight:800;
    text-shadow:1px 1px 1px #dcdcdc;
    font-size:12px;
}
    
.shoplinkamazon a{
    color:#FF9901;
}
 
 .shoplinkrakuten a{
    color:#c20004;
}
 
.shoplinkkindle a{
    color:#007dcd;    
}
 
.shoplinkkakakucom a{
    color:#314995;    
}
 
.shoplinkyahoo a{
    color:#7b0099; 
}
.shoplinkyahoo img{
    display:none;
}
 
.booklink-footer{
    clear:left;
}

.shoplinkyahoo a{
     font-size:10px;
 }
 /*ヨメレバ　ここまで*/

/*記事がよかったら、いいねPC*/
.p-entry__push {
    margin-bottom: 20px;
    display: table;
    table-layout: fix;
    width: 100%;
    background-color: #2b2b2b;
    color: #fff;
}
 
.p-entry__pushThumb {
    display: table-cell;
    min-width: 240px;
    background-position: center;
    background-size: cover;
}
 
.p-entry__pushLike {
    display: table-cell;
    padding: 20px;
    text-align: center;
    vertical-align: middle;
    line-height: 1.4;
    font-size: 18px;
    font-weight: bold;
}
 
.p-entry__pushButton {
    margin-top: 15px;
    display: inline-block;
    width: 200px;
    height: 40px;
    line-height: 40px;
    -webkit-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2);
}
 
.p-entry__pushButtonLike {
    line-height: 1;
}
 
.p-entry__note {
    margin-top: 15px;
    font-size: 12px;
    color: #999;
}
/*記事がよかったらいいね　ここまで*/

/*広告 文字大きさ(記事下)*/
#my-footer p{
    margin: 0px;
    font-size: 1px;
}

#advertisement {
    margin: 0 -35px 0;
}

/*****ここから会話のCSS*****/
.talk-wrap{
 display: block;
 clear: both;
 margin:0 auto 3px auto;
 }
.talk-wrap p{
 margin:0;
 }
 .left-icon{
 width: 100px;
 height: 100px;
 border-radius: 50%;
 -webkit-border-radius: 50%;
 background: no-repeat;
 background-size: 100%;
 background-position: center;
 float:left;
 display:inline-block;
 box-shadow: 1px 1px 5px #aaa; /*左のアイコンの影の設定*/
 border: 3px solid #fff; /*左のアイコンの枠の設定*/
 margin-bottom: 10px;
 }
 .talk-left{
 float:right;
 position: relative;
 background: #fff; /*左の会話の背景色*/
 border: 2px solid #666;
 padding: 3%;
 border-radius: 10px;
 width: 70%;
 margin-top:10px;
 box-shadow: 1px 1px 5px #aaa; /*左の会話の影の設定*/
 margin-bottom: 10px;
 }
.talk-left:before {
 content: "";
 display: inline-block;
 border: 10px solid transparent;
 border-right-color: #666;
 position: absolute;
 left: -20px;
 top: 25%;
 margin-top: -9px;
}
.talk-left:after {
 content: "";
 display: inline-block;
 border: 9px solid transparent;
 border-right-color: #fff;
 position: absolute;
 left: -16px;
 top: 25%;
 margin-top: -8px;
}
 .right-icon{
 width: 100px;
 height: 100px;
 border-radius: 50%;
 -webkit-border-radius:50%;
 background: no-repeat;
 background-size: 100%;
 background-position: center;
 float:right;
 display:inline-block;
 box-shadow: 1px 1px 5px #aaa; /*右のアイコンの影の設定*/
 border: 3px solid #FFF; /*右のアイコンの枠の設定*/
 margin-bottom: 10px;
 }
 .talk-right{
 float:left;
 position: relative;
 background: #fff; /*右の会話の背景色*/
 border: 2px solid #666;
 padding: 3%;
 border-radius: 10px;
 width: 70%;
 margin-top:10px;
 box-shadow: 1px 1px 5px #aaa; /*右の会話の影*/
 margin-bottom:10px;
 }
 .talk-right:before {
 content: "";
 display: inline-block;
 border: 10px solid transparent;
 border-left-color: #666;
 position: absolute;
 right: -20px;
 top: 25%;
 margin-top: -9px;
}
.talk-right:after {
 content: "";
 display: inline-block;
 border: 9px solid transparent;
 border-left-color: #fff;
 position: absolute;
 right: -16px;
 top: 25%;
 margin-top: -8px;
}
.talk-end{
 clear:both;
}
/*****レスポンシブ設定*****/
@media screen and (max-width: 480px){
 .left-icon{
 width: 80px;
 height: 80px;
 }
 .talk-left{
 width: 65%; 
 }
 .right-icon{
 width: 80px;
 height: 80px;
 }
 .talk-right{
 width: 65%; 
 }
 }
 @media screen and (max-width: 380px){
 .left-icon{
 width: 60px;
 height: 60px;
 }
 .talk-left{
 width: 65%; 
 }
 .right-icon{
 width: 60px;
 height: 60px;
 }
 .talk-right{
 width: 65%; 
 }
 }