@charset "UTF-8";
/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video, progress {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, progress {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

/**
 * CSS for pixpedia
 * 2011 pixiv, Inc.
 */
/* =basic
------------------------------------------------------------ */
body {
  margin: 0;
  padding: 0;
  min-width: 970px;
  font-family: arial, sans-serif;
  font-size: 12px;
  color: #333;
  background-color: #F2F2F2;
  position: relative;
  line-break: strict;
}

a {
  color: #007AB3;
  text-decoration: none;
}

a:hover {
  color: #00ADFF;
  text-decoration: underline;
}

img {
  vertical-align: middle;
  border: none;
}

ul, li {
  list-style: none;
}

/* =button リンクを立体的なボタンにする
------------------------------------------------------------ */
.button {
  padding: 9px;
  display: block;
  font-weight: bold;
  text-align: center;
  background: #E7E7E7 url("../images/module_more_button_bg.png") 0 0 repeat-x;
  border: 1px solid #DFDFDF;
  font-size: 14px;
  text-shadow: rgba(255, 255, 255, 0.75) 0 1px 0;
  -moz-border-radius: 3px;
  -webkit-border-radius: 3px;
  -o-border-radius: 3px;
  border-radius: 3px;
  color: #666;
}
.button.more_button {
  width: 100%;
}

.button:hover {
  color: #182738;
  cursor: pointer;
}

.button:active {
  border: 1px solid #aaa;
  color: #000;
}

/* =top ページヘッダー部分
------------------------------------------------------------ */
.top {
  border-bottom: 1px solid #fff;
}
.top_header {
  margin: 0;
  padding: 0;
  min-width: 700px;
  font-size: 13px;
  color: #fff;
  background: #263b54 url("../images/header_bg.png") 0 0 repeat-x;
  overflow: hidden;
  zoom: 1;
}
.top_header div {
  width: 970px;
  margin: 0 auto;
}
.top_header h1 {
  margin: 0;
  padding: 8px 0 11px;
  font-size: 12px;
  float: left;
}
.top_header #search {
  float: left;
  padding: 8px 16px;
}
.top_header #search .query {
  width: 234px;
  padding: 5px 6px;
  border: 1px solid #273d57;
  font-size: 13px;
  background: #4b74a5 url("../images/search_query_bg.png") 0 0 repeat-x;
  color: #345376;
  -webkit-appearance: none;
}
.top_header #search .query:focus {
  color: #fff;
  font-weight: bold;
  text-shadow: #253a53 0 1px 0;
  outline: none;
}
.top_header #search .query::-webkit-input-placeholder {
  color: #345376;
}
.top_header #search .query:-moz-placeholder {
  color: #345376;
}
.top_header #search .submit {
  width: 48px;
  height: 28px;
  padding: 0;
  border: none;
  cursor: pointer;
  text-indent: -9999px;
  background: transparent url("../images/search_submit_en.png") 0 0 no-repeat;
}
.top_header #search .ja {
  background: transparent url("../images/search_submit_en.png") 0 0 no-repeat;
}
.top_header #search .en {
  width: 58px;
}
.top_header nav {
  float: right;
}
@media (max-width: 970px) {
  .top_header nav {
    padding-right: 10px;
  }
}
.top_header nav a,
.top_header nav a:visited {
  color: #fff;
}
.top_header nav a:hover {
  color: #00ADFF;
  text-decoration: none;
}
.top_header nav li {
  font-size: 14px;
  font-weight: bold;
  float: left;
  padding: 17px 12px 0 10px;
  text-shadow: #253a53 0 1px 0;
  background: transparent url("../images/top_nav_separater.png") right 17px no-repeat;
}
.top_header nav .profile-image {
  margin: 12px 0 0 0;
  padding: 0;
  background-image: none;
  background-color: white;
  width: 24px;
  text-align: center;
  overflow: hidden;
}
.top_header nav .profile-image img {
  height: 24px;
}
.top_header nav #login,
.top_header nav #logout {
  padding-right: 0;
  background-image: none;
}
.top .header {
  margin: 0;
  padding: 0;
  min-width: 970px;
  min-height: 64px;
  font-size: 13px;
  color: #fff;
  background: #314e6f;
}
.top .header_box {
  height: 64px;
  margin: 0;
  padding: 0 24px;
  display: flex;
  align-items: center;
  color: #fff;
  background: #314e6f;
}
.top .header_box h1 {
  margin: 0;
  font-size: 12px;
  width: 261px;
}
.top .header_box h1 img {
  height: 32px;
}
.top .header_box #search {
  padding: 0 16px;
  max-width: 528px;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}
@media (max-width: 1159px) {
  .top .header_box #search {
    margin-right: 64px;
    margin-left: 64px;
  }
}
.top .header_box #search .search-box {
  background-color: white;
  border-radius: 4px;
  width: 528px;
  height: 40px;
  margin-right: auto;
  margin-left: auto;
  position: relative;
}
@media (max-width: 1367px) {
  .top .header_box #search .search-box {
    width: 400px;
  }
}
@media (max-width: 1159px) {
  .top .header_box #search .search-box {
    width: 100%;
  }
}
@media (max-width: 951px) {
  .top .header_box #search .search-box {
    margin-right: auto;
    margin-left: auto;
  }
}
.top .header_box #search .search-icon {
  position: absolute;
  top: 52%;
  left: 11px;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  z-index: 1;
}
.top .header_box #search input {
  border: none;
  box-sizing: border-box;
  outline: none;
  font-family: inherit;
  transform-origin: top left;
  -webkit-transform: scale(0.875);
  -ms-transform: scale(0.875);
  transform: scale(0.875);
  width: 114.2857142857%;
  height: 114.2857142857%;
  font-size: 16px;
  line-height: 25.1428571429px;
  padding-left: 36.5714285714px;
  padding-right: 9.1428571429px;
  border-radius: 4.5714285714px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: rgba(0, 0, 0, 0.04);
  color: #474747;
  -webkit-transition: 0.2s background-color, 0.2s box-shadow;
  transition: 0.2s background-color, 0.2s box-shadow;
}
.top .header_box ul {
  margin-left: auto;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  margin-left: auto;
  -webkit-align-items: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 16px;
}
.top .header_box ul a,
.top .header_box ul a:visited {
  color: #fff;
}
.top .header_box ul a:hover {
  color: #00ADFF;
  text-decoration: none;
}
.top .header_box ul .profile-nav {
  display: flex;
  align-items: center;
  gap: 16px;
}
.top .header_box ul .article-post a {
  width: min-content;
  display: inline-grid;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  color: #ffffff;
  background-color: #0096fa;
  font-size: 14px;
  line-height: 22px;
  font-weight: bold;
  padding-right: 24px;
  padding-left: 24px;
  border-radius: 999999px;
  -webkit-transition: 0.2s color, 0.2s background-color, 0.2s box-shadow;
  transition: 0.2s color, 0.2s background-color, 0.2s box-shadow;
  height: 40px;
}
.top .header_box ul .profile-image {
  padding: 0;
  background-image: none;
  background-color: white;
  text-align: center;
  overflow: hidden;
  border-radius: 999999px;
}
.top .header_box ul .profile-image img {
  width: 40px;
  aspect-ratio: auto 40/40;
  height: 40px;
  border-radius: 999999px;
  object-fit: cover;
}
.top .header_box ul #register {
  white-space: nowrap;
}
.top .header_box ul #register,
.top .header_box ul #login,
.top .header_box ul #logout {
  padding-right: 0;
  background-image: none;
  font-size: 14px;
  font-weight: bold;
  color: white;
}
.top .header_box ul #register button,
.top .header_box ul #login button,
.top .header_box ul #logout button {
  white-space: nowrap;
  cursor: pointer;
}
.top #news {
  background: #fff;
  border-bottom: 1px solid #d9d9d9;
}
.top #news #news_content {
  width: 970px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  padding: 5px 0;
  gap: 16px;
}
.top #news #news_content #news_link a {
  font-weight: bold;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.top #news #news_content #news_close {
  cursor: pointer;
}
.top #infobar {
  background: #fff;
  border-bottom: 1px solid #d9d9d9;
  overflow: hidden;
  zoom: 1;
}
.top #infobar .topic {
  width: 970px;
  margin: 0 auto;
  padding: 5px 0;
  overflow: hidden;
  zoom: 1;
}
.top #infobar .topic .hot {
  display: block;
  float: left;
  padding: 3px 4px;
  font-size: 10px;
  font-weight: normal;
  color: #fff;
  background-color: #FBAA4B;
  -moz-border-radius: 2px;
  -webkit-border-radius: 2px;
  -o-border-radius: 2px;
  border-radius: 2px;
}
.top #infobar .topic ul {
  float: left;
  margin: 3px 0 0 5px;
}
.top #infobar .topic li {
  float: left;
  margin: 0 6px 0;
}
.top #infobar .message {
  margin: 5px auto;
  padding: 15px 0px;
  text-align: center;
  font-weight: bold;
  font-size: 16px;
  color: #fff;
  background-color: #007AB3;
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  -o-border-radius: 5px;
  border-radius: 5px;
}
.top #infobar .error {
  margin: 5px auto;
  padding: 15px 0px;
  text-align: center;
  font-weight: bold;
  font-size: 16px;
  color: #fff;
  background-color: #F66;
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  -o-border-radius: 5px;
  border-radius: 5px;
}
.top #infobar #biron {
  width: 970px;
  margin: 0 auto;
  padding: 0;
  position: relative;
}
.top #infobar #biron .close {
  bottom: 5px !important;
}
.top #infobar .facebook-biron {
  width: 870px !important;
  padding: 14px 0 14px 100px !important;
  background: #FFF url("../images/biron_facebook.png") 0 center no-repeat;
}
.top #infobar .facebook-biron .box {
  padding: 10px;
  width: 460px;
  border: 1px solid #007AB3;
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  -o-border-radius: 5px;
  border-radius: 5px;
}
.top #infobar .introductionforenglish {
  width: 870px !important;
  padding: 55px 0 5px 77px !important;
  background: #FFF url("../images/biron_gateway_en.png") 0 center no-repeat;
}
.top #infobar .introductionforenglish .box {
  padding: 10px 0;
  font-size: 15px;
  line-height: 1.1;
}
.top #infobar .searchengine {
  width: 400px !important;
  padding: 30px 0 30px 570px !important;
  background: #FFF url("../images/biron_searchengine.png?20110728") 15px center no-repeat;
}
.top #infobar .searchengine .box {
  padding: 10px;
  width: 320px;
  border: 1px solid #007AB3;
  background-color: #f5f5f5;
  border: 1px solid #DDD;
  -moz-border-radius: 3px;
  -webkit-border-radius: 3px;
  -o-border-radius: 3px;
  border-radius: 3px;
  overflow: hidden;
  zoom: 1;
}
.top #infobar .searchengine .box li {
  margin-right: 10px;
}
.top #infobar .searchengine .box .twitter {
  margin-right: 15px;
}

/* =breadcrumbs パンくずリスト・カテゴリーリスト
------------------------------------------------------------ */
#categories,
.pagebar {
  width: 970px;
  margin: 10px auto;
  border-top: 1px solid #b5b5b5;
  border-bottom: 1px solid #fcfcfc;
  background-color: #e6e6e6;
  -moz-border-radius: 4px;
  -webkit-border-radius: 4px;
  -o-border-radius: 4px;
  border-radius: 4px;
  clear: both;
}

#categories {
  margin: 10px auto 5px;
}
#categories ul {
  padding: 8px;
  text-align: center;
  letter-spacing: -0.25em;
}
#categories li {
  display: inline-block;
  *display: inline;
  zoom: 1;
  letter-spacing: normal;
  font-size: 13px;
  padding: 0px 12px 0 10px;
  text-shadow: #fff 0 1px 0;
  background: transparent url("../images/categories_separater.png") right 0 no-repeat;
}
#categories li:last-child {
  background-image: none;
}
#categories .current {
  padding: 0px 3px 0px 0px;
}
#categories .current a {
  background-color: #007AB3;
  color: white;
  padding: 3px 8px;
  -moz-border-radius: 2px;
  -webkit-border-radius: 2px;
  -o-border-radius: 2px;
  border-radius: 2px;
  text-shadow: rgba(0, 0, 0, 0.25) 0 -1px 0;
}

#page-index #categories {
  margin: 10px auto;
}

#breadcrumbs {
  width: 970px;
  margin: 5px auto 0px;
  padding: 8px 0 3px;
  overflow: hidden;
  zoom: 1;
}
#breadcrumbs div {
  float: left;
  font-size: 13px;
  margin-bottom: 10px;
  padding: 0px 15px 0 10px;
  text-shadow: #fff 0 1px 0;
  background: transparent url("../images/breadcrumbs_separater.png") right 0 no-repeat;
}
#breadcrumbs .current {
  font-weight: bold;
  background-image: none;
}

