/* <system section="theme" selected="8454420450080713961"> */
@charset "utf-8";
/*
Theme: Rouge
Author: WEDGES.BIN
Version: 1.0.7
Description:This Theme is based on "boilerplate".
Copyright 2014, WEDGES.BIN
Licensed under the MIT license.
Copyright 2014, Hatena Blog Team
Licensed under the MIT license.
Responsive: yes
*/

/* ====================== Import ======================== */
@import url("https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css");


/* ====================================================== */

/*                        Normalize                       */

/* ====================================================== */
/* normalize.css v3.0.0 | MIT License | git.io/normalize  */

html {
font-family: sans-serif;
-ms-text-size-adjust: 100%;
-webkit-text-size-adjust: 100%;
}
body {
margin: 0;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
display: block;
}
audio,
canvas,
progress,
video {
display: inline-block;
vertical-align: baseline;
}
audio:not([controls]) {
display: none;
height: 0;
}
[hidden],
template {
display: none;
}
a {
background: transparent;
}
a:active,
a:hover {
outline: 0;
}
abbr[title] {
border-bottom: 1px dotted;
}
b,
strong {
font-weight: bold;
}
dfn {
font-style: italic;
}
h1 {
font-size: 2em;
margin: 0.67em 0;
}
mark {
background: #ff0;
color: #000;
}
small {
font-size: 80%;
}
sub,
sup {
font-size: 75%;
line-height: 0;
position: relative;
vertical-align: baseline;
}
sup {
top: -0.5em;
}
sub {
bottom: -0.25em;
}
img {
border: 0;
}
svg:not(:root) {
overflow: hidden;
}
figure {
margin: 1em 40px;
}
hr {
-moz-box-sizing: content-box;
box-sizing: content-box;
height: 0;
}
pre {
overflow: auto;
}
code,
kbd,
pre,
samp {
font-family: monospace, monospace;
font-size: 80%;
}
button,
input,
optgroup,
select,
textarea {
color: inherit;
font: inherit;
margin: 0;
}
button {
overflow: visible;
}
button,
select {
text-transform: none;
}
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
-webkit-appearance: button;
cursor: pointer;
}
button[disabled],
html input[disabled] {
cursor: default;
}
button::-moz-focus-inner,
input::-moz-focus-inner {
border: 0;
padding: 0;
}
input {
line-height: normal;
}
input[type="checkbox"],
input[type="radio"] {
box-sizing: border-box;
padding: 0;
}
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
height: auto;
}
input[type="search"] {
-webkit-appearance: textfield;
-moz-box-sizing: content-box;
-webkit-box-sizing: content-box;
box-sizing: content-box;
}
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
-webkit-appearance: none;
}
fieldset {
border: 1px solid #c0c0c0;
margin: 0 2px;
padding: 0.35em 0.625em 0.75em;
}
legend {
border: 0;
padding: 0;
}
textarea {
overflow: auto;
}
optgroup {
font-weight: bold;
}
table {
border-collapse: collapse;
border-spacing: 0;
font-size: 90%;
}
td,
th {
padding: 0;
}
.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;
}

/* ====================================================== */

/*                         Common                         */

/* ====================================================== */
html,
body {
font-family: 'Helvetica Neue', 'Helvetica', 'Arial', 'Hiragino Kaku Gothic Pro', 'Meiryo', 'MS PGothic', sans-serif;
color: #454545;
background-color: #f5f5f5;
}
a {
color: #333;
text-decoration: none;
}
a:visited {
color: #333;
}
h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a,
h1 a:visited,
h2 a:visited,
h3 a:visited,
h4 a:visited,
h5 a:visited,
h6 a:visited,
h1 a:hover,
h2 a:hover,
h3 a:hover,
h4 a:hover,
h5 a:hover,
h6 a:hover {
color: #333;
font-weight: bold;
}
a, a:visited {
transition: color 0.5s ease-out;
-webkit-transition: color 0.5s ease-out;
-moz-transition: color 0.5s ease-out;
-ms-transition: color 0.5s ease-out;
-o-transition: color 0.5s ease-out;
}
a:hover {
color: #999;
}

