@charset "UTF-8";
/* ==========================================================================
   reset
   ========================================================================== */
html {
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif; }

body {
  margin: 0;
  word-wrap: break-word;
  overflow-wrap: break-word;
  -webkit-font-smoothing: subpixel-antialiased; }

dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, p, blockquote, th, td {
  margin: 0;
  padding: 0; }

a,
a:active,
a:hover {
  outline: 0; }

pre {
  white-space: pre-wrap; }

q:before,
q:after {
  content: '';
  content: none; }

ol,
ul {
  list-style-type: none; }

img {
  border: 0; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

br {
  letter-spacing: 0; }

.clearfix, .cf {
  zoom: 1; }
  .clearfix:before, .clearfix:after, .cf:before, .cf:after {
    content: "";
    display: table; }
  .clearfix:after, .cf:after {
    clear: both; }

/*
#colors

@primary $link-color
@secondary #333
@color-name color-code
*/
/* ==========================================================================
   オリジナルデザイン
   ========================================================================== */
.more-post a {
  background-color: #333;
  padding: 10px 56px;
  margin: 20px 0;
  display: inline-block; }
  .more-post a:hover {
    background: #c3c3c3; }

.category {
  display: block;
  margin-bottom: .5em; }
  .category a {
    color: #fff;
    border: 1px solid #fff;
    padding: 4px 10px;
    font-size: 13px;
    font-size: 0.8125rem;
    margin-bottom: 1em; }

.card-title {
  font-weight: bold;
  font-size: 20px;
  font-size: 1.25rem; }

.card-title a {
  color: #fff;
  text-decoration: none; }

.card-title a:hover {
  text-decoration: underline; }

.card-date {
  margin-top: 2em; }

.card-detail {
  font-size: 14px;
  font-size: 0.875rem;
  margin-top: 1em;
  line-height: 1.6;
  max-width: 400px; }

.card-detail:empty {
  margin-top: 0;
  background: red; }

#detail-page #main-contents {
  border-top: 1px solid #ccc;
  padding-top: 20px; }

.agenda {
  color: #333; }

.menu-title, .CAL_TOP {
  border-bottom: 1px solid #ccc;
  padding-bottom: 4px;
  text-align: center; }

/* ==========================================================================
   リンク定義
   ========================================================================== */
a {
  color: #333; }
  a:hover {
    text-decoration: none; }

#blog-head h1 a,
.category a {
  text-decoration: none; }

/* ==========================================================================
   カラム
   ========================================================================== */
#main-contents {
  max-width: 1600px;
  min-width: 960px; }

#sub-contents {
  max-width: 1600px;
  min-width: 960px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 0 40px; }

#profile, .menu {
  display: inline-block;
  vertical-align: top;
  width: 200px; }

.menu:nth-child(5n) {
  margin-right: 0; }

.menu-list {
  max-width: 1360px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap; }

/* ==========================================================================
   共通パーツ
   ========================================================================== */
#wrap {
  padding-bottom: 40px;
  background: #fff; }

.contents-wrap, #blog-head .inner {
  max-width: 1600px;
  margin: 0 auto; }

#blog-admin {
  color: #767676;
  font-size: 12px;
  font-size: 0.75rem;
  position: absolute;
  top: 0;
  right: 0;
  margin-top: -.3em; }
  #blog-admin a {
    color: #767676; }

#pager {
  text-align: center;
  clear: both; }

.pagerNavLink {
  clear: both;
  padding-right: 32px; }

/* ==========================================================================
   本文
   ========================================================================== */
#main-contents {
  margin-bottom: 60px; }