.pagebar {
  padding: 0px 0;
  overflow: hidden;
  zoom: 1;
}
.pagebar h2 {
  font-size: 16px;
  padding: 8px 8px;
  float: left;
}
.pagebar ul {
  padding: 4px 0px;
  float: right;
}
.pagebar ul li {
  float: left;
  margin-right: 5px;
}
.pagebar ul li .confirm {
  width: 78px;
  height: 28px;
  padding: 0;
  border: none;
  cursor: pointer;
  text-indent: -9999px;
  background: transparent url("../images/form_button_confirm_en.png") 0 0 no-repeat;
  display: block;
}
.pagebar ul li .cancel {
  width: 78px;
  height: 28px;
  padding: 0;
  border: none;
  cursor: pointer;
  text-indent: -9999px;
  background: transparent url("../images/form_button_cancel_en.png") 0 0 no-repeat;
  display: block;
}
.pagebar ul li .post {
  width: 90px;
  height: 28px;
  padding: 0;
  border: none;
  cursor: pointer;
  text-indent: -9999px;
  background: transparent url("../images/form_button_post_en.png") 0 0 no-repeat;
  display: block;
}
.pagebar ul li .back {
  width: 105px;
  height: 28px;
  padding: 0;
  border: none;
  cursor: pointer;
  text-indent: -9999px;
  background: transparent url("../images/form_button_back_en.png") 0 0 no-repeat;
  display: block;
}

/* =content ページのメインコンテンツ部分
------------------------------------------------------------ */
#content {
  margin: 0 auto;
  padding: 0;
  width: 970px;
  overflow: hidden;
  zoom: 1;
  position: relative;
}

#main {
  width: 654px;
  float: left;
}
#main #topics {
  border-bottom: 3px solid #9fc54e;
  margin-bottom: 3px;
  overflow: hidden;
  zoom: 1;
}
#main #topics li {
  display: inline;
}
#main #topics li a {
  display: block;
  float: left;
  margin: 0 2px 0 0;
  padding: 9px 18px 7px;
  border: 1px solid #B2D46A;
  background: #c4c5c5 url("../images/top_topics_tab_bg.png?20120131") 0 0 repeat-x;
  font-size: 14px;
  font-weight: bold;
  color: #fff;
  text-shadow: rgba(0, 0, 0, 0.25) 0 1px 0;
}
#main #topics li a:hover {
  background: #c4c5c5 url("../images/top_topics_tab_bg.png?20120131") 0 -40px repeat-x;
  text-decoration: none;
}
#main #topics li a.special {
  padding-right: 72px;
  background: #739dd1 url("../images/top_topics_special_tab_bg.png") right top no-repeat;
  border-color: #739DD1;
}
#main #topics li a.special:hover {
  background: #739dd1 url("../images/top_topics_special_tab_bg.png") right -45px no-repeat;
  border-color: #739DD1;
}
#main #topics li a.current {
  border: 1px solid #9fc54e;
  background-image: none;
  background-color: #9fc54e;
}
#main #topics li a.special.current {
  background: #739dd1 url("../images/top_topics_special_tab_bg.png") right -90px no-repeat;
  border-color: #4E82C5;
}
#main #topics li a.hot {
  background: #FBBC71;
  border-color: #FBAA4B;
}
#main #topics li a.hot:hover {
  background: #FBAA4B;
  border-color: #FBAA4B;
}
#main #topics li a.hot.current {
  background: #FBAA4B;
  border-color: #FBAA4B;
}
#main #topics.special {
  border-bottom: 3px solid #4E82C5;
}
#main #topics.hot {
  border-bottom: 3px solid #FBAA4B;
}
#main #search-title {
  border-bottom: 3px solid #9fc54e;
  margin-bottom: 3px;
  overflow: hidden;
  zoom: 1;
}
#main #search-title h1 {
  float: left;
  padding: 9px 18px 7px;
  border: 1px solid #9fc54e;
  background-color: #9fc54e;
  font-size: 14px;
  font-weight: bold;
  color: #fff;
  text-shadow: rgba(0, 0, 0, 0.25) 0 1px 0;
}
#main #search-title .info {
  padding: 10px 5px 0 0;
  float: right;
  font-size: 13px;
  font-weight: bold;
  color: #4D4D4D;
}
#main .subtopic {
  background-color: #f9f9f9;
  overflow: hidden;
  zoom: 1;
}
#main .subtopic li {
  float: left;
  display: block;
  width: 141px;
  padding: 10px;
  border-left: 1px solid #F2F2F2;
  text-align: center;
  font-size: 14px;
}
#main .subtopic li:first-child {
  border: none;
}
#main .subtopic li.current-sub {
  background-color: #fff;
}
#main .subtopic.hidden {
  display: none;
}
#main article {
  margin-bottom: 3px;
  padding: 18px;
  background-color: #fff;
  overflow: hidden;
  zoom: 1;
}
#main article .thumb {
  width: 128px;
  height: 128px;
  padding: 1px;
  margin-right: 15px;
  float: left;
  overflow: hidden;
  vertical-align: middle;
  line-height: 127px;
  border: 1px solid #E6E6E6;
}
#main article .thumb img {
  width: 128px;
}
#main article .thumb:hover {
  border-color: #007AB3;
}
#main article .info {
  width: 470px;
  float: left;
}
#main article .info h2 {
  margin-bottom: 10px;
  font-size: 18px;
}
#main article .info .summary {
  line-height: 1.5;
  padding: 0 0 8px 0;
  font-size: 14px;
}
#main article .info .data {
  padding: 0 0 8px 0;
}
#main article .info .data li {
  display: inline-block;
  *display: inline;
  zoom: 1;
  padding: 0px 3px 0 0;
  color: #999;
}
#main article .info .relation {
  overflow: hidden;
  zoom: 1;
  padding: 0 0 0px 0;
}
#main article .info .relation span {
  display: block;
  float: left;
  margin-right: 5px;
  padding: 3px 3px;
  font-size: 10px;
  font-weight: normal;
  color: #fff;
  background-color: #999;
  -moz-border-radius: 2px;
  -webkit-border-radius: 2px;
  -o-border-radius: 2px;
  border-radius: 2px;
}
#main article .info .relation ul {
  float: left;
  width: 435px;
  height: 18px;
}
#main article .info .relation li {
  display: inline-block;
  *display: inline;
  zoom: 1;
  padding: 3px 3px;
}
#main footer .more {
  display: block;
  width: 654px;
  height: 38px;
  text-indent: -9999px;
  background: transparent url("../images/top_more_en.png") 0 0 no-repeat;
}
#main footer .more:hover {
  background: transparent url("../images/top_more_en.png") 0 -38px no-repeat;
}

/* =box-module サイドバーやマイページのボックスモジュール
------------------------------------------------------------ */
.box-module {
  margin-bottom: 10px;
  background-color: #fff;
}
.box-module h2 {
  padding: 6px 10px;
  color: #fff;
  border: 1px solid #375579;
  background-color: #476F9E;
  text-shadow: rgba(0, 0, 0, 0.25) 0 1px 0;
}
.box-module .body {
  padding: 5px;
  border: 1px solid #D9D9D9;
}
.box-module .items li {
  margin-bottom: 5px;
  padding: 5px;
  font-size: 10px;
  color: #aaa;
  clear: both;
  overflow: hidden;
  zoom: 1;
}
.box-module .items li a {
  font-size: 13px;
  font-weight: bold;
  line-height: 1.5;
}
.box-module .items li img {
  width: 32px;
  height: 32px;
  margin-right: 5px;
  border: 1px solid #E6E6E6;
  vertical-align: top;
  float: left;
}
.box-module .items li .info {
  float: left;
}
.box-module .items li .info a {
  display: block;
}
.box-module .items li .data {
  float: right;
  text-align: right;
  line-height: 1.5;
}
.box-module .items li .data button {
  display: block;
  font-size: 12px;
  margin-left: auto;
}
.box-module .items li:hover {
  background-color: #eee;
}
.box-module .thread-items {
  padding: 5px 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.box-module .thread-items li {
  padding: 0 4px;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 5px;
  font-size: 10px;
  color: #aaa;
}
.box-module .thread-items li .thread-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.box-module .thread-items li .thread-info .link-title {
  font-size: 12px;
  font-weight: bold;
  line-height: 20px;
  word-break: break-all;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}
.box-module .thread-items li .thread-info .article {
  display: flex;
}
.box-module .thread-items li .thread-info .article span {
  flex-shrink: 0;
  font-size: 10px;
  line-height: 10px;
  color: #ABABAB;
}
.box-module .thread-items li .thread-info .article a {
  font-size: 10px;
  line-height: 10px;
  width: 100%;
  display: inline-block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.box-module .thread-items li .thread-data {
  flex-shrink: 0;
  line-height: 10px;
  font-size: 10px;
  color: #ABABAB;
}
.box-module .thread-items li .thread-data .thread-uncheck {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.box-module .thread-items li .thread-data .thread-uncheck button {
  display: block;
  font-size: 12px;
  margin-left: auto;
}
.box-module .thread-items li:hover {
  background-color: #eee;
}

/* =sub 共通サイドバー
------------------------------------------------------------ */
#sub {
  width: 300px;
  margin-top: 15px;
  margin-left: 15px;
}
#sub section {
  margin-bottom: 10px;
  background-color: #fff;
}
#sub h2 {
  padding: 6px 10px;
  color: #fff;
  text-shadow: rgba(0, 0, 0, 0.25) 0 1px 0;
}
#sub .ranking h2 {
  border: 1px solid #FBAA4B;
  background-color: #FBBC71;
}
#sub .ranking nav {
  border-right: 1px solid #D9D9D9;
  border-left: 1px solid #D9D9D9;
}
#sub .ranking nav ul {
  overflow: hidden;
  zoom: 1;
}
#sub .ranking nav li {
  display: inline;
}
#sub .ranking nav li a {
  display: block;
  float: left;
  width: 148px;
  padding: 10px 0;
  border-right: 1px solid #D9D9D9;
  border-bottom: 1px solid #D9D9D9;
  background-color: #EBEBEB;
  text-align: center;
  font-size: 13px;
  font-weight: bold;
  color: #999;
}
#sub .ranking nav li a:hover {
  background-color: #f0f0f0;
  color: #333;
}
#sub .ranking nav li .active {
  border-bottom: none;
  background-color: #fff;
  color: #FBB05A;
}
#sub .ranking nav li a.active:hover {
  background-color: #fff;
  color: #FBB05A;
}
#sub .ranking nav li:last-child a {
  width: 148px;
  border-right: none;
}
#sub .ranking ul.ranking {
  border: 1px solid #D9D9D9;
  border-top: none;
  clear: both;
  list-style-type: none;
  padding: 10px;
}
#sub .ranking ul.ranking li {
  padding: 3px 0;
  font-size: 13px;
  font-weight: bold;
  color: #FBB05A;
}
#sub .ranking ul.ranking li img {
  width: 32px;
  height: 32px;
  margin-right: 5px;
  border: 1px solid #E6E6E6;
}
#sub .ranking ul.ranking a:hover img {
  border-color: #007AB3;
}
#sub .ranking ol {
  border: 1px solid #D9D9D9;
  border-top: none;
  clear: both;
  list-style-type: none;
  padding: 10px;
}
#sub .ranking ol li {
  padding: 3px 0;
  font-size: 13px;
  font-weight: bold;
  color: #FBB05A;
}
#sub .ranking ol li img {
  width: 32px;
  height: 32px;
  margin-right: 5px;
  border: 1px solid #E6E6E6;
}
#sub .ranking ol a:hover img {
  border-color: #007AB3;
}
#sub .ranking #ranking-monthly {
  display: none;
}
#sub .spotlight h2 {
  border: 1px solid #edd70c;
  background-color: #F8E71C;
  color: black;
  font-size: 13px;
}
#sub .spotlight ul.items i.thumbnail {
  display: block;
  float: left;
  border: 1px solid #E6E6E6;
  background-size: cover;
  width: 32px;
  height: 32px;
  margin-right: 5px;
}
#sub .updated h2 {
  border: 1px solid #398cbd;
  background-color: #5f9abd;
}
#sub .created h2 {
  border: 1px solid #48b2ef;
  background-color: #78c3ef;
}
#sub .items {
  padding: 5px;
  border: 1px solid #D9D9D9;
}
#sub .items li {
  padding: 5px;
  font-size: 10px;
  clear: both;
  overflow: hidden;
  zoom: 1;
  color: #aaa;
}
#sub .items li a {
  font-size: 13px;
  font-weight: bold;
  line-height: 1.5;
}
#sub .items li a span {
  display: inline-block;
  width: 80%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
#sub .items li img {
  width: 32px;
  height: 32px;
  margin-right: 5px;
  border: 1px solid #E6E6E6;
  vertical-align: top;
  float: left;
}
#sub .items li a:hover img {
  border-color: #007AB3;
}