/* ====================== Buttons ======================= */
.btn {
display: inline-block;
*display: inline;
*zoom: 1;
padding: 4px 10px 4px;
margin-bottom: 0;
line-height: 18px;
color: #454545;
background-color: #fff;
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;
}

/* =================== Hatena header ==================== */
#globalheader-container {
background-color: #333;
color: #fff;
position: fixed;
top: 0;
left: 0;
width: 100%;
}


/* ====================================================== */

/*                       Structure                        */

/* ====================================================== */
#container {
margin-left: auto;
margin-right: auto;
}
#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;
}
#box2,
#bottom-editarea {
background-color: #fff;
border: 1px solid #DADADA;
border-radius: 5px;
box-sizing: border-box;
}
#wrapper {
background-color: #fff;
border-left: 1px solid #DADADA;
border-right: 1px solid #DADADA;
border-bottom: 1px solid #DADADA;
border-radius: 0 0 5px 5px;
box-sizing: border-box;
}

/* ======================= header ======================= */
#blog-title {
background-color: #c70032;
}
h1#title {
padding: 0;
margin: 0;
}
h1#title,
h2#blog-description {
text-align: center;
padding: 0 30px;
color: #fff;
}
h1#title {
margin-bottom: 0;
padding-bottom: 0;
}
h1#title a {
color: #fff;
}

#blog-description {
font-weight: normal;
font-size: 85%;
color: #fff;
margin: 5px 0 0 0;
}

.header-image-enable #blog-title #blog-title-inner,
.header-image-only #blog-title #blog-title-inner {
background-color: #fff;
box-sizing: border-box;
border-top: 1px solid #dadada;
border-left: 1px solid #dadada;
border-right: 1px solid #dadada;
}
.header-image-enable #blog-title #title a,
.header-image-enable #blog-title #blog-description {
text-shadow: 0px 0px 10px rgba(0,0,0,0.5);
}
.header-image-enable #blog-title #blog-title-inner,
.header-image-only #blog-title #blog-title-inner,
#blog-title {
border-radius: 5px 5px 0 0;
}
.header-image-enable #blog-title #blog-title-inner,
.header-image-only #blog-title #blog-title-inner,
#blog-title {
height: auto !important;
}
.customized-header {
clear: both;
}

/* =================== top-editarea ===================== */
#top-editarea {
background-color: #fff;
border-left: 1px solid #dadada;
border-right: 1px solid #dadada;
box-sizing: border-box;
padding: 15px;
}

/* ====================== top-box ======================= */
#top-box {
background-color: #fff;
border-left: 1px solid #dadada;
border-right: 1px solid #dadada;
box-sizing: border-box;
font-size: 90%;
}

/* ===================== breadcrumb ===================== */
#top-box .breadcrumb {
padding: 15px;
color: #999;
}
#top-box .breadcrumb a {
color: #999;
}
#top-box .breadcrumb a:hover {
color: #333;
}

/* ======================== entry ======================= */
.entry {
position: relative;
margin-bottom: 100px;
}
.entry-header {
padding-top: 2.25em;
position: relative;
display:table;
width: 100%;
border-top: 2px solid #999;
margin-top: 0.5em;
margin-bottom: 1.75em;
}
.entry-title {
margin: 0;
line-height: 1.3;
font-size: 160%;
display: table-header-group;
width: 100%;
}
h1.entry-title a {
display: table-cell;
padding-bottom: 1.4em;
border-bottom: 2px solid #999;
}
h1.entry-title a {
padding-left: 0.5em;
padding-right: 0.25em;
}

/* ======================== date ======================== */
.date {
display: table-cell;
text-align: right;
}
.date a {
font-size: 80%;
color: #999;
}
.date a:hover {
color: #333;
}

/* ===================== categories ===================== */
.categories {
font-size: 80%;
position: relative;
top: -17px;
float: left;
margin-right:100px;
}
.categories.no-categories {
margin: 0;
}
.categories a {
color: #999;
}
.categories a:hover {
color: #333;
}