/*--- 本文記事デフォルト ---*/
.post-main {
  text-align: justify;
  letter-spacing: .1em;
  line-break: strict;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1.8; }
  .post-main h3 {
    font-weight: bold;
    background: #eee;
    padding: 5px 10px;
    font-size: 17px;
    font-size: 1.0625rem; }
  .post-main h4 {
    font-weight: bold;
    font-size: 16px;
    font-size: 1rem; }
  .post-main h5 {
    font-weight: bold;
    font-size: 15px;
    font-size: 0.9375rem; }
  .post-main h6 {
    font-weight: bold;
    font-size: 14px;
    font-size: 0.875rem; }
  .post-main hr {
    border: none;
    border-top: solid 1px #ccc;
    margin: 2em 0; }
  .post-main caption {
    font-weight: bold; }
  .post-main th {
    font-weight: bold;
    padding: 5px; }
  .post-main td {
    padding: 5px; }
  .post-main iframe {
    max-width: 1600px; }
  .post-main img {
    margin: 10px 0;
    max-width: 1600px;
    vertical-align: middle; }
  .post-main #imgYdn img {
    margin: 0; }
  .post-main p {
    margin: 10px auto; }
    .post-main p br {
      line-height: 0; }
  .post-main dl {
    margin: 0 0 0 10px; }
    .post-main dl dd {
      margin: 0 40px; }
    .post-main dl dt {
      font-weight: bold; }
  .post-main ol {
    margin: 10px; }
    .post-main ol li {
      margin: 0 40px;
      list-style: decimal; }
  .post-main ul {
    margin: 10px; }
    .post-main ul li {
      margin: 0 40px;
      list-style: disc; }
  .post-main blockquote {
    margin: 10px 0; }
  .post-main .sm_icon_mini {
    margin-top: 10px; }
  .post-main .lifelog-entry a {
    background: #fff; }
    .post-main .lifelog-entry a:hover {
      opacity: .5; }

/*---広告---*/
.ydn_im {
  margin: 40px 0 20px 0; }
  .ydn_im dt {
    margin-top: 0; }

/*---exblog auto class---*/
.COMMENT {
  margin-top: 35px;
  font-size: 14px;
  font-size: 0.875rem; }

.COMMENT_TAIL {
  font-weight: bold;
  padding-bottom: 10px; }

.COMMENT_BODY {
  padding: 0 15px 10px;
  margin: 0 0 10px;
  border-bottom: solid 1px #ccc; }

.COMMENT_INPUT {
  margin-top: 30px;
  background: #fcfbf2;
  padding: 20px;
  color: #333; }

.COMMENT_INPUT table {
  margin: 0 auto; }

.COMMENT_INPUT .TXTFLD {
  margin: 3px auto !important; }

.TXTFLD {
  width: 100%;
  padding: 5px 0;
  border: 1px solid #ccc; }

.CAL_TOP {
  margin-bottom: 12px;
  font-weight: bold; }
  .CAL_TOP:before {
    content: ""; }

.CAL_HEAD {
  text-align: center; }

#calendar {
  margin-bottom: 30px; }

.MEMOBODY {
  width: 150px !important; }

/* ==========================================================================
   記事詳細ページ
   ========================================================================== */
.post {
  margin-bottom: 80px;
  color: #333; }

.post-head {
  position: relative; }

.postdate {
  font-size: 13px;
  font-size: 0.8125rem; }

.post-title {
  font-size: 20px;
  font-size: 1.25rem;
  line-height: 1.6;
  font-weight: bold; }

.post-admin {
  position: absolute;
  top: 0px;
  right: 0px;
  font-size: 12px;
  font-size: 0.75rem; }

.post-body {
  margin-top: 20px; }

.post-foot {
  font-size: 12px;
  font-size: 0.75rem;
  text-align: right;
  margin-top: 5px; }

.post-main img {
  max-width: 100%;
  height: auto; }

.bbs_preview {
  width: auto !important;
  line-height: 1.6; }
  .bbs_preview a {
    color: #333; }
  .bbs_preview img {
    margin: 0; }
  .bbs_preview .thumnail_next_bbs {
    width: 200px;
    -o-object-fit: cover;
       object-fit: cover;
    height: 200px;
    background: #fff;
    margin-right: 12px !important; }

/* ==========================================================================
   詳細記事以外の一覧
   ========================================================================== */
.articles {
  min-height: 500px;
  position: relative;
  overflow: hidden; }
  .articles .articles-item {
    display: block; }
    .articles .articles-item:before {
      content: "";
      background: #000;
      width: 100%;
      height: 100%;
      position: absolute;
      top: 0;
      left: 0;
      display: block;
      z-index: 1;
      opacity: .2;
      -webkit-transition: all 0.5s ease;
      transition: all 0.5s ease; }
  .articles:hover .articles-item:before {
    opacity: .6; }
  .articles .articles-admin {
    position: absolute;
    bottom: 0px;
    left: 0px;
    font-size: 12px;
    font-size: 0.75rem; }

.card-thumb {
  width: 100%;
  height: 500px;
  overflow: hidden;
  position: relative; }

.card-thumb img {
  max-width: 140%;
  min-width: 100%;
  width: auto;
  min-height: 100%;
  height: auto;
  position: absolute;
  top: -40%;
  right: -40%;
  bottom: -40%;
  left: -40%;
  margin: auto; }

.card {
  -webkit-transition: .3s;
  transition: .3s;
  position: absolute;
  top: 60px;
  left: 60px;
  color: #fff;
  z-index: 100;
  text-shadow: 0px 0px 6px #666; }
  .card .card-title {
    font-weight: normal;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3; }
  .card .card-lead {
    font-size: 13px;
    min-height: 40px; }
  .card .card-date {
    font-size: 11px;
    font-size: 0.6875rem; }

/*---カテゴリ上部目次部分---*/
.agenda + .articles {
  display: none; }

/* ==========================================================================
   ヘッダー部分
   ========================================================================== */
#blog-head {
  padding-top: 30px;
  margin-bottom: 30px;
  overflow: hidden; }
  #blog-head .inner {
    font-size: 14px;
    font-size: 0.875rem;
    position: relative; }
  #blog-head .thumb {
    width: 100px;
    height: 100px;
    overflow: hidden;
    position: relative;
    float: left;
    margin: 0 20px 0 0;
    border-radius: 100%; }
    #blog-head .thumb:before {
      border-top: 0;
      border-right: 60px solid #fff;
      border-bottom: 100px solid transparent;
      border-left: 60px solid #fff;
      position: absolute;
      content: "";
      background-color: rgba(0, 0, 0, 0.2); }
    #blog-head .thumb img {
      max-width: 140%;
      min-width: 100%;
      width: auto;
      min-height: 100%;
      max-height: 140%;
      height: auto;
      position: absolute;
      top: -40%;
      right: -40%;
      bottom: -40%;
      left: -40%;
      margin: auto; }
  #blog-head #logo {
    padding-top: 10px; }