#page-index #sub,
#page-mypage #sub {
  margin-top: 0px;
}

/* =footer フッター
------------------------------------------------------------ */
#page-footer {
  margin: 60px 0 0;
  text-align: left;
  color: #fff;
  position: relative;
}
#page-footer a {
  color: #fff;
  text-shadow: rgba(0, 0, 0, 0.25) 0 -1px 0;
}
#page-footer a:hover {
  color: #00ADFF;
  text-shadow: rgba(0, 0, 0, 0.25) 0 1px 0;
}
#page-footer nav {
  padding: 5px;
  border-top: 1px solid #0D8CA3;
  background: #0FA2BD;
}
#page-footer nav ul {
  width: 970px;
  margin: 10px auto;
}
#page-footer nav li {
  display: inline-block;
  *display: inline;
  zoom: 1;
  padding: 0 10px 0 0;
}
#page-footer nav a:hover {
  color: #333;
  text-shadow: rgba(255, 255, 255, 0.75) 0 1px 0;
}
#page-footer .pixiv {
  padding: 10px;
  background: #0d0035;
}
#page-footer .pixiv span {
  display: block;
  width: 970px;
  margin: 0 auto;
}
#page-footer #back-to-top {
  position: absolute;
  top: -26px;
  width: 100%;
}
#page-footer #back-to-top div {
  width: 970px;
  margin: 0 auto;
  position: relative;
}
#page-footer #back-to-top div img {
  position: absolute;
  right: 10px;
}

/* =article 記事ページ
------------------------------------------------------------ */
#page-article #content header, #page-article-confirm #content header {
  margin-bottom: 2px;
  padding: 15px;
  background-color: #fff;
  font-size: 14px;
  display: flex;
}
#page-article #content header .embedimage .info, #page-article-confirm #content header .embedimage .info {
  position: absolute;
  bottom: 0px;
  left: 0px;
  width: 224px;
  padding: 10px 10px;
  line-height: 1.2;
  background-color: #007AB3;
  text-align: left;
  color: #91BBD0;
  font-size: 12px;
  display: none;
}
#page-article #content header .embedimage .info h3, #page-article-confirm #content header .embedimage .info h3 {
  margin-bottom: 3px;
  font-size: 15px;
}
#page-article #content header .embedimage .info a, #page-article-confirm #content header .embedimage .info a {
  color: #fff;
}
#page-article #content header .embedimage .info a:hover, #page-article-confirm #content header .embedimage .info a:hover {
  color: #68B8FF;
  text-shadow: rgba(0, 0, 0, 0.25) 0 1px 0;
}
#page-article #content header #main-image, #page-article-confirm #content header #main-image {
  width: 240px;
  height: 240px;
  padding: 2px;
  margin-right: 15px;
  border: 1px solid #E6E6E6;
  line-height: 239px;
  text-align: center;
  vertical-align: top;
  position: relative;
}
#page-article #content header #main-image img, #page-article-confirm #content header #main-image img {
  width: 240px;
  max-height: 240px;
  object-fit: cover;
  object-position: top;
}
#page-article #content header #main-image.embedimage:hover, #page-article-confirm #content header #main-image.embedimage:hover {
  border: 1px solid #007AB3;
}
#page-article #content header #article-name, #page-article-confirm #content header #article-name {
  font-size: 30px;
  font-weight: bold;
  margin-top: 2px;
  margin-bottom: 14px;
  color: #000;
}
#page-article #content header .subscript, #page-article-confirm #content header .subscript {
  color: #666;
  font-size: 12px;
  font-weight: bold;
  margin-bottom: 14px;
}
#page-article #content header .summary, #page-article #content header .link-to-pixiv, #page-article-confirm #content header .summary, #page-article-confirm #content header .link-to-pixiv {
  line-height: 1.6;
  font-size: 15px !important;
  padding: 0 !important;
}
#page-article #content header .summary .button, #page-article #content header .link-to-pixiv .button, #page-article-confirm #content header .summary .button, #page-article-confirm #content header .link-to-pixiv .button {
  width: 120px !important;
}
#page-article #content #main, #page-article-confirm #content #main {
  width: 654px;
  margin-bottom: 15px;
  float: left;
  color: #333;
}

/* =article-body 記事本文
------------------------------------------------------------ */
#article-body {
  margin-bottom: 2px;
  padding: 15px;
  background-color: #FFF;
  font-size: 14px;
  line-height: 1.75;
  overflow: hidden;
  zoom: 1;
}
#article-body a.no-article {
  color: #b3005d;
}
#article-body a.no-article:hover {
  color: #830044;
}
#article-body a.external-link {
  background-image: url("https://s.pximg.net/source/dic/images/external-link.png");
  background-position: center right;
  background-repeat: no-repeat;
  background-size: auto 70%;
  padding-right: 13px;
}
#article-body .article_index {
  border: solid 2px #E6E6E6;
  padding: 5px;
  margin-bottom: 10px;
  float: left;
  font-size: 14px;
}
#article-body .article_index .index_title {
  padding: 5px 10px;
}
#article-body .article_index .index_title span {
  font-weight: bold;
  font-size: 14px;
  margin-right: 5px;
}
#article-body .article_index .index_title .toggle_index {
  font-size: 12px;
}
#article-body .article_index .index_level1 {
  margin-left: 5px;
}
#article-body .article_index .index_level2 {
  margin-left: 15px;
}
#article-body .article_index .index_level3 {
  margin-left: 25px;
}
#article-body h1 {
  font-size: 30px;
  font-weight: bold;
}
#article-body h2 {
  margin: 0px 0 15px;
  padding: 10px 0 5px;
  font-size: 20px;
  min-height: 24px;
  line-height: 24px;
  color: #000;
  border-bottom: 2px solid #E6E6E6;
  clear: both;
}
#article-body h3 {
  margin: 0 0 13px;
  padding: 0 0;
  font-size: 16px;
  min-height: 24px;
  line-height: 24px;
  color: #000;
}
#article-body h4 {
  margin: 0 0 13px;
  padding: 0 0;
  font-size: 14px;
  min-height: 24px;
  line-height: 24px;
  color: #000;
}
#article-body h2 > span,
#article-body h3 > span,
#article-body h4 > span {
  padding: 2px 0;
  line-height: 24px;
  vertical-align: middle;
  margin-right: 8px;
}
#article-body h2 > .link_edit_partial,
#article-body h3 > .link_edit_partial,
#article-body h4 > .link_edit_partial {
  display: inline-block;
}
#article-body p {
  padding: 0 1px 1em;
}
#article-body br {
  clear: both;
}
#article-body ul li {
  margin: 10px 0;
  padding: 0px 0 0px 30px;
  background: transparent url("../images/list_style.png") 10px 4px no-repeat;
  line-height: 1.6;
  font-size: 14px;
}
#article-body ul li ul li {
  padding: 0px 0 0px 15px;
  background: transparent url("../images/list_style2.png") 0px 4px no-repeat;
}
#article-body ol li {
  margin: 10px 0 10px 30px;
  padding: 0px 0 0px 0px;
  line-height: 1.6;
  font-size: 14px;
  list-style-type: decimal;
}
#article-body .sensitiveimage {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 240px;
  height: 240px;
  padding: 0px;
  margin: 0 2px 4px 2px;
  border: 1px solid #E6E6E6;
  overflow: hidden;
  float: left;
  position: relative;
}
#article-body .embedimage {
  display: inline-block;
  justify-content: center;
  align-items: center;
  width: 240px;
  height: 240px;
  padding: 0px;
  margin: 0 2px 4px 2px;
  border: 1px solid #E6E6E6;
  overflow: hidden;
  text-align: center;
  vertical-align: top;
  float: left;
  position: relative;
  cursor: pointer;
}
#article-body .embedimage .info {
  position: absolute;
  bottom: 0px;
  left: 0px;
  width: 286px;
  padding: 10px 10px;
  line-height: 1.2;
  background-color: #007AB3;
  text-align: left;
  color: #91BBD0;
  font-size: 12px;
  display: none;
}
#article-body .embedimage .info h3 {
  margin-bottom: 3px;
  font-size: 15px;
}
#article-body .embedimage .info a {
  color: #fff;
}
#article-body .embedimage .info a:hover {
  color: #68B8FF;
  text-shadow: rgba(0, 0, 0, 0.25) 0 1px 0;
}
#article-body .embedimage:hover {
  border: 1px solid #007AB3;
}
#article-body .no-image {
  display: flex;
  justify-content: center;
  align-items: center;
  float: left;
  margin: 0 2px 4px 2px;
  width: 240px;
  height: 240px;
  border: 1px solid #E6E6E6;
  text-align: center;
}
#article-body .small {
  width: 150px;
  height: 150px;
  line-height: 148px;
  margin: 0 2px 2px 0px;
}
#article-body .small.no-image {
  width: 152px;
  height: 152px;
  border: none;
}
#article-body .small.no-image > img {
  width: 100%;
}
#article-body .small.sensitiveimage {
  margin-top: 1px;
}
#article-body .small .info {
  width: 144px;
  padding: 5px;
  font-size: 11px;
}
#article-body .small .info h3 {
  margin-bottom: 2px;
  font-size: 12px;
}
#article-body .small .info a {
  color: #fff;
}
#article-body .small .info a:hover {
  color: #68B8FF;
}
#article-body .embednovel {
  position: relative;
  z-index: 0;
  display: flex;
  align-items: stretch;
  flex-shrink: 0;
  height: 100%;
  margin-left: 8px;
  margin-right: 8px;
  width: 484px;
}
#article-body .embednovel a {
  text-decoration: none;
}
#article-body .embednovel .background-link {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 1;
}
#article-body .embednovel .cover {
  display: block;
  width: 80px;
  margin-right: 16px;
  z-index: 10;
}
#article-body .embednovel .cover img {
  display: block;
  width: 80px;
  height: 112px;
  border-radius: 8px;
  object-fit: cover;
  object-position: center;
}
#article-body .embednovel .details {
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  z-index: 10;
  min-width: 0;
  pointer-events: none;
}
#article-body .embednovel .details a {
  pointer-events: auto;
}
#article-body .embednovel .details .series_title {
  display: inline-block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 100%;
  font-size: 14px;
  line-height: 22px;
  color: rgba(0, 0, 0, 0.32);
}
#article-body .embednovel .details .title {
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-all;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  max-width: 100%;
  font-size: 14px;
  line-height: 22px;
  color: inherit;
}
#article-body .embednovel .details .author {
  display: inline-flex;
  align-items: center;
}
#article-body .embednovel .details .author img {
  width: 16px;
  height: 16px;
  border-radius: 50%;
}
#article-body .embednovel .details .author .name {
  margin-left: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  line-height: 20px;
  color: rgba(0, 0, 0, 0.64);
}
#article-body .embednovel .details .embednovel_caption {
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-all;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  font-size: 14px;
  line-height: 22px;
  color: rgba(0, 0, 0, 0.64);
}
#article-body .embednovel .details .footer {
  font-size: 12px;
  line-height: 20px;
  color: rgba(0, 0, 0, 0.32);
  display: flex;
  align-items: center;
}
#article-body .embednovel .details .footer .num_characters {
  margin-right: 8px;
}
#article-body .embednovel .details .footer .arrow_top_right {
  position: relative;
}
#article-body .embednovel .details .footer .arrow_top_right::before {
  content: "";
  position: absolute;
  top: 0;
  right: -17px;
  width: 8px;
  height: 8px;
  border-top: 3px solid rgba(0, 0, 0, 0.32);
  border-right: 3px solid rgba(0, 0, 0, 0.32);
}
#article-body .embednovel .details .footer .arrow_top_right::after {
  content: "";
  position: absolute;
  top: 6px;
  right: -16px;
  width: 13px;
  height: 3px;
  background: rgba(0, 0, 0, 0.32);
  transform: rotate(135deg);
}
#article-body table {
  margin-bottom: 1em;
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
  border: 1px solid #ddd;
  line-height: 1.5;
}
#article-body th,
#article-body td {
  padding: 5px;
}
#article-body th {
  border: 1px solid #ddd;
  text-align: left;
  vertical-align: top;
  background-color: #f3f3f3;
  white-space: nowrap;
}
#article-body td {
  border: 1px solid #ddd;
}
#article-body .sample {
  margin: 2em 0 0.5em;
  padding: 5px;
  background-color: #eee;
  border: 1px solid #ccc;
  color: #333;
}