/* ================= entry-header-menu ================== */
.entry-header-menu {
position:  absolute;
top: 3px;
right: 0px;
}
.entry-header-menu a {
display: inline-block;
*display: inline;
*zoom: 1;
padding: 0;
margin-bottom: 0;
line-height: 18px;
cursor: pointer;
font-size: 12px;
text-decoration: none;
font-weight: normal;
text-decoration: none !important;
color: #999;
}
.entry-header-menu a:hover {
text-decoration: none !important;
color: #333;
}

/* =================== entry-content ==================== */
.entry-content {
font-size: 110%;
line-height: 1.7;
padding-bottom: 10px;
border-bottom: 1px dotted #dddddd;
}
.entry-content p {
margin: 0 0 1em 0;
}
.entry-content img {
max-width: 100%;
}
.entry-content a {
border-bottom: 1px dotted #999;
}
.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;
}

/* ================ Headlines Design & ================== */
.entry-content h2 {
  position: relative;
  color: #fff;
  background: #c70032;
  padding: 15px 12px 12px 10px;
  margin-bottom: 26px;
  border-radius: 5px;
}
.entry-content h2 a {
  color: #fff;
}
.entry-content h2:after,.entry-content h2:before {
  content: "";
  position: absolute;
  top: 100%;
  height: 0;
  width: 0;
}
.entry-content h2:after {
  left: 33px;
  border: 11px solid transparent;
  border-top: 12px solid #c70032;
}
.entry-content h2:before {
  left: 30px;
  border: 14px solid transparent;
}
.entry-content h3 {
  background: #eee;
  border-left: 8px solid #c70032;
  padding: 9px 15px 8px 10px;
}
.entry-content h4 {
  border-left: 6px solid #c70032;
  padding: 3px 9px 2px 5px;
}
.entry-content strong {
  color: #000;
}
a.hatena-fotolife {
border: none;
}
.hatena-asin-detail, .itunes-embed {
border-radius: 5px;
}

/* ==================== entry-footer ==================== */
.entry-footer {
margin-top: 0;
}
.entry-footer-section {
margin-top: 3px;
font-size: 80%;
color: #999;
text-align: right;
}
.entry-footer-section a {
color: #999;
}
.social-buttons,
.entry-footer-html {
margin: 10px 0;
}

/* ====================================================== */

/*                         comment                        */

/* ====================================================== */
.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 dotted #ddd;
position: relative;
}
.comment-box li:first-child {
border-top: 1px dotted #ddd;
}
.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: #999;
margin: 0;
}
.comment-metadata a {
color: #999;
}
.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;
}

/* ====================== see-more ====================== */
.entry-see-more {
display: inline-block;
*display: inline;
*zoom: 1;
padding: 4px 22px 4px;
margin-bottom: 0;
line-height: 18px;
color: #fff !important;
background-color: #c70032;
text-align: center;
vertical-align: middle;
border-radius: 4px;
background-clip: padding-box;
cursor: pointer;
font-size: 12px;
text-decoration: none;
font-weight: bold;
text-decoration: none !important;
border-bottom: none !important;
}
.entry-see-more:hover {
color: #fff !important;
background-color: #de0020;
}

/* ====================================================== */

/*                         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%;
color: #666;
}
.hatena-module-title a {
color: #666;
text-decoration: none;
}

/* =================== 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: normal;
margin-bottom: 5px;
}
.hatena-module-profile .profile-description {
font-size: 90%;
}
.hatena-module-profile .profile-description p {
margin-top: 0;
}
.hatena-module-profile .id a {
color: #999;
}
.hatena-module-profile .id a:hover {
color: #333;
}

/* =================== urllist module =================== */
.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 #f2f2f2;
line-height: 1.5;
}
.hatena-urllist li a {
text-decoration: none;
}
a.recent-entries-title-link {
font-weight: bold;
color: #666;
}
a.recent-entries-title-link:hover {
color: #ccc;
}
.urllist-date-link a, .urllist-date-link a:visited,
.urllist-categories a, .urllist-categories a:visited {
color: #999;
}
.urllist-categories a {
border-bottom: 1px dotted #999;
}
.urllist-date-link a:hover,
.urllist-categories a:hover {
color: #333;
}
.urllist-entry-body {
color: #999;
}
.urllist-image {
border-radius: 5px;
}