#blog-head h1 {
  font-weight: bold;
  line-break: strict;
  position: relative;
  display: inline-block;
  overflow: hidden;
  line-height: 1.1; }
  #blog-head h1 a {
    color: #333;
    font-size: 50px;
    font-size: 3.125rem; }
  #blog-head h1 .blog-url {
    font-weight: normal;
    display: block;
    color: #333;
    font-size: 11px;
    font-size: 0.6875rem; }

/* ==========================================================================
   メニュー部分
   ========================================================================== */
.blog-description {
  overflow-wrap: break-word;
  margin: 0;
  font-size: 13px;
  font-size: 0.8125rem;
  line-height: 2;
  color: #333; }

#sub-contents {
  word-break: break-strict;
  font-size: 13px;
  font-size: 0.8125rem; }

#profile {
  font-size: 14px;
  font-size: 0.875rem; }

#profile div a:before {
  content: "> "; }

#profile, .menu {
  margin-bottom: 30px; }

.menu {
  margin-right: 40px;
  color: #333; }
  .menu .menu-title {
    display: block;
    position: relative;
    font-weight: bold; }
    .menu .menu-title a {
      font-size: 70% !important; }
  .menu a {
    color: #333; }

.menu-body {
  margin-top: 12px; }
  .menu-body a {
    color: #333; }

#logo a:before {
  display: none; }

* + html #logo a img {
  height: auto; }

.menu-set {
  text-align: center; }

/*---検索---*/
.menu-body table {
  width: 100%; }

.menu-body table tbody tr:nth-child(2) td:first-child,
.menu-body table tbody input + tr td:first-child {
  width: 150px !important; }

.menu-body table tbody tr:nth-child(2) td:nth-child(2),
.menu-body table tbody input + tr td:nth-child(2) {
  width: 10px !important; }

.menu-body table tbody tr:nth-child(2) td:nth-child(3),
.menu-body table tbody input + tr td:nth-child(3) {
  width: 20px !important; }

.menu-body table input[type="submit"] {
  background: #fff;
  border: none;
  border: 1px solid #ccc;
  padding: 4px 5px; }

@media screen and (max-width: 1600px) {
  #detail-page #main-contents {
    padding-left: 20px;
    padding-right: 20px; }
  #blog-head .thumb {
    margin-left: 10px; }
  #blog-admin {
    right: 10px; } }