/* バルーン
------------------------------------------------------------ */
.balloon {
  display: none;
  position: absolute;
  background-color: #0096FA;
  color: #fff;
  padding: 16px;
  border-radius: 16px;
  border: 2px solid #fff;
  max-width: 320px;
  box-sizing: border-box;
}
.balloon .balloon_arrow {
  position: absolute;
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-top: 8px solid #0096FA;
  top: -8px;
  transform: translateX(-50%) rotate(180deg);
}
.balloon .balloon_content {
  display: flex;
  font-size: 14px;
  font-weight: bold;
}
.balloon .balloon_content .text {
  width: 100%;
  margin-right: 8px;
  line-height: 22px;
}
.balloon .balloon_content .icon {
  cursor: pointer;
}
.balloon .balloon_content .icon:hover path {
  fill: #f5f5f5;
}

/* ツールチップ
------------------------------------------------------------ */
.tooltip {
  position: absolute;
  background: rgba(0, 0, 0, 0.8784313725);
  color: #FFFFFF;
  font-size: 12px;
  line-height: 20px;
  padding: 4px 12px;
  border-radius: 4px;
  opacity: 0;
  transition: opacity 0.2s;
  pointer-events: none;
  transform: translateY(-8px);
  max-width: 184px;
}
.tooltip.show {
  opacity: 1;
}

/* =report-problem 通報画面
------------------------------------------------------------ */
.report-problem {
  display: none;
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.32);
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center;
  overflow-y: auto;
  background: rgba(0, 0, 0, 0.3215686275);
  z-index: 300;
}
.report-problem_box {
  display: flex;
  margin: auto;
  padding-top: 40px;
  padding-bottom: 40px;
}
.report-problem_modal {
  position: relative;
  background-color: #fff;
  height: 100%;
  max-height: 802px;
  width: 80vw;
  max-width: 480px;
  border-radius: 24px;
}
.report-problem_modal .header {
  margin-top: 20px;
}
.report-problem_modal .header_title {
  font-style: normal;
  font-weight: 700;
  font-size: 16px;
  line-height: 24px;
  text-align: center;
}
.report-problem_modal .header_close {
  cursor: pointer;
  position: absolute;
  top: 17px;
  right: 17px;
}
.report-problem_modal .report {
  padding: 0px 24px 40px;
  background: #fff;
  border-radius: 0 0 24px 24px;
}
.report-problem_modal .report_box {
  margin-top: 20px;
  position: relative;
}
.report-problem_modal .report_title {
  margin: 20px auto 5px;
  font-style: normal;
  font-weight: 700;
  font-size: 14px;
  line-height: 22px;
  color: #1F1F1F;
  text-align: center;
}
.report-problem_modal .report select {
  margin-top: 5px;
  width: 100%;
  font-style: normal;
  font-weight: 400;
  font-size: 14px;
  color: #474747;
  background: rgba(0, 0, 0, 0.04);
  border-radius: 4px;
  border: none;
  height: 40px;
  padding: 8px;
}
.report-problem_modal .report textarea {
  resize: none;
  margin-top: 5px;
  padding: 8px;
  font-style: normal;
  font-weight: 400;
  font-size: 14px;
  background: rgba(0, 0, 0, 0.04);
  border-radius: 4px;
  border: none;
  min-height: 100px;
  max-height: 260px;
  height: 25vh;
  width: 100%;
  width: -webkit-fill-available;
}
.report-problem_modal .report_counter {
  position: absolute;
  right: 18px;
  bottom: 10px;
  color: #858585;
}
.report-problem_modal .report .description {
  padding: 12px 16px;
  border-radius: 4px;
  background: #F5F5F5;
}
.report-problem_modal .report_description {
  display: flex;
  justify-content: flex-start;
}
.report-problem_modal .report_description img {
  margin-top: 3px;
  height: 100%;
}
.report-problem_modal .report_description p {
  margin-left: 10px;
  font-size: 14px;
  font-weight: 400;
  line-height: 22px;
  letter-spacing: 0em;
  text-align: left;
  color: #858585;
}
.report-problem_modal .report_description p span {
  display: block;
  font-size: 14px;
  font-weight: 700;
  line-height: 22px;
  letter-spacing: 0em;
  text-align: left;
  color: #1F1F1F;
}
.report-problem_modal .report_action {
  margin-top: 40px;
}
.report-problem_modal .report_action_send {
  cursor: pointer;
  background: #0096FA;
  border-radius: 20px;
  height: 40px;
  width: 100%;
  border: initial;
  padding: 9px 24px;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
}
.report-problem_modal .report_action_send:hover {
  opacity: 0.7;
}
.report-problem_modal .report_action_cancel {
  cursor: pointer;
  margin-top: 8px;
  background: rgba(0, 0, 0, 0.04);
  border-radius: 20px;
  height: 40px;
  width: 100%;
  border: initial;
  padding: 9px 24px;
  font-size: 14px;
  font-weight: 700;
  color: #474747;
}
.report-problem_modal .report_action_cancel:hover {
  opacity: 0.7;
}
.report-problem_send {
  display: none;
  flex-direction: column;
  align-items: center;
  position: relative;
  background-color: #fff;
  width: 336px;
  border-radius: 24px;
  padding: 64px 0 40px;
}
.report-problem_send_close {
  position: absolute;
  top: 17px;
  right: 17px;
  cursor: pointer;
}
.report-problem_send_icon {
  display: flex;
  align-items: center;
  margin-bottom: 12px;
  height: 48px;
}
.report-problem_send_content {
  margin-bottom: 36px;
  font-style: normal;
  font-weight: 700;
  font-size: 16px;
  line-height: 24px;
}
.report-problem_send_cancel {
  cursor: pointer;
  background: rgba(0, 0, 0, 0.04);
  border-radius: 20px;
  height: 40px;
  width: 288px;
  border: initial;
  padding: 9px 24px;
  color: #474747;
  font-weight: bold;
}
.report-problem_send_cancel:hover {
  opacity: 0.7;
}

/* =feedback フィードバック画面
------------------------------------------------------------ */
.feedback {
  display: none;
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.32);
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center;
  overflow-y: auto;
  background: rgba(0, 0, 0, 0.3215686275);
  z-index: 300;
}
.feedback_box {
  display: flex;
  margin: auto;
  padding-top: 40px;
  padding-bottom: 40px;
  font-family: arial, sans-serif;
}
.feedback_modal {
  position: relative;
  background-color: #fff;
  height: 100%;
  width: 90vw;
  max-width: 440px;
  border-radius: 24px;
}
.feedback_modal .header {
  margin-top: 20px;
  margin-bottom: 40px;
}
.feedback_modal .header_title {
  font-style: normal;
  font-weight: 700;
  font-size: 16px;
  line-height: 24px;
  text-align: center;
}
.feedback_modal .header_close {
  cursor: pointer;
  position: absolute;
  top: 17px;
  right: 17px;
}
.feedback_modal .feedback-content {
  padding: 0px 24px 40px;
  background: #fff;
  border-radius: 0 0 24px 24px;
}
.feedback_modal .feedback-content_head {
  margin: 0px 0px 20px;
  line-height: 22px;
  font-size: 14px;
  color: rgb(92, 92, 92);
}
.feedback_modal .feedback-content_box {
  margin-top: 20px;
  position: relative;
}
.feedback_modal .feedback-content_box .annotation-txt {
  font-size: 14px;
  line-height: 22px;
  display: flow-root;
  margin-top: 4px;
  margin-bottom: 0px;
  color: #1f1f1f;
}
.feedback_modal .feedback-content_box .error-txt {
  font-size: 14px;
  line-height: 22px;
  display: flow-root;
  margin-top: 4px;
  margin-bottom: 0px;
  color: #ff2b00;
}
.feedback_modal .feedback-content_title {
  margin: 20px auto 5px;
  font-style: normal;
  font-weight: 700;
  font-size: 14px;
  line-height: 22px;
  color: #1f1f1f;
  text-align: center;
}
.feedback_modal .feedback-content_title span {
  display: inline;
  font-size: 14px;
  line-height: 22px;
  font-weight: 100;
}
.feedback_modal .feedback-content select {
  margin-top: 4px;
  width: 100%;
  font-style: normal;
  font-weight: 400;
  font-size: 14px;
  font-family: arial, sans-serif;
  color: #474747;
  background: rgba(0, 0, 0, 0.04);
  border-radius: 4px;
  border: none;
  height: 40px;
  padding: 8px;
  outline: none;
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: url("../images/select_box_menu_icon.svg");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 10px 8px;
}
.feedback_modal .feedback-content select:focus {
  box-shadow: rgba(0, 150, 250, 0.32) 0 0 0 4px;
}
.feedback_modal .feedback-content input {
  margin-top: 4px;
  font-style: normal;
  font-weight: 400;
  font-size: 14px;
  color: #474747;
  background: rgba(0, 0, 0, 0.04);
  border-radius: 4px;
  border: none;
  height: 24px;
  width: 100%;
  width: -webkit-fill-available;
  padding: 8px;
  outline: none;
  -webkit-transition: 0.2s background-color, 0.2s box-shadow;
  transition: 0.2s background-color, 0.2s box-shadow;
}
.feedback_modal .feedback-content input::-webkit-input-placeholder {
  color: #858585;
}
.feedback_modal .feedback-content input::-moz-placeholder {
  color: #858585;
}
.feedback_modal .feedback-content input::placeholder {
  color: #858585;
}
.feedback_modal .feedback-content input:focus {
  box-shadow: rgba(0, 150, 250, 0.32) 0 0 0 4px;
}
.feedback_modal .feedback-content input.error {
  box-shadow: rgba(255, 43, 0, 0.32) 0px 0px 0px 4px;
}
.feedback_modal .feedback-content input:hover {
  background-color: rgba(0, 0, 0, 0.0784);
}
.feedback_modal .feedback-content textarea {
  resize: none;
  margin-top: 5px;
  padding: 8px;
  font-style: normal;
  font-weight: 400;
  font-size: 14px;
  font-family: arial, sans-serif;
  line-height: 22px;
  color: #474747;
  background: rgba(0, 0, 0, 0.04);
  border-radius: 4px;
  border: none;
  height: 25vh;
  width: 100%;
  width: -webkit-fill-available;
  height: 132px;
  outline: none;
  -webkit-transition: 0.2s background-color, 0.2s box-shadow;
  transition: 0.2s background-color, 0.2s box-shadow;
}
.feedback_modal .feedback-content textarea::-webkit-input-placeholder {
  color: #858585;
}
.feedback_modal .feedback-content textarea::-moz-placeholder {
  color: #858585;
}
.feedback_modal .feedback-content textarea::placeholder {
  color: #858585;
}
.feedback_modal .feedback-content textarea:focus {
  box-shadow: rgba(0, 150, 250, 0.32) 0 0 0 4px;
}
.feedback_modal .feedback-content textarea.error {
  box-shadow: rgba(255, 43, 0, 0.32) 0px 0px 0px 4px;
}
.feedback_modal .feedback-content textarea:hover {
  background-color: rgba(0, 0, 0, 0.0784);
}
.feedback_modal .feedback-content .description {
  padding: 12px 16px;
  border-radius: 4px;
  background: #f5f5f5;
}
.feedback_modal .feedback-content .description .bold {
  display: inline;
  font-weight: bold;
  color: rgb(71, 71, 71);
}
.feedback_modal .feedback-content .description .help {
  color: rgb(61, 118, 153);
  text-decoration: none;
}
.feedback_modal .feedback-content_description {
  display: flex;
  justify-content: flex-start;
}
.feedback_modal .feedback-content_description img {
  margin-top: 3px;
  height: 100%;
}
.feedback_modal .feedback-content_description p {
  margin-left: 4px;
  font-size: 14px;
  font-weight: 400;
  line-height: 22px;
  letter-spacing: 0em;
  text-align: left;
  color: #474747;
  letter-spacing: -0.4px !important;
}
.feedback_modal .feedback-content_description p span {
  display: block;
  font-size: 14px;
  font-weight: 700;
  line-height: 22px;
  letter-spacing: -0.4px !important;
  letter-spacing: 0em;
  text-align: left;
  color: #1f1f1f;
}
.feedback_modal .feedback-content .kind {
  margin-top: 36px;
}
.feedback_modal .feedback-content .bug {
  display: none;
  margin-top: 20px;
  margin-bottom: -2px;
}
.feedback_modal .feedback-content .bug.timing {
  margin-top: 22px;
}
.feedback_modal .feedback-content .content {
  margin-top: 20px;
}
.feedback_modal .feedback-content_action {
  margin-top: 36px;
}
.feedback_modal .feedback-content_action_send {
  cursor: pointer;
  background: #0096fa;
  border-radius: 20px;
  height: 40px;
  width: 100%;
  border: initial;
  padding: 9px 24px;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
}
.feedback_modal .feedback-content_action_send:hover {
  opacity: 0.7;
}
.feedback_modal .feedback-content_action_cancel {
  cursor: pointer;
  margin-top: 8px;
  background: rgba(0, 0, 0, 0.04);
  border-radius: 20px;
  height: 40px;
  width: 100%;
  border: initial;
  padding: 9px 24px;
  font-size: 14px;
  font-weight: 700;
  color: #474747;
}
.feedback_modal .feedback-content_action_cancel:hover {
  opacity: 0.7;
}
.feedback_send {
  display: none;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  position: relative;
  background-color: #fff;
  padding: 40px 24px;
  border-radius: 24px;
  font-family: arial, sans-serif;
}
.feedback_send_close {
  position: absolute;
  top: 17px;
  right: 17px;
  cursor: pointer;
}
.feedback_send_icon {
  margin-top: 30px;
  margin-bottom: 20px;
}
.feedback_send_title {
  margin-bottom: 30px;
  font-style: normal;
  font-weight: 700;
  font-size: 16px;
  line-height: 24px;
}
.feedback_send_content {
  width: 256px;
  margin-bottom: 34px;
  font-style: normal;
  font-size: 14px;
  color: #474747;
  line-height: 22px;
  text-align: center;
}
.feedback_send_cancel {
  font-size: 14px;
  cursor: pointer;
  background: rgba(0, 0, 0, 0.04);
  border-radius: 20px;
  height: 40px;
  width: 288px;
  border: initial;
  padding: 9px 24px;
  color: #474747;
  font-weight: bold;
}
.feedback_send_cancel:hover {
  opacity: 0.7;
}