/* ==================== 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%;
-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;
height: 20px;
width: 90%;
}
.hatena-module-search-box .search-module-button {
width: 20px;
height: 20px;
background: transparent 
url(https://cdn.blog.st-hatena.com/images/theme/search.png) 
no-repeat right center;
border: none;
outline: none;
text-indent: -9999px;
position: absolute;
top: 5px;
right: 5px;
opacity: 0.5;
filter: alpha(opacity=50);
}
.hatena-module-search-box .search-module-button:hover {
opacity: 0.85;
filter: alpha(opacity=85);
}

/* ====================== calendar ====================== */
.archive-module-calendar {
color: #666;
}
.archive-module-calendar table {
color: #999;
}
.archive-module-calendar table a {
color: #666;
text-decoration: underline;
}
.archive-module-calendar table a:hover {
color: #ccc;
}
.archive-module-calendar {
text-align: left !important;
}

/* ======================== 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: #999;
line-height: 1.5;
font-size: 80%;
}
#footer p {
margin: 0;
}
#footer a {
color: #999;
}

/* ======================= 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 0.5em;
border-left: 6px solid #c70032;
}
.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;
}
.page-archive .archive-entries .entry-title,
.page-archive .archive-entries .entry-title a,
.page-archive .archive-entries .archive-entry .date {
display: block;
}
.page-archive .archive-entries .entry-title a {
padding-top: 0.3em;
padding-bottom: 0.3em;
border-bottom: none;
}
.page-archive .archive-entries .archive-entry .date {
border-bottom: 1px solid #ddd;
margin: 15px 0;
}
.page-archive .archive-entries .categories {
position: static;
float: none;
font-size: 90%;
}
.page-archive .archive-entries .entry-description {
font-size: 90%;
}


/* ====================================================== */

/*                 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 - Smartphone & Tablet - Portrait === */
@media (max-width: 736px) ,
(min-width: 737px) and (max-width: 1024px) and 
(orientation:portrait) {
#globalheader-container {
position: static;
}
#container {
width: 93.75%;
word-wrap: break-word;
overflow: hidden;
padding-top: 10px;
}
.globalheader-off #container {
padding-top: 10px;
padding-bottom: 10px;
}
#main-inner {
padding: 20px;
padding-top: 2em;
}
#wrapper {
margin-bottom:25px;
}
.header-image-enable #blog-title #blog-title-inner,
.header-image-only #blog-title #blog-title-inner {
background-size:100% auto;
-moz-background-size:100% auto;
-webkit-background-size:100% auto;
-o-background-size:100% auto;
-ms-background-size:100% auto;
}
}

/* =========== Media Queries - Smartphone only ========== */
@media (max-width: 736px) {
#globalheader-container {
position: static;
}
#main-inner {
padding: 10px;
padding-top: 2em;
}
#box2 {
margin-bottom: 15px;
}
#box2-inner {
padding: 10px;
}
#wrapper {
margin-bottom:15px;
}
#bottom-editarea {
padding: 0 10px;
}
.header-image-enable #blog-title #blog-title-inner,
.header-image-only #blog-title #blog-title-inner,
#blog-title {
min-height: 110px;
background-position: center !important;
}
#blog-title-inner h1#title {
padding-top: 35px;
font-size: 180%;
}
h2#blog-description {
padding-bottom: 28px;
}
}

