
html { font-size: 62.5%; }
body {
  margin: 0;
  padding: 0;
  font: 1.4rem/1.7 -apple-system, BlinkMacSystemFont,
        "Hiragino Kaku Gothic ProN", "Meiryo", sans-serif;
  color: #eee;
  background: linear-gradient(to bottom, #2c2d2f 0%, #2a2a2a 100%);
  background-attachment: fixed;
}

#page { position: relative; }
#main { margin: 0 auto; padding: 0; }
#contenthead, #main-inner, #colophon .inner-box { width: 900px; max-width: 92%; margin: 0 auto; }
#main::after { content:""; display: table; clear: both; }

#sp-site-branding-1 { padding: 16px 0 0; }
.site-title { margin: 0; }
.site-title a { display:block; width: 368px; height: 66px; background: url(img/logo_3d-12.png) no-repeat; text-indent:-9999px; overflow:hidden; }

#contenthead { margin-top: 12px; }
#sp-image-1 {
  width: 100%; height: auto; display:block;
  border-radius: 6px;
  box-shadow: 0 15px 40px rgba(0,0,0,.45), 0 2px 0 rgba(0,0,0,.6) inset;
}

#sp-site-navigation-1 {
  margin: 14px auto 24px;
  background: rgba(25,18,13,.85);
  border-radius: 6px;
  box-shadow: 0 2px 0 rgba(0,0,0,.4) inset;
}
#sp-site-navigation-1 ul {
  list-style: none; margin: 0; padding: 0 12px;
  display: flex; flex-wrap: wrap;
}
#sp-site-navigation-1 li { position: relative; }
#sp-site-navigation-1 a {
  display: block; padding: 0 14px; line-height: 48px;
  color: #fff; text-decoration: none; font-weight: 700;
  border-bottom: 3px solid transparent;
  transition: color .15s ease, border-color .15s ease;
}
#sp-site-navigation-1 a:hover { color:#b7ff37; }
#sp-site-navigation-1 > ul > li.current_page_item > a {
  color: #b7ff37; border-bottom-color:#b7ff37;
}

#sp-site-navigation-1::after{
  content:""; display:block; height:2px; width: 85%;
  margin: 0 auto; background: #22170f; box-shadow: 0 -1px 0 rgba(0,0,0,.25) inset;
}

#sp-page-title-1 .entry-title {
  margin: 0 0 18px; padding: 0 0 8px 4px;
  font-size: 2.2rem; font-weight: 800; color:#fff;
  border-bottom: 1px solid rgba(255,255,255,.45);
}
h3 {
  margin: 22px 0 14px; padding: 0 0 8px 4px; color:#fff;
  font-size: 1.7rem; font-weight: 800;
  border-bottom: 1px solid rgba(255,255,255,.28);
}
#page-content p.large { margin: .6em 0 1.8em; color:#e7e0da; }

#sp-list-1 { list-style: none; margin: 0 0 12px; padding:0; }
#sp-list-1 li {
  position: relative; padding-left: 22px; margin: 10px 0;
}
#sp-list-1 li::before{
  content:"•"; position:absolute; left:4px; top:0; color:#b7ff37; font-size: 1.6rem;
}
#sp-list-1 a { color:#dfe8ff; text-decoration: underline; }
#sp-list-1 a:hover { color:#b7ff37; }

#sp-definition-list-1 { margin: 0 0 10px; padding: 0; color:#eee; }
#sp-definition-list-1 dt {
  font-weight: 800; margin: 18px 0 6px; white-space: nowrap;
}
#sp-definition-list-1 dd {
  margin: 0 0 16px; padding-left: 0;
}
#sp-definition-list-1 a { color:#dfe8ff; text-decoration: underline; }
#sp-definition-list-1 a:hover { color:#b7ff37; }

#sidebar2 { width: 170px; float: right; }
@media (max-width: 980px){
  #sidebar2 { float:none; width: 100%; margin-top: 18px; }
}

#colophon { background: rgba(25,18,13,.9); margin-top: 40px; }
#colophon .inner-box { padding: 26px 0; }
.hpb-copyright { color:#a9a097; font-size: 1.2rem; margin: 0; }

a { color:#ffffff; }
a:hover { color:#b7ff37; }

@media (min-width: 981px){
  body { min-width: 900px; }
}

@media (max-width: 640px){
  #sp-site-navigation-1 a { line-height: 44px; padding: 0 10px; }
  #sp-site-navigation-1 { margin: 10px auto 18px; }
  #sp-page-title-1 .entry-title { font-size: 2.0rem; }
  h3 { font-size: 1.6rem; }
}

#sp-page-title-10 .entry-title{
  margin: 0 0 18px;
  padding: 0 0 10px 4px;
  font-size: 2.2rem; font-weight: 800; color: #fff;
  border-bottom: 1px solid rgba(255,255,255,.45);
}

#sp-table-9{
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: rgba(0,0,0,.25);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  overflow: hidden;
}

#sp-table-9 tr{
  transition: background-color .15s ease, transform .05s ease;
}
#sp-table-9 tr:hover{
  background: rgba(255,255,255,.03);
}

#sp-table-9 td{
  padding: 18px 16px;
  vertical-align: middle;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
#sp-table-9 tr:last-child td{
  border-bottom: 0;
}

.preline { white-space: pre-line; }

#sp-table-9 td:first-child{
  width: 260px;
  border-right: 1px solid rgba(255,255,255,.06);
}
#sp-table-9 td:first-child img{
  max-width: 100%;
  height: auto;
  display: block;
  border-radius: 4px;
  box-shadow: 0 3px 16px rgba(0,0,0,.25);
}

#sp-table-9 td:last-child a{
  display: inline-block;
  color: #dfe8ff;
  text-decoration: underline;
  font-weight: 700;
  line-height: 1.5;
}
#sp-table-9 td:last-child a:hover{
  color: #b7ff37;
  text-decoration: underline;
}

#sp-block-container-12{
  margin-top: 8px;
}

#sp-button-9 a{
  display: inline-block;
  margin-top: 14px;
  padding: 10px 16px;
  color: #111;
  background: linear-gradient(to bottom, #cfff7a, #96e02d);
  border: 1px solid rgba(0,0,0,.25);
  border-radius: 6px;
  text-decoration: none;
  font-weight: 800;
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
}
#sp-button-9 a:hover{
  filter: brightness(1.05);
}

@media (max-width: 680px){
  #sp-table-9, #sp-table-9 tbody, #sp-table-9 tr{ display:block; width:100%; }
  #sp-table-9 tr{
    border-bottom: 1px solid rgba(255,255,255,.06);
  }
  #sp-table-9 td{
    display:block; width:100%;
    border: 0; padding: 12px 12px 0;
  }
  #sp-table-9 td:first-child{ padding-bottom: 8px; }
  #sp-table-9 td:last-child{ padding: 0 12px 14px; }
}

#sp-table-9 td:first-child { width: 140px; }
#sp-table-9 td:first-child a,
#sp-table-9 td:first-child img { display: block; }
#sp-table-9 td:first-child img {
  max-width: 100%;
  height: auto;
  object-fit: contain;
}