/* 告知ダイアログ
------------------------------------------------------------ */
.notice-dialog {
  display: flex;
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.32);
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center;
  overflow-y: auto;
  background: rgba(0, 0, 0, 0.3215686275);
  z-index: 300;
}
.notice-dialog_box {
  display: flex;
  margin: auto;
}
.notice-dialog_modal {
  position: relative;
  background-image: url("../images/dialog_new.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-color: #fff;
  height: 290px;
  width: 392px;
  padding: 186px 24px 40px;
  border-radius: 8px;
}
.notice-dialog_modal .close {
  cursor: pointer;
  position: absolute;
  top: 17px;
  right: 17px;
}
.notice-dialog_modal .content {
  padding: 36px 16px;
}
.notice-dialog_modal .content_title {
  font-style: normal;
  font-weight: 700;
  font-size: 16px;
  line-height: 24px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  color: #1F1F1F;
}
.notice-dialog_modal .content_desc {
  margin-top: 32px;
  font-style: normal;
  font-weight: 400;
  font-size: 14px;
  line-height: 22px;
  text-align: center;
  color: #474747;
}
.notice-dialog_modal .action_link {
  cursor: pointer;
  background: rgba(0, 0, 0, 0.04);
  border-radius: 20px;
  height: 40px;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  border: initial;
  font-size: 14px;
  font-weight: 700;
  color: #474747;
}
.notice-dialog_modal .action_link:hover {
  opacity: 0.7;
}
.notice-dialog_modal .action_cancel {
  cursor: pointer;
  margin-top: 8px;
  background: #0096FA;
  border-radius: 20px;
  height: 40px;
  width: 100%;
  border: initial;
  padding: 9px 24px;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
}
.notice-dialog_modal .action_cancel:hover {
  opacity: 0.7;
}

/* =additional-content 記事に追加される要素(関連イラスト・ニュース、コメントなど)
------------------------------------------------------------ */
.additional-content h2 {
  padding: 10px 15px;
  font-size: 16px;
  text-shadow: rgba(255, 255, 255, 0.75) 0 1px 0;
  border-top: 1px solid #d5d5d6;
  border-bottom: 1px solid #c0c0c1;
  background: #dcdddd url("../images/article_header_bg.png") 0 0 repeat-x;
  position: relative;
}
.additional-content h2 a,
.additional-content h2 .total-count {
  display: block;
  font-size: 12px;
  position: absolute;
  right: 8px;
  top: 14px;
  text-align: right;
}
.additional-content #article_relation_images {
  padding: 25px 0px 12px 42px;
  background: #212121 url("../images/article_relation_images_bg.png") 0 bottom no-repeat;
}
.additional-content #article_relation_images ul {
  overflow: hidden;
  zoom: 1;
}
.additional-content #article_relation_images .embedimage {
  float: left;
  margin: 0 14px 14px 0;
  border: 2px solid #212121;
  overflow: hidden;
  position: relative;
}
.additional-content #article_relation_images .embedimage img {
  width: 128px;
  height: 128px;
}
.additional-content #article_relation_images .embedimage .info {
  position: absolute;
  bottom: 0px;
  left: 0px;
  width: 118px;
  padding: 5px;
  line-height: 1.2;
  background-color: #007AB3;
  text-align: left;
  color: #91BBD0;
  font-size: 11px;
  display: none;
}
.additional-content #article_relation_images .embedimage .info h3 {
  margin-bottom: 2px;
  font-size: 12px;
}
.additional-content #article_relation_images .embedimage .info a {
  color: #fff;
}
.additional-content #article_relation_images .embedimage .info a:hover {
  color: #68B8FF;
  text-shadow: rgba(0, 0, 0, 0.25) 0 1px 0;
}
.additional-content #article_relation_images .embedimage:hover {
  border: 2px solid #007AB3;
}
.additional-content #article_relation_novels {
  padding: 25px 0px 12px 42px;
  background: #212121 url("../images/article_relation_images_bg.png") 0 bottom no-repeat;
}
.additional-content #article_relation_novels ul {
  overflow: hidden;
  zoom: 1;
}
.additional-content #article_relation_novels .embedimage {
  float: left;
  margin: 2px 16px 16px 2px;
  overflow: hidden;
  position: relative;
}
.additional-content #article_relation_novels .embedimage a.novel {
  width: 128px;
  display: block;
  text-align: center;
}
.additional-content #article_relation_novels .embedimage img {
  width: 91px;
  height: 128px;
  object-fit: cover;
  object-position: center;
}
.additional-content #article_relation_novels .embedimage .info {
  position: absolute;
  bottom: 0px;
  left: 0px;
  height: 112px;
  width: 112px;
  padding: 8px;
  line-height: 1.2;
  background-color: #007AB3;
  text-align: left;
  color: #91BBD0;
  font-size: 11px;
  display: none;
  cursor: pointer;
}
.additional-content #article_relation_novels .embedimage .info a {
  color: #fff;
}
.additional-content #article_relation_novels .embedimage .info a:hover {
  color: #68B8FF;
  text-shadow: rgba(0, 0, 0, 0.25) 0 1px 0;
}
.additional-content #article_relation_novels .embedimage .info .comment-container {
  height: 98px;
}
.additional-content #article_relation_novels .embedimage .info .comment {
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-all;
  font-size: 12px;
  line-height: 14px;
  -webkit-box-orient: vertical;
}
.additional-content #article_relation_novels .embedimage .info .comment a:hover {
  color: #fff;
  text-shadow: none;
  text-decoration: none;
}
.additional-content #article_relation_novels .embedimage .info .author {
  margin-top: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.additional-content #article_relation_novels .embedimage:hover {
  outline: 2px solid #007AB3;
}
.additional-content #comments {
  padding: 15px;
  background-color: #FFF;
}
.additional-content #comments article-comments #comment-box img {
  max-width: 48px;
  height: 48px;
  padding-right: 13px;
  float: left;
}
.additional-content #comments article-comments #comment-box .body {
  width: 552px;
  float: left;
}
.additional-content #comments article-comments #comment-box .body textarea {
  width: 100%;
  height: 4em;
  margin: 0;
  padding: 5px;
  font-size: 14px;
  border: 1px solid #d9d9d9;
  border-top: 1px solid #bfbfbf;
  background: #fff url("../images/form_textarea_bg.png") 0 0 repeat-x;
}
.additional-content #comments article-comments #comment-box .body textarea:focus {
  outline: none;
}
.additional-content #comments article-comments #comment-box .body textarea::-webkit-input-placeholder {
  color: #345376;
}
.additional-content #comments article-comments #comment-box .body textarea:-moz-placeholder {
  color: #345376;
}
.additional-content #comments article-comments #comment-box div.submit {
  padding: 3px 0 5px;
  clear: both;
  text-align: right;
}
.additional-content #comments article-comments #comment-box input.submit {
  width: 75px;
  height: 26px;
  padding: 0;
  border: none;
  cursor: pointer;
  text-indent: -9999px;
  background: transparent url("../images/comment_write_en.png") 0 0 no-repeat;
}
.additional-content #comments article-comments #comment-box .ja {
  background: transparent url("../images/comment_write_en.png") 0 0 no-repeat;
}
.additional-content #comments article-comments article {
  padding: 10px 0;
  border-top: 1px solid #E6E6E6;
  overflow: hidden;
  zoom: 1;
}
.additional-content #comments article-comments article img {
  max-width: 48px;
  height: 48px;
  margin-right: 10px;
  float: left;
}
.additional-content #comments article-comments article .body {
  width: 566px;
  float: left;
  line-height: 1.5;
  font-size: 14px;
}
.additional-content #comments article-comments article .body span {
  float: right;
  color: #aaa;
}
.additional-content #comments article-comments article .body div {
  padding: 0px 0 0 0;
}
.additional-content #comments article-comments footer .more {
  width: 624px;
  margin-top: 5px;
}
.additional-content #comments article-comments footer .ja {
  background-image: url("../images/comment_more_en.png");
}
.additional-content.relation {
  background: #fff;
}
.additional-content.relation h2 {
  margin-bottom: 5px;
}
.additional-content.relation h3 {
  font-size: 13px;
  margin-top: 13px;
  margin-bottom: 2px;
}
.additional-content.relation h3, .additional-content.relation .items, .additional-content.relation .relation-more-button {
  margin-left: 15px;
  margin-right: 15px;
}
.additional-content.relation .items {
  display: flex;
  flex-wrap: wrap;
}
.additional-content.relation .items > * {
  box-sizing: border-box;
  display: flex;
  flex: 50%;
  font-size: 12px;
  padding: 2px;
}
.additional-content.relation .items > * > .info {
  text-overflow: ellipsis;
  white-space: nowrap;
}
.additional-content.relation .items > * > .info > a {
  font-size: 16px;
  margin-bottom: 5px;
}
.additional-content.relation .items > * img {
  width: 40px;
}
.additional-content.relation .relation-more-button {
  display: block;
  padding: 4px;
}

/* =sub-contents
------------------------------------------------------------ */
#sub-contents {
  width: 316px;
  float: right;
}

.relation {
  padding-bottom: 5px;
}
.relation h3 {
  font-weight: normal;
  color: #666;
}
.relation img {
  margin-right: 8px;
  border: 1px solid #E6E6E6;
}
.relation img:hover {
  border-color: #007AB3;
}
.relation .relation-more-button {
  cursor: pointer;
}
.relation .info {
  color: #808080;
}
.relation .info > a {
  color: #007AB3;
  display: block;
  font-weight: bold;
}
.relation > .items > [aria-hidden=true] {
  display: none;
}