/* ======= Media Queries - Tablet - Portrait only ======= */
@media (min-width: 737px) and (max-width: 1024px) and 
(orientation:portrait) {
#container ,.globalheader-off #container {
padding-top: 20px;
padding-bottom: 20px;
}
#box2 {
margin-bottom: 25px;
}
#box2-inner {
padding: 20px;
}
#bottom-editarea {
padding: 0 20px;
}
.header-image-enable #blog-title #blog-title-inner,
.header-image-only #blog-title #blog-title-inner,
#blog-title {
min-height: 220px;
background-position: center !important;
}
#blog-title-inner h1#title {
padding-top: 72px;
font-size: 350%;
}
h2#blog-description {
padding-bottom: 65px;
}
.entry-content {
font-size: 130%;
}
}

/* ===========　Media Queries - PC & landscape ========== */
@media (min-width: 1025px) ,
(min-width: 737px) and (max-width: 1024px) and 
(orientation:landscape) {
#container {
width: 1024px;
padding-top: 62px;
}
.globalheader-off #container {
padding-top: 25px;
padding-bottom: 25px;
}
#container-inner {
width: 974px;
margin-left: auto;
margin-right: auto;
position:relative;
}
.header-image-enable #blog-title #blog-title-inner,
.header-image-only #blog-title #blog-title-inner,
#blog-title {
float: left;
width: 630px;
}
#blog-title {
min-height: 300px;
}
h1#title {
padding-top: 105px;
font-size: 350%;
}
h2#blog-description {
padding-bottom: 100px;
}
.header-image-enable #blog-title #blog-title-inner,
.header-image-only #blog-title #blog-title-inner {
min-height: 300px;
background-size:117.2% auto;
-moz-background-size:117.2% auto;
-webkit-background-size:117.2% auto;
-o-background-size:117.2% auto;
-ms-background-size:117.2% auto;
background-position: center !important;
}
#top-box,
#wrapper,
#top-editarea {
float: left;
width: 630px;
}
#box2 {
position: relative;
width: 320px;
top: 0;
margin-left:654px;
}
#main-inner {
padding: 15px;
padding-top: 3em;
width: 600px;
}
#box2-inner {
padding: 25px 10px 0 10px;
overflow: hidden;
zoom: 1;
}
#bottom-editarea {
width: 630px;
padding: 0 15px;
margin: 25px 0;
}
}

/* ====================================================== */

/*               icon web font "FontAwesome"              */