/* =article-relation 関連記事などのサイドバー要素
------------------------------------------------------------ */
#article-relation {
  width: 314px;
  margin-left: 2px;
}
#article-relation .actions,
#article-relation section {
  padding: 15px;
  background-color: #FFF;
  margin-bottom: 2px;
}
#article-relation .actions .title-box,
#article-relation section .title-box {
  display: flex;
  justify-content: flex-start;
}
#article-relation .actions .title-box h3,
#article-relation section .title-box h3 {
  margin-right: 10px;
}
#article-relation h2 {
  margin-bottom: 13px;
  font-size: 16px;
}
#article-relation section ul {
  overflow: hidden;
  zoom: 1;
}
#article-relation section ul li {
  padding-right: 1em;
  float: left;
}
#article-relation section ul li a {
  font-weight: bold;
}
#article-relation .actions .updates,
#article-relation .actions .edit {
  padding: 0 0px 0px 0px;
}
#article-relation .actions .updates dl,
#article-relation .actions .edit dl {
  margin-bottom: 0px;
  padding-left: 3px;
  overflow: hidden;
  zoom: 1;
}
#article-relation .actions .updates dt,
#article-relation .actions .edit dt {
  float: left;
  padding-right: 0.5em;
}
#article-relation .actions .updates dd,
#article-relation .actions .edit dd {
  float: left;
  padding-right: 1em;
}
#article-relation .actions .updates ul,
#article-relation .actions .edit ul {
  overflow: hidden;
  zoom: 1;
}
#article-relation .actions .updates li,
#article-relation .actions .edit li {
  padding: 0 2px;
  font-size: 16px;
  font-weight: bold;
  float: left;
}
#article-relation .actions .updates li .button,
#article-relation .actions .edit li .button {
  padding: 5px 27px 9px;
  -moz-border-radius: 4px;
  -webkit-border-radius: 4px;
  -o-border-radius: 4px;
  border-radius: 4px;
}
#article-relation .actions .updates li img,
#article-relation .actions .edit li img {
  width: 19px;
  height: 19px;
  margin-right: 0px;
  vertical-align: bottom;
}
#article-relation .actions .report {
  display: block;
  margin: 15px auto 0;
  text-align: center;
  font-style: normal;
  font-weight: 400;
  font-size: 14px;
  line-height: 16px;
  color: #007AB3;
  cursor: pointer;
  background-color: transparent;
  border: none;
  outline: none;
  padding: 0;
  appearance: none;
}
#article-relation .actions .report:hover {
  text-decoration: underline;
}
#article-relation .actions .data {
  padding: 0 2px;
}
#article-relation .actions .data ul {
  overflow: hidden;
  zoom: 1;
}
#article-relation .actions .data li {
  margin-right: 0.75em;
  padding-right: 1em;
  padding-bottom: 10px;
  padding-left: 2px;
  font-size: 14px;
  font-weight: bold;
  background: transparent url("../images/article_action_separater.png") right 0 no-repeat;
  float: left;
}
#article-relation .actions .data li img {
  height: 16px;
  margin-right: 2px;
}
#article-relation .actions .data li:last-child {
  margin-right: 0;
  padding-right: 0;
  background-image: none;
}
#article-relation .actions .data .checklist {
  line-height: 28px;
  padding-left: 0;
}
#article-relation .actions .data .checklist a {
  display: block;
  width: 157px;
  height: 28px;
  padding: 0;
  border: none;
  text-indent: -9999px;
  background: transparent url("../images/checklist_button_en.png") 0 0 no-repeat;
  float: left;
  margin-right: 8px;
}
#article-relation .actions .data .checklist a:hover {
  background-position: 0 -28px;
}
#article-relation .actions .data .checklist a:active {
  background-position: 0 -56px;
}
#article-relation .actions .data .checklist a.checked {
  background-position: 0 -84px;
}
#article-relation .actions .data .checklist a.checked:hover {
  background-position: 0 -112px;
}
#article-relation .actions .data .checklist a.checked:active {
  background-position: 0 -140px;
}
#article-relation .relation h3 {
  clear: both;
  margin: 10px 0;
  font-size: 12px;
}
#article-relation .relation .items li {
  margin-bottom: 10px;
  padding-right: 0;
  float: none;
  clear: both;
  overflow: hidden;
  zoom: 1;
}
#article-relation .relation .parent {
  margin-bottom: 20px;
  overflow: hidden;
  zoom: 1;
}
#article-relation .relation img {
  vertical-align: top;
  float: left;
}
#article-relation .relation .info {
  float: right;
  width: 210px;
  font-size: 10px;
  line-height: 1.4;
}
#article-relation .relation .info a {
  margin-bottom: 5px;
  font-size: 12px;
}
#article-relation .relation img {
  width: 64px;
  height: 64px;
}
#article-relation .relation .info {
  width: 210px;
}
#article-relation .relation-more-button {
  float: right;
}
#article-relation .pixivision-article-section {
  background-color: #f8e71c;
}
#article-relation .pixivision-article-section a {
  color: #fff;
}
#article-relation .pixivision-article-section .section-heading-pchan {
  height: 25px;
  width: auto;
  margin-bottom: -5px;
}
#article-relation .pixivision-article {
  background: #333;
  letter-spacing: 0;
  min-height: 66px;
}
#article-relation .pixivision-article::after {
  content: "";
  display: block;
  clear: both;
  visibility: hidden;
}
#article-relation .pixivision-article .thumbnail-container {
  float: left;
  overflow: hidden;
  width: 66px;
  height: 66px;
  background-size: cover;
  background-position: center top;
}
#article-relation .pixivision-article .title-container {
  float: right;
  width: 202px;
  height: 45px;
  padding: 10px 8px 0;
  line-height: 1.3em;
  font-size: 12px;
  font-weight: bold;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

/* amazon aws
------------------------------------------------------------ */
#amazon-aws-outer {
  background-color: #F4FAFE;
  border: 1px solid #C9E1F4;
  -moz-border-radius: 10px;
  -webkit-border-radius: 10px;
  -o-border-radius: 10px;
  border-radius: 10px;
}
#amazon-aws-outer h2 {
  border: none;
  margin: 0 12px 0;
  padding: 10px 0 5px;
  font-size: 20px;
  line-height: 1.3;
  color: black;
  clear: both;
}
#amazon-aws-outer .button {
  margin: 0 10px 10px;
}

ul#amazon-aws {
  position: relative;
  list-style-type: none;
  padding: 0 0 22px;
}
ul#amazon-aws:after {
  position: absolute;
  bottom: 6px;
  right: 6px;
  font-size: 10px;
  color: gray;
  content: "PR - Amazon.co.jp -";
}
ul#amazon-aws .info {
  font-size: 10px;
  color: gray;
  line-height: 16px;
}
ul#amazon-aws .info .title {
  padding: 0;
  color: #007AB3;
  display: block;
  margin-bottom: 5px;
  font-size: 12px;
  font-weight: bold;
  line-hieght: 19px;
}
ul#amazon-aws li {
  display: block;
  margin: 6px 19px;
  padding: 0;
  background: none;
  width: 169px;
  float: left;
}
ul#amazon-aws li .amazonimage {
  width: 160px;
  height: 160px;
  padding: 0px;
  margin: 1px;
  overflow: hidden;
  text-align: center;
  vertical-align: top;
  line-height: 126px;
  position: relative;
  cursor: pointer;
}
ul#amazon-aws li .amazonimage img {
  vertical-align: middle;
  border: none;
}
ul#amazon-aws li:hover img {
  border-color: #007AB3;
}
ul#amazon-aws li:hover .title {
  color: #00ADFF;
}

.ads section {
  background-color: #ffffff;
  padding: 13px 15px 13px;
}
.ads footer {
  margin-top: 0;
}

.d_header {
  height: 90px;
  margin-bottom: 4px;
  text-align: center;
}
.d_header > * {
  margin: auto;
}

.d_header_not_spa {
  height: 90px;
  margin-bottom: 4px;
  text-align: center;
}
.d_header_not_spa > * {
  margin: auto;
}

#article-body #amazon-aws-outer {
  margin-top: 14px;
}

/* =illust-detail
------------------------------------------------------------ */
.illust-detail {
  width: 600px;
  border: 2px solid #007AB3;
  background-color: #000;
  color: #fff;
}
.illust-detail .image {
  width: 600px;
  height: 600px;
  padding: 0px;
  text-align: center;
  line-height: 598px;
  cursor: pointer;
}
.illust-detail .description {
  padding: 10px;
  background-color: #007AB3;
  line-height: 1.5;
  background-color: #007AB3;
  text-align: left;
  color: #182738;
  font-size: 12px;
}
.illust-detail .description h3 {
  margin-bottom: 2px;
  font-size: 15px;
}
.illust-detail .description a {
  color: #fff;
}
.illust-detail .description a:hover {
  color: #68B8FF;
  text-shadow: rgba(0, 0, 0, 0.25) 0 1px 0;
}
.illust-detail .description .caption {
  margin-top: 3px;
  clear: both;
}
.illust-detail .description .button {
  float: right;
  padding: 3px 10px;
  font-size: 13px;
  border: none;
  color: #007AB3;
}
.illust-detail .description .button:hover {
  color: #182738;
  border: none;
}
.illust-detail .description .button:active {
  margin-top: 1px;
  border: none;
  color: #000;
}

.lb_overlay {
  cursor: pointer;
}

/* =page-mypage マイページ
------------------------------------------------------------ */
#page-mypage #main .box-module {
  margin-bottom: 10px;
  background-color: #fff;
}
#page-mypage #main .show-ads-form {
  padding: 30px 20px;
}
#page-mypage #main .ui-setting-form {
  padding: 30px 20px;
  align-items: normal !important;
}
#page-mypage #main .sprites-premium {
  background-image: url("../images/premium.png");
  background-repeat: no-repeat;
  display: inline-block;
  height: 20px;
  width: 17px;
  vertical-align: middle;
}
#page-mypage #main .setting-form {
  display: flex;
  flex-direction: row;
  align-items: baseline;
}
#page-mypage #main .setting-form .setting-title {
  font-weight: bold;
  width: 100px;
}
#page-mypage #main .setting-form .setting-title-ui {
  font-weight: bold;
}
#page-mypage #main .setting-form .setting-content {
  display: flex;
  flex-direction: column;
  margin-left: 20px;
}
#page-mypage #main .setting-form .setting-content .setting-selector label > input {
  margin: 0 6px 5px 0;
}
#page-mypage #main .setting-form .setting-content .setting-annotation {
  margin: 5px 0;
  color: #aaa;
  line-height: 17px;
  font-size: 10px;
  text-align: left;
}
#page-mypage #main .setting-form .setting-content .switch {
  position: relative;
  display: inline-block;
  width: 28px;
  height: 16px;
}
#page-mypage #main .setting-form .setting-content .switch.disabled {
  opacity: 0.32;
}
#page-mypage #main .setting-form .setting-content .switch input {
  opacity: 0;
  width: 0;
  height: 0;
}
#page-mypage #main .setting-form .setting-content .slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #adadad;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
#page-mypage #main .setting-form .setting-content .slider:before {
  position: absolute;
  content: "";
  height: 12px;
  width: 12px;
  left: 2px;
  bottom: 2px;
  background-color: white;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
#page-mypage #main .setting-form .setting-content input:checked + .slider {
  background-color: #2196F3;
}
#page-mypage #main .setting-form .setting-content input:focus + .slider {
  box-shadow: 0 0 1px #2196F3;
}
#page-mypage #main .setting-form .setting-content input:checked + .slider:before {
  -webkit-transform: translateX(12px);
  -ms-transform: translateX(12px);
  transform: translateX(12px);
}
#page-mypage #main .setting-form .setting-content .slider.round {
  border-radius: 34px;
}
#page-mypage #main .setting-form .setting-content .slider.round:before {
  border-radius: 50%;
}
#page-mypage #main .setting-form .setting-content .about {
  font-size: 10px;
  color: #858585;
  text-decoration: underline;
  margin-top: 8px;
}

/* =page-history 編集履歴
------------------------------------------------------------ */
#page-history #main #versions {
  padding: 15px;
  background-color: #fff;
}
#page-history #main #versions .button {
  padding: 10px;
  margin-bottom: 15px;
  width: 100%;
}
#page-history #main #versions #compare {
  background-color: #E7E7E7;
}
#page-history #main #versions #compare[disabled] {
  background-image: none;
}
#page-history #main #versions p {
  padding: 0 0 10px;
  text-align: center;
}
#page-history #main .box-module {
  margin-bottom: 10px;
  background-color: #fff;
}
#page-history #main article {
  padding: 10px 0;
  border-bottom: 1px solid #E6E6E6;
  overflow: hidden;
  zoom: 1;
}
#page-history #main article .version {
  float: left;
  width: 125px;
  padding: 8px 0;
}
#page-history #main article img {
  width: 32px;
  height: 32px;
  margin-right: 10px;
  border-bottom: 1px solid #E6E6E6;
  float: left;
}
#page-history #main article .body {
  width: 455px;
  float: left;
}
#page-history #main article .body span {
  float: right;
  color: #aaa;
}
#page-history #main article .body div {
  padding: 8px 0 0 0;
  lin-height: 1.5;
}
#page-history #compare {
  padding: 20px;
  background-color: #fff;
}
#page-history #compare table {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
  line-height: 1.5;
  word-break: break-all;
}
#page-history #compare th,
#page-history #compare td {
  padding: 1px;
}
#page-history #compare th {
  width: 452px;
  border: 1px solid #ddd;
  text-align: left;
  background-color: #f3f3f3;
}
#page-history #compare .row_space {
  height: 10px;
}
#page-history #compare .row_space_title {
  height: 2px;
}
#page-history #compare .compare_num {
  font-size: 12px;
  font-weight: bold;
  color: #333333;
}
#page-history #compare .compare_space {
  width: 17px;
}
#page-history #compare .compare_right,
#page-history #compare .compare_left {
  width: 450px;
  padding: 5px;
  background-color: #f3f3f3;
}
#page-history #compare .compare_sign {
  background-color: #666;
  color: #fff;
  width: 10px;
  text-align: center;
  padding: initial;
}
#page-history #compare .diff_deleted {
  background: #FFDDDD;
}
#page-history #compare .diff_added {
  background: #DDFFDD;
}

header.history {
  margin-bottom: 2px;
  padding: 15px;
  background-color: #fff;
  overflow: hidden;
  zoom: 1;
}
header.history h1 {
  float: left;
  padding: 5px 0 0 0;
  font-size: 20px;
}
header.history p {
  padding: 8px 0 8px 8px;
  float: left;
  color: #999;
}
header.history nav {
  float: right;
}
header.history nav ul {
  overflow: hidden;
  zoom: 1;
}
header.history nav ul .button {
  float: left;
  margin-right: 2px;
  padding: 7px 8px;
  font-size: 12px;
  color: #ccc;
}
header.history nav ul .button.archive {
  font-weight: initial;
}
header.history nav ul .newest {
  -moz-border-radius: 0px;
  -webkit-border-radius: 0px;
  -o-border-radius: 0px;
  border-radius: 0px;
}
header.history nav ul .next {
  -webkit-border-top-left-radius: 0px;
  -webkit-border-bottom-left-radius: 0px;
  -moz-border-radius-topleft: 0px;
  -moz-border-radius-bottomleft: 0px;
  border-top-left-radius: 0px;
  border-bottom-left-radius: 0px;
}
header.history nav ul .previous {
  -webkit-border-top-right-radius: 0px;
  -webkit-border-bottom-right-radius: 0px;
  -moz-border-radius-topright: 0px;
  -moz-border-radius-bottomright: 0px;
  border-top-right-radius: 0px;
  border-bottom-right-radius: 0px;
}

#history-bar {
  background-color: white;
}
#history-bar header.history {
  margin: 0 auto;
  width: 970px;
}

/* =page-edit 記事の作成・編集
------------------------------------------------------------ */
#page-edit #content header {
  margin-bottom: 2px;
  padding: 15px;
  background-color: #FFF;
  overflow: hidden;
  zoom: 1;
}
#page-edit #content header h3 {
  padding: 0 0 10px 0;
  text-align: left;
  font-size: 12px;
}
#page-edit #content header #main-image {
  width: 246px;
  margin-top: 10px;
  margin-right: 15px;
  float: left;
  text-align: center;
  font-size: 10px;
}
#page-edit #content header #main-image .tumbnail {
  display: block;
  margin-bottom: 10px;
  padding: 2px;
  border: 1px solid #999;
  text-align: center;
  overflow: hidden;
  width: 240px;
  height: 240px;
  line-height: 238px;
}
#page-edit #content header #main-image .tumbnail img {
  width: 240px;
}
#page-edit #content header #main-image input {
  width: 234px;
}
#page-edit #content header #main-image #cancel-image-url {
  display: none;
  margin-top: 5px;
}
#page-edit #content header .info {
  width: 678px;
  float: left;
}
#page-edit #content header .info .title {
  font-size: 24px;
  color: black;
  font-weight: bold;
}
#page-edit #content header .info .caption {
  padding: 10px 0;
  color: #aaa;
}
#page-edit #content header .info .caption p {
  padding: 0px 0 10px;
  line-height: 1.5;
}
#page-edit #content header.partial {
  margin-bottom: 10px;
}
#page-edit #content #confirm-image-url {
  margin-top: 5px;
}
#page-edit #content .item {
  padding: 10px 0;
}
#page-edit #content label {
  padding: 0 0 10px 0;
  font-weight: bold;
  display: block;
  color: #333;
  cursor: pointer;
}
#page-edit #content label span {
  font-weight: normal;
  color: #999;
}
#page-edit #content .link {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
  text-align: right;
  display: block;
  margin: 10px 0 0 auto;
  line-height: 20px;
  font-size: 12px;
  color: #007AB3;
}
#page-edit #content .hide {
  display: none;
}
#page-edit #content #title {
  font-size: 20px;
  font-weight: bold;
}
#page-edit #content #summary {
  height: 5em;
}
#page-edit #content #main {
  margin-bottom: 15px;
}
#page-edit #content #templates {
  margin-bottom: 2px;
  padding: 15px;
  background-color: #FFF;
}
#page-edit #content #templates h3 {
  padding: 0 0 10px 0;
}
#page-edit #content #templates label {
  display: inline;
  margin-right: 10px;
  font-weight: normal;
}
#page-edit #content #comment-box {
  margin-bottom: 2px;
  padding: 15px;
  background-color: #FFF;
}
#page-edit #content #comment-box div {
  width: 612px;
}
#page-edit #content #editor textarea {
  font-size: 13px;
  height: 30em;
  width: 612px;
}
#page-edit #content #comment {
  width: 612px;
}
#page-edit #content #article-relation section {
  padding: 50px 15px;
  background-color: #E6E6E6;
}
#page-edit #content #article-relation section h3 {
  padding-bottom: 10px;
}
#page-edit #content #article-relation table {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
  border-top: 1px solid #B3B3B3;
  line-height: 1.5;
}
#page-edit #content #article-relation th,
#page-edit #content #article-relation td {
  padding: 10px 2px;
}
#page-edit #content #article-relation th {
  border-bottom: 1px solid #B3B3B3;
  text-align: left;
}
#page-edit #content #article-relation td {
  border-bottom: 1px solid #B3B3B3;
}
#page-edit #content .template {
  display: none;
}

/* =form
------------------------------------------------------------ */
textarea {
  vertical-align: bottom;
}

input.text,
textarea {
  width: 666px;
  margin: 0px 0;
  padding: 5px;
  font-size: 13px;
  border: 1px solid #999;
  background: #fff url("../images/form_textarea_bg.png") 0 0 repeat-x;
}

input.text:focus,
textarea:focus {
  outline: none;
  border: 1px solid #000;
}

input.error,
textarea.error {
  border: 1px solid red;
}

input.text::-webkit-input-placeholder {
  color: #D9D9D9;
}

input.text:-moz-placeholder,
textarea:-moz-placeholder {
  color: #D9D9D9;
}

select {
  font-size: 16px;
  margin-right: 10px;
}

.error-message {
  padding: 7px 6px;
  font-size: 13px;
  font-weight: bold;
  background-color: red;
  color: #fff;
  text-align: left;
}
.error-message a {
  color: #FAA;
}
.error-message a:hover {
  color: #F66;
}

/* =login ログインページ
------------------------------------------------------------ */
#page-login #content {
  overflow: visible;
}
#page-login #back-to-top {
  display: none;
}

#login-box {
  width: 360px;
  margin: 30px auto;
  position: relative;
}
#login-box .login,
#login-box .newuser {
  margin-bottom: 2px;
  padding: 25px;
  background-color: #FFF;
}
#login-box .login h2,
#login-box .newuser h2 {
  font-size: 18px;
}
#login-box .item {
  padding: 20px 0 0;
}
#login-box label {
  padding: 0 0 10px 0;
  font-weight: bold;
  display: block;
}
#login-box label span {
  font-weight: normal;
}
#login-box .text {
  width: 298px;
  margin: 0px 0;
  padding: 5px;
  font-size: 24px;
  border: 1px solid #d9d9d9;
  border-top: 1px solid #bfbfbf;
  background: #fff url("../images/form_textarea_bg.png") 0 0 repeat-x;
}
#login-box .text:focus {
  outline: none;
}
#login-box .text::-webkit-input-placeholder {
  color: #D9D9D9;
}
#login-box .text:-moz-placeholder {
  color: #D9D9D9;
}
#login-box .permanent-login {
  padding: 10px 0 0;
  cursor: pointer;
}
#login-box .submit {
  width: 310px;
  height: 38px;
  padding: 0;
  border: none;
  cursor: pointer;
  text-indent: -9999px;
  background: transparent url("../images/login_button_en.png") 0 0 no-repeat;
}
#login-box .newuser a {
  display: block;
  width: 310px;
  height: 38px;
  padding: 0;
  border: none;
  cursor: pointer;
  text-indent: -9999px;
  background: transparent url("../images/newuser_button_en.png") 0 0 no-repeat;
}
#login-box .hakutakutan {
  z-index: 100;
  position: absolute;
  top: -47px;
  right: -25px;
}

/* =gad 広告
------------------------------------------------------------ */
.gad {
  padding: 20px 0 0;
  font-size: 13px;
  line-height: 1.5;
}
.gad a.url {
  font-size: 12px !important;
  font-weight: normal !important;
  color: #999;
}
.gad a.url:hover {
  color: #00ADFF;
}

#article-body .gad h2 {
  font-size: 15px !important;
  padding: 5px !important;
  margin: 0 0 15px !important;
  overflow: hidden;
  zoom: 1;
}
#article-body .gad h2 a {
  float: left;
}
#article-body .gad .items li {
  background-image: none !important;
  padding-left: 5px !important;
}

#sub .gad {
  margin: 10px 0 10px;
  padding: 0px;
  background-color: #FFF;
  border-top: none;
}
#sub .gad img, #sub .gad embed {
  margin: 0px;
}
#sub .gad .items li {
  font-size: 12px;
  color: #444;
}
#sub .gad h2 {
  border: 1px solid #2663A4;
  background-color: #007AB3;
  padding: 3px 10px;
  overflow: hidden;
  zoom: 1;
}
#sub .gad h2 a {
  float: left;
  color: #fff;
}

/* =support
------------------------------------------------------------ */
#support textarea,
#support .text {
  width: 500px;
  padding: 3px;
  font-size: 13px;
}

/* =share-buttons
------------------------------------------------------------ */
.share-buttons li {
  float: left;
}
.share-buttons li.twitter iframe {
  width: 90px;
}
.share-buttons li iframe {
  width: 100px;
  height: 20px;
  overflow: hidden;
}
.share-buttons .facebook {
  width: 102px;
}
.share-buttons .facebook iframe {
  height: 21px;
}
.share-buttons .mixi {
  width: 90px;
}
.share-buttons .hatena {
  width: 55px;
}
.share-buttons .plusone {
  width: 65px;
}

/* =dynamic-biron
------------------------------------------------------------ */
#dynamic-biron {
  align-items: center;
  display: flex;
  justify-content: center;
  padding: 5px 0;
  background: #FFF url("../images/biron_bg.png") 0 0 repeat-x;
  width: 100%;
  position: fixed;
  box-shadow: 0 0px 5px rgba(0, 0, 0, 0.5);
  bottom: 0;
  z-index: 100;
}
#dynamic-biron[aria-hidden=true].dynamic-biron--animated {
  animation: dynamic-biron--hidden 3s forwards;
}
#dynamic-biron[aria-hidden=true]:not(.dynamic-biron--animated) {
  display: none;
}
#dynamic-biron:not([aria-hidden=true]).dynamic-biron--animated {
  animation: dynamic-biron--shown 0.3s forwards;
}
#dynamic-biron > a {
  align-items: center;
  border-radius: 5px;
  color: #fff;
  cursor: pointer;
  display: flex;
  font-size: 16px;
  font-weight: bold;
  height: 100%;
  justify-content: center;
  margin: 0 5px;
  min-width: 210px;
  text-decoration: none;
  transition: background-color 0.1s ease;
}
#dynamic-biron > a > * {
  margin: 13px 10px;
}
#dynamic-biron > a > * > svg {
  fill: #fff;
  margin: 0 1rem 0 0;
  vertical-align: sub;
  width: 1.2em;
}
#dynamic-biron > a.facebook {
  background: #3a5b98;
}
#dynamic-biron > a.facebook:hover {
  background: #6d8ecb;
}
#dynamic-biron > a.twitter {
  background: #51aeee;
}
#dynamic-biron > a.twitter:hover {
  background: #84e1ff;
}
#dynamic-biron > .close {
  cursor: pointer;
}
#dynamic-biron > h2 {
  font-size: 18px;
  margin: 25px;
}

@keyframes dynamic-biron--hidden {
  10% {
    opacity: 1;
  }
  100% {
    transform: translateY(1000%);
    opacity: 0;
  }
}
@keyframes dynamic-biron--shown {
  0% {
    transform: translateY(100%);
  }
}
#biron .close,
#dynamic-biron .close {
  position: absolute;
  right: 14px;
  top: 14px;
  display: block;
  width: 24px;
  height: 22px;
  padding: 0;
  border: none;
  text-indent: -9999px;
  background: transparent url("../images/biron_close.png") 0 0 no-repeat;
}
#biron .close:hover,
#dynamic-biron .close:hover {
  display: block;
  width: 24px;
  height: 22px;
  padding: 0;
  border: none;
  text-indent: -9999px;
  background: transparent url("../images/biron_close.png") 0 -22px no-repeat;
}
#biron .close:active,
#dynamic-biron .close:active {
  display: block;
  width: 24px;
  height: 22px;
  padding: 0;
  border: none;
  text-indent: -9999px;
  background: transparent url("../images/biron_close.png") 0 -44px no-repeat;
}

/** for Japanese**/
header .share-buttons {
  height: 34px;
  margin-top: 10px;
  padding: 0;
}
header .share-buttons li {
  margin: 2px 4px !important;
  padding: 0 !important;
  background: none !important;
}

/** for English**/
#sub-contents .share-buttons {
  background-color: #f5f5f5;
  padding: 10px 15px 0px;
  border: 1px solid #DDD;
  height: 66px;
}
#sub-contents .share-buttons li {
  margin-bottom: 10px;
}

/* =static-content
------------------------------------------------------------ */
.static-content {
  width: 970px !important;
}