/* ====================================================== */
.entry-header div.date a:before,
.entry-header div.categories a:before,
.entry-header-menu a:before,
.entry-footer span.author:before,
time.updated:before,
.hatena-module-links .hatena-urllist li a:before {
font-family: FontAwesome;
font-weight: normal;
font-style: normal;
display: inline-block;
line-height: 1;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
.entry-header div.date a,
.entry-header div.categories a,
.entry-header-menu a,
.entry-footer span.author,
time.updated,
.hatena-module-links .hatena-urllist li a {
display: inline-block;
line-height: 1;
}
.entry-header div.date a:before {
content: "\f073";
}
.entry-header div.categories a:before {
font-size: 90%;
margin:0 2px 0 5px;
content: "\f02c";
}
.entry-header-menu a:before {
margin:0 2px 0 0;
content: "\f044";
}
.entry-footer span.author:before {
margin:0 2px 0 0;
content: "\f007";
}
time.updated:before {
margin:0 2px 0 10px;
content: "\f017";
}
.hatena-module-links .hatena-urllist li a:before {
margin:0 5px 0 5px;
content: "\f14c";
color: #999;
}

/* </system> */

body {
font: 16px/1.8 "Meiryo";
}

.entry-content h3 {
  padding: 4px 10px;
  background-color: #f0f0f0;
}

.entry-content h4 {
  padding: 4px 10px;
  border-left: solid 28px;
  border-bottom: 2px solid;
}

.table-of-contents:before {
  content: "目次";
  font-size: 150%;
  font-weight: bold;
}
.table-of-contents {
  box-shadow: 5px 5px 10px;
  border: 1px solid #999999;
  background: #f0f0f0;
}

.t_h {
 background: #cccccc;
}
.t_b {
 background: #cccccc;
}
.appended {
 background: #cccccc;
}

/*******************************
* 左からの吹き出し
********************************/
.left_balloon {
    position: relative;
    background: #fff;
    border: 1px solid #777;
    margin: 10px;
    padding: 10px;
    border-radius: 15px;
    margin-right: 20%;
    clear: both;
    max-width: 500px;
    float: left;
}
.left_balloon:after,
.left_balloon:before {
    right: 100%;
    top: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
}
.left_balloon:after {
    border-color: rgba(255, 255, 255, 0);
    border-right-color: #fff;
    border-width: 7px;
    margin-top: -7px;
}
.left_balloon:before {
    border-color: rgba(0, 0, 0, 0);
    border-right-color: #000;
    border-width: 8px;
    margin-top: -8px;
}
 
/*******************************
* 右からの吹き出し
********************************/
.right_balloon {
    position: relative;
    background: #85e249;
    border: 1px solid #777;
    margin: 10px;
    padding: 10px;
    border-radius: 15px;
    margin-left: 20%;
    clear: both;
    max-width: 500px;
    float: right;
}
.right_balloon:after,
.right_balloon:before {
    left: 100%;
    top: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
}
.right_balloon:after {
    border-color: rgba(133, 226, 73, 0);
    border-left-color: #85e249;
    border-width: 7px;
    margin-top: -7px;
}
.right_balloon:before {
    border-color: rgba(119, 119, 119, 0);
    border-left-color: #777;
    border-width: 8px;
    margin-top: -8px;
}
 
/*******************************
* 割り込みを解除
********************************/
.clear_balloon{
  clear: both;
}

/*カエレバ・ヨメレバ（PC版）*/
.kaerebalink-box, .booklink-box {
    border: 2px solid #CCCCCC;
    padding: 20px;
    width: 90%;
    max-width:680px;
    margin:0 auto;
}
.kaerebalink-image, .booklink-image {
    width:20%;
    float: left;
}
.kaerebalink-image a img,.booklink-image a img {
    width:100%;
}
.kaerebalink-info, .booklink-info {
    width:70%;
    margin-left: 2em;
    float: left;
}
.kaerebalink-name > a, .booklink-name > a {
    font-size: 16px;
    color: #256CC5;
    text-decoration: underline;
}
.kaerebalink-powered-date, .booklink-powered-date {
    font-size: 12px;
}
.kaerebalink-powered-date a, .booklink-powered-date a {
    color: #256CC5;
    text-decoration: underline;
}
.kaerebalink-link1, .booklink-link2 {
    margin-top: 1em;
}
.kaerebalink-link1 div, .booklink-link2 div {
    margin-right: 5px;
    margin-top:5px;
    margin-bottom:3px;
    text-align: center;
    float:left;
    width: 40%;
}
.kaerebalink-link1 div:active, .booklink-link2 div:active {
    border-top:3px solid #FFFFFF;
    margin-bottom: none;
    box-shadow:none;
}
.kaerebalink-link1 div a, .booklink-link2 div a {
    color: white;
    text-decoration: none;
    font-weight: bold;
    display:block;
    width: 100%;
    height: 40px;
    line-height: 40px;
}
.shoplinkamazon {
    background: #FF9900;
    box-shadow: 0 3px #B16A00;
}
.shoplinkamazon:hover {
    background: #FFB23F;
}
.shoplinkkindle {
    background: #0079BA;
    box-shadow: 0 3px #015684;
}
.shoplinkkindle:hover {
    background: #2797D4;
}
.shoplinkrakuten {
    background: #BF0000;
    box-shadow: 0 3px #7B0101;
}
.shoplinkrakuten:hover {
    background: #DC3939;
}
.shoplinkkakakucom {
    background: #25388E;
    box-shadow: 0 3px #081658;
}
.shoplinkkakakucom:hover {
    background: #485CB7;
}
.shoplinkyahoo {
    background: #750992;
    box-shadow: 0 3px #3F0250;
}
.shoplinkyahoo:hover {
    background: #8F0FB3;
}
.booklink-footer {
    height:0;
    clear: left;
}

.entry-content blockquote {
    position: relative;
    padding: 10px 12px;
    box-sizing: border-box;
    font-style: italic;
    color: #464646;
    border-left: solid 40px #c4c4c4;
    background: #f3f3f3;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.19);
}

.entry-content blockquote:before{
    display: inline-block;
    position: absolute;
    top: 50%;
    left: -48px;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    vertical-align: middle;
    content: "“";
    font-family: sans-serif;
    color: #FFF;
    font-size: 80px;
    line-height: 1;
}

.entry-content blockquote p {
    position: relative;
    padding: 0;
    margin: 10px 0;
    z-index: 3;
    line-height: 1.7;
}

.entry-content blockquote cite {
    display: block;
    text-align: right;
    color: #888888;
    font-size: 0.9em;
}

.center {text-align:center;}

/*****ここから会話の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: 180%;
 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: 180%;
 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%; 
 }
 }
 
 /*グローバルメニュー*/
#menu {
 position: relative;
 width: 100%;
 padding-left: 0px;
 height: 40px;
 background: #343838;/*グローバルメニュー背景色*/
}
.menu-inner{
 width: 968px;
 margin: 0 auto;
 height: 40px;
}
#menu li {
 list-style-type: none;
 float: left;
 height: 40px;
 text-align: left;
}
#menu li a {
 padding-left: 15px;
 padding-right: 15px;
 display: block;
 color: #ffffff;/*グローバルメニュー文字色*/
 font-size: 80%;
 font-weight: bold;
 line-height: 40px;
}
#menu li:hover a {
 color: #00DFFC;
 background: #ffffff;
 transition: all .5s;
}

.menu-toggle{
 display: none;
} 

/*パソコン１カラム*/
@media screen and (max-width:968px){
    .menu-inner{
        width: 768px;
    }
}

/*タブレット*/
@media screen and (max-width:768px){
 #top-editarea{
  height: initial;
  background: #343838;/*MENU背景色*/
  text-align: right;/*MENUの文字の位置*/
  width: 100%;
 }
 .menu-toggle{
  color: #ffffff;/*MENUの文字色*/
  display: inline-block;
  padding: 5px;
  margin: 3px;
 }
 #menu {
  width: 100%;
  display: none;
  height: initial;
  padding: 0;
  margin: 0;
  
 }
 .menu-inner{
  width: 100%;
  height: initial;
  position: static;
  margin: 0;
 }
 #menu li{
  float: none;
  height: 35px;
  width: 100%;
  list-style-type: none;
  background: #00DFFC;/*リスト文字の背景色*/
  margin: 0 auto;
  text-align: left;/*リストの文字の位置*/
 }
 #menu li a {
  height: initial;
  color: #343838;/*リスト文字色*/
  display: block;
 }
 #menu li:hover a{
  color: initial;
  background: initial;
 }
}

/*ナビゲーションメニュー*/
.nav>ul {
  padding: 0;
  margin: 0;
  width: 100%;
  margin-bottom: 30px;
  display: block;
  overflow: hidden;
}

.nav>ul>li {
  box-sizing: border-box;
  width: calc(100% / 4);
  height: 50px;
  line-height: 50px;
  background: linear-gradient(#1a1a1a, #676767, #1a1a1a);
  border-left: 1px solid white;
  color: white;
  float: left;
  list-style-type: none;
  text-align: center;
  position: relative;
  transition: box-shadow .3s ease-in-out;
}

.nav>ul>li:first-child() {
  border-left: 0;
}

.nav>ul>li:hover {
  box-shadow: 0 0 50px 25px #1a1a1a inset;
}

.nav>ul>li>a {
  color: white;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

/* ページトップへ戻るボタン */
#pagetop {
    position:fixed;
    bottom:10px;
    right:10px;
    padding:10px 20px;
    color:#fff;
    font-size:20px;
    text-decoration:none;
    background:#000;
}

/* ページトップへ戻るボタン：ホバー時 */
#pagetop:hover {
    background:#e74c3c;
}