/* =touch-switching
------------------------------------------------------------ */
#switch-touch {
  text-align: center;
  margin: 20px;
  padding: 20px;
  font-size: 64px;
  border-radius: 20px;
  border: 2px solid #AAA;
  color: #999;
  background-color: #DDD;
}

/* =BOOTH商品欄
------------------------------------------------------------- */
.booth-items {
  background-color: #F4FAFE;
  border: 1px solid #C9E1F4;
  -moz-border-radius: 10px;
  -webkit-border-radius: 10px;
  -o-border-radius: 10px;
  border-radius: 10px;
}
.booth-items header {
  background-color: #F4FAFE !important;
}
.booth-items h2 {
  border: none;
  margin: 0 12px 0;
  padding: 10px 0 5px;
  font-size: 20px;
  line-height: 1.3;
  clear: both;
  display: contents;
  background-color: #F4FAFE;
}
.booth-items h2 a {
  border: none;
  margin: 0 12px 0;
  padding: 10px 0 5px;
  font-size: 20px;
  line-height: 1.3;
  clear: both;
  position: relative;
  text-align: left;
}
.booth-items .button {
  margin: 0 10px 10px;
}

.booth-items .description {
  font-size: 13px;
  text-align: center;
}

.booth-items .information {
  margin-bottom: 10px;
  padding: 12px;
  border-radius: 8px;
  background-color: #f2f4f6;
  text-align: center;
}

.booth-items .information .add-item {
  display: inline-block;
  margin-bottom: 8px;
  padding: 8px 12px 6px;
  border-radius: 4px;
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  background-color: #de2e35;
  box-shadow: 0 3px #b62121;
}

.booth-items .information .add-item:hover {
  text-decoration: none;
  background-color: #d60911;
  box-shadow: 0 3px #a50707;
}

.booth-items .information .caption {
  font-size: 12px;
  color: #666;
}

.booth-items .information .registration {
  font-size: 14px;
}

.booth-items .information .registration a {
  font-weight: bold;
}

.booth-items a.event {
  display: block;
}

.booth-items .image-item {
  height: 230px !important;
  width: 200px;
  padding: 0 10px;
  margin: 0;
}

._image-items {
  display: flex;
  flex-direction: row;
  background-color: #F4FAFE;
}

.image-item ._layout-thumbnail {
  height: 150px;
  background-color: #F4FAFE;
}

._layout-thumbnail img {
  display: block;
  margin: auto;
  vertical-align: middle;
}

img._thumbnail {
  height: 100%;
  object-position: left;
  object-fit: scale-down;
}

.booth-items .event-name-badge {
  display: inline-block;
  padding: 3px 7px;
  border-radius: 10px;
  font-size: 10px;
  color: #fff;
  background-color: #22d59b;
}

.booth-items .event-name-badge:hover {
  background-color: #00bd80;
}

._unit.booth-items .description {
  margin: 10px 20px;
  padding: 8px;
  border-radius: 4px;
  background-color: #f2f4f6;
  font-size: 13px;
}

._unit.booth-items .description .sprites-booth {
  margin-top: -2px;
}

._unit.booth-items .information {
  margin: 0 20px 12px;
}

.viewer_graph {
  clear: both;
}

._sensitive-warning-container {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 8px;
  margin-bottom: 10px;
  background-color: #e6e6e6;
  border-top: 1px solid #b5b5b5;
  border-bottom: 1px solid #fcfcfc;
  border-radius: 4px;
}
._sensitive-warning-container.footer {
  margin: 0 auto;
  width: 954px;
}
._sensitive-warning-container .info-icon {
  margin-right: 8px;
  width: 16px;
  height: 16px;
  background-image: url("../images/info.svg");
  background-repeat: no-repeat;
}
._sensitive-warning-container .text {
  font-size: 14px;
  line-height: 22px;
  color: #808080;
}

.sidewall {
  width: 228px;
  height: 1024px;
  position: absolute;
  display: none;
}

button.text {
  appearance: none;
  background: inherit;
  border: none;
  color: inherit;
  font: inherit;
  padding: inherit;
  margin: inherit;
}
button.text:hover {
  color: #00ADFF;
  cursor: pointer;
}

._gdpr-notify-header {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  color: #FFF;
}
._gdpr-notify-header .notify-button {
  width: 76px;
  min-width: 76px;
  height: 36px;
  border: none;
  border-radius: 18px;
  font-size: 14px;
  cursor: pointer;
  text-decoration: none;
}
._gdpr-notify-header .notify-button.detail {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 8px 4px 8px 16px;
  background-color: #f5f5f5;
  color: #666666;
}
._gdpr-notify-header .notify-button.agree {
  text-align: center;
  margin: 8px 8px 8px 4px;
  background-color: #0096fa;
  color: #fff;
}

._gdpr-notify-header_replace {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 52px;
  color: #FFF;
  background-color: #333;
  font-size: 14px;
  gap: 4px;
  padding: 0 24px;
}
._gdpr-notify-header_replace .detail {
  color: #669FC2;
  text-decoration: underline;
}
._gdpr-notify-header_replace .notify-button {
  width: 76px;
  min-width: 76px;
  height: 36px;
  border: none;
  border-radius: 18px;
  font-size: 14px;
  font-weight: bold;
  cursor: pointer;
  text-decoration: none;
}
._gdpr-notify-header_replace .notify-button.agree {
  text-align: center;
  margin: 12px 20px;
  background-color: #0096fa;
  color: #fff;
}

/* =login-only-modal 未ログイン時に出すログイン限定機能モーダル
------------------------------------------------------------ */
.login-only-function {
  display: none;
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.32);
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center;
  overflow-y: auto;
  background: rgba(0, 0, 0, 0.3215686275);
  z-index: 300;
}
.login-only-function_box {
  display: flex;
  margin: auto;
  padding-top: 40px;
  padding-bottom: 40px;
}
.login-only-function_modal {
  position: relative;
  background-color: #fff;
  height: 328;
  width: 336px;
  border-radius: 24px;
}
.login-only-function_modal .header {
  height: 64px;
}
.login-only-function_modal .header_title {
  font-style: normal;
  font-weight: 700;
  font-size: 16px;
  line-height: 24px;
  text-align: center;
}
.login-only-function_modal .header_close {
  cursor: pointer;
  position: absolute;
  top: 17px;
  right: 17px;
}
.login-only-function_modal .content {
  background: #fff;
  border-radius: 0 0 24px 24px;
  height: 100px;
  text-align: center;
}
.login-only-function_modal .content_title {
  height: 24px;
  font-style: normal;
  font-weight: 700;
  font-size: 16px;
  line-height: 24px;
  color: #1F1F1F;
}
.login-only-function_modal .content_text {
  margin-top: 32px;
  margin-left: 40px;
  margin-right: 40px;
  height: 44px;
  font-style: normal;
  font-weight: 400;
  font-size: 14px;
  line-height: 22px;
  color: #474747;
}
.login-only-function_modal .action {
  margin-top: 36px;
  margin-bottom: 40px;
  margin-left: 24px;
  margin-right: 24px;
}
.login-only-function_modal .action_signup {
  cursor: pointer;
  background: #0096FA;
  border-radius: 20px;
  height: 40px;
  width: 100%;
  border: initial;
  padding: 9px 24px;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
}
.login-only-function_modal .action_signup:hover {
  opacity: 0.7;
}
.login-only-function_modal .action_login {
  cursor: pointer;
  margin-top: 8px;
  background: rgba(0, 0, 0, 0.04);
  border-radius: 20px;
  height: 40px;
  width: 100%;
  border: initial;
  padding: 9px 24px;
  font-size: 14px;
  font-weight: 700;
  color: #474747;
}
.login-only-function_modal .action_login:hover {
  opacity: 0.7;
}

/* -------------------------------------------------------------------
// markItUp! Universal MarkUp Engine, JQuery plugin
// By Jay Salvat - http://markitup.jaysalvat.com/
// ------------------------------------------------------------------*/
.markItUp * {
  margin: 0px;
  padding: 0px;
  outline: none;
}

.markItUp a:link,
.markItUp a:visited {
  color: #000;
  text-decoration: none;
}

.markItUp {
  margin: 0;
}

.markItUpContainer {
  font: 11px Verdana, Arial, Helvetica, sans-serif;
}

.markItUpEditor {
  font: 12px "Courier New", Courier, monospace;
  padding: 5px;
  height: 320px;
  clear: both;
  line-height: 18px;
  overflow: auto;
}

.markItUpPreviewFrame {
  overflow: auto;
  background-color: #FFF;
  width: 99.9%;
  height: 300px;
  margin: 5px 0;
}

.markItUpFooter {
  width: 100%;
}

.markItUpResizeHandle {
  overflow: hidden;
  width: 22px;
  height: 5px;
  margin-left: auto;
  margin-right: auto;
  background-image: url("../images/markitup_handle.png");
  cursor: n-resize;
}

/***************************************************************************************/
/* first row of buttons */
.markItUpHeader ul li {
  list-style: none;
  float: left;
  position: relative;
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
}

.markItUpHeader ul li:hover > ul {
  display: block;
}

.markItUpHeader ul .markItUpDropMenu {
  background: transparent url("../images/markitup_menu.png") no-repeat 115% 50%;
  margin-right: 5px;
}

.markItUpHeader ul .markItUpDropMenu li {
  margin-right: 0px;
}

/* next rows of buttons */
.markItUpHeader ul ul {
  display: none;
  position: absolute;
  top: 18px;
  left: 0px;
  background: #FFF !important;
  border: 1px solid #000;
}

.markItUpHeader ul ul li {
  float: none;
  border-bottom: 1px solid #000;
}

.markItUpHeader ul ul .markItUpDropMenu {
  background: #FFF url("../images/markitup_submenu.png") no-repeat 100% 50%;
}

.markItUpHeader ul .markItUpSeparator {
  margin: 0 10px !important;
  width: 1px;
  height: 16px;
  overflow: hidden;
  background-color: #CCC !important;
}

.markItUpHeader ul ul .markItUpSeparator {
  width: auto;
  height: 1px;
  margin: 0px !important;
}

/* next rows of buttons */
.markItUpHeader ul ul ul {
  position: absolute;
  top: -1px;
  left: 150px;
}

.markItUpHeader ul ul ul li {
  float: none;
}

.markItUpHeader ul a {
  display: block;
  width: 16px;
  height: 16px;
  text-indent: -10000px;
  background-repeat: no-repeat;
  padding: 3px;
  margin: 0px;
}

.markItUpHeader ul ul a {
  display: block;
  padding-left: 0px;
  text-indent: 0;
  width: 120px;
  padding: 5px 5px 5px 25px;
  background-position: 2px 50%;
}

.markItUpHeader ul ul a:hover {
  color: #FFF;
  background-color: #000;
}

.markItUp .markItUpButton1 a {
  background-image: url("../images/markitup_h1.png");
}

.markItUp .markItUpButton2 a {
  background-image: url("../images/markitup_h2.png");
}

.markItUp .markItUpButton3 a {
  background-image: url("../images/markitup_h3.png");
}

.markItUp .markItUpButton4 a {
  background-image: url("../images/markitup_bold.png");
}

.markItUp .markItUpButton5 a {
  background-image: url("../images/markitup_italic.png");
}

.markItUp .markItUpButton6 a {
  background-image: url("../images/markitup_link.png");
}

.markItUp .markItUpButton7 a {
  background-image: url("../images/markitup_externallink.png");
}

.markItUp .markItUpButton8 a {
  background-image: url("../images/markitup_image.png");
}

.markItUp .markItUpButton9 a {
  background-image: url("../images/markitup_image_s.png");
}

.markItUp .markItUpButton10 a {
  background-image: url("../images/markitup_novel.png");
}

.markItUp .preview a {
  background-image: url("../images/markitup_preview.png");
}

/*
 * 英語版のためのCSS上書き
 */
body {
  font-family: "lucida grande", tahoma, verdana, arial, "Hiragino Kaku Gothic Pro", Meiryo, "MS PGothic", sans-serif !important;
}

#top header h1 {
  padding: 11px 0 0 !important;
}

#main article .info .relation ul {
  float: left;
  width: 420px;
  height: 18px;
}

#main #topics li a.special {
  background-image: url("../images/top_topics_special_tab_bg_en.png");
}

#main #topics li a.special:hover {
  background-image: url("../images/top_topics_special_tab_bg_en.png");
}

#main #topics li a.special.current {
  background-image: url("../images/top_topics_special_tab_bg_en.png");
}

#main article .info .data {
  line-height: 1.5;
  font-size: 10px;
}

#top #infobar .facebook-biron {
  background-image: url("../images/biron_facebook_en.png");
}

#top #infobar .searchengine {
  background-image: url("../images/biron_searchengine_en.png");
}

#share-buttons .share-buttons {
  height: 30px;
}
