@charset "UTF-8";
body {
  background-color: #eee; }

header h1 {
  font-family: 'Noto Serif JP',serif;
  position: fixed;
  z-index: -1;
  color: silver;
  font-weight: 900;
  font-size: 24px; }
  @media screen and (min-width: 0px) and (max-width: 349px) {
    header h1 {
      margin-top: 0px; } }
  @media screen and (min-width: 350px), print {
    header h1 {
      transform-origin: left bottom;
      transform: rotate(90deg);
      margin-top: -24px; } }

.contents {
  position: relative;
  top: 40px; }
  .contents article {
    position: relative;
    width: 100%;
    margin: 0px auto 64px; }
    @media screen and (min-width: 0px) and (max-width: 349px) {
      .contents article {
        width: 320px; } }
    @media screen and (min-width: 350px) and (max-width: 509px), print {
      .contents article {
        width: 320px; } }
    @media screen and (min-width: 510px) and (max-width: 669px), print {
      .contents article {
        width: 480px; } }
    @media screen and (min-width: 670px) and (max-width: 829px), print {
      .contents article {
        width: 640px; } }
    @media screen and (min-width: 830px) and (max-width: 989px), print {
      .contents article {
        width: 800px; } }
    @media screen and (min-width: 990px), print {
      .contents article {
        width: 960px; } }
    .contents article > h1 {
      font-family: 'Noto Serif JP',serif;
      font-size: 12px;
      color: #444;
      margin: 0px 5px 12px 5px; }
    .contents article .search {
      display: flex;
      height: 48px; }
      .contents article .search .button {
        display: inline-block;
        margin: 0 0 5px 5px;
        padding: 0; }
        .contents article .search .button a {
          display: inline-block;
          max-width: 100px;
          height: 28px;
          line-height: 28px;
          padding: 0 1em;
          background-color: #fff;
          border: 1px solid #FFBE00;
          border-radius: 8px;
          white-space: nowrap;
          text-overflow: ellipsis;
          overflow: hidden;
          color: #888;
          font-size: 12px;
          text-decoration: none;
          -webkit-transition: .2s;
          transition: .2s; }
          .contents article .search .button a:hover {
            background-color: #FFBE00;
            border: 1px solid #FFBE00;
            color: #fff; }
      .contents article .search input {
        border: none;
        background: none;
        -webkit-appearance: none; }
      .contents article .search #form2 {
        display: inline-block;
        margin: 0 0 5px 5px;
        padding: 0;
        position: relative;
        width: 200px; }
      .contents article .search #sbox2 {
        height: 28px;
        width: 100%;
        padding: 0 10px;
        position: absolute;
        left: 0;
        top: 0;
        border-radius: 8px;
        outline: 0;
        background: #fff;
        border: 1px solid #FFBE00; }
      .contents article .search #sbtn2 {
        height: 28px;
        position: absolute;
        left: calc(100% - 9px);
        /*アイコン左右の位置調整*/
        top: 6px;
        background: none;
        color: #888;
        border: none;
        font-size: 18px;
        /*アイコンサイズ*/ }
      .contents article .search #sbtn2:hover {
        color: #FFBE00; }
    .contents article .grid {
      position: relative;
      height: 100%; }
      .contents article .grid .item {
        display: block;
        position: absolute;
        width: 150px;
        margin: 5px;
        z-index: 1; }
        .contents article .grid .item.sizeL {
          width: 310px; }
        .contents article .grid .item.sizeS {
          width: 150px; }
        .contents article .grid .item .muuri-item-dragging {
          z-index: 3; }
        .contents article .grid .item .muuri-item-dragging {
          z-index: 2; }
        .contents article .grid .item .muuri-item-dragging {
          z-index: 0; }
      .contents article .grid .item-content {
        position: relative;
        padding-bottom: 20px;
        width: 100%;
        height: 100%;
        border-radius: 8px;
        background: #fff;
        -webkit-transition: .2s;
        transition: .2s; }
        .contents article .grid .item-content:hover {
          filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3)); }
        .contents article .grid .item-content a {
          text-decoration: none; }
        .contents article .grid .item-content img {
          width: 100%;
          border-radius: 8px 8px 0px 0px; }
          .contents article .grid .item-content img.Attention {
            position: absolute;
            top: -8px;
            left: -8px;
            width: 24px;
            height: 24px;
            border: solid 2px #D01609;
            border-radius: 14px;
            transition: .2s; }
            .contents article .grid .item-content img.Attention:hover {
              transform: rotate(180deg); }
        .contents article .grid .item-content .info {
          width: calc(100% - 40px);
          padding: 10px 20px 15px 20px; }
          .contents article .grid .item-content .info h1 {
            font-size: 20px;
            font-weight: 900;
            color: #444;
            margin-bottom: 12px; }
          .contents article .grid .item-content .info p {
            font-size: 12px;
            font-weight: 500;
            line-height: 1.4;
            color: #888;
            margin-top: 4px; }
        .contents article .grid .item-content ul {
          margin: 0px 20px 0px 20px;
          padding: 0;
          list-style: none; }
          .contents article .grid .item-content ul li {
            display: inline-block;
            margin: 0 .2em .2em 0;
            padding: 0; }
            .contents article .grid .item-content ul li a {
              display: inline-block;
              max-width: 100px;
              height: 20px;
              line-height: 20px;
              padding: 0 .5em;
              background-color: #fff;
              border: 1px solid #FFBE00;
              border-radius: 8px;
              white-space: nowrap;
              text-overflow: ellipsis;
              overflow: hidden;
              color: #888;
              font-size: 12px;
              text-decoration: none;
              -webkit-transition: .2s;
              transition: .2s; }
              .contents article .grid .item-content ul li a:hover {
                background-color: #FFBE00;
                border: 1px solid #FFBE00;
                color: #fff; }
    .contents article .profile {
      position: relative;
      width: calc(100% - 10px);
      margin: 5px;
      z-index: 1;
      border-radius: 8px;
      background: #fff;
      overflow: hidden; }
      .contents article .profile img {
        width: 100%;
        height: 200px;
        overflow: hidden;
        object-fit: cover; }
        .contents article .profile img.icon_img {
          position: relative;
          border: solid 4px #fff;
          margin-top: -80px;
          left: 50%;
          -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
          width: 160px;
          height: 160px;
          border-radius: 84px;
          filter: drop-shadow(0px 0px 0px rgba(0, 0, 0, 0));
          transition: .2s; }
          .contents article .profile img.icon_img:hover {
            filter: drop-shadow(0px 0px 4px rgba(0, 0, 0, 0.4)); }
      .contents article .profile h2, .contents article .profile h3 {
        position: relative;
        font-weight: 900;
        color: #444;
        text-align: center; }
      .contents article .profile h2 {
        font-size: 32px;
        margin: 16px 0px 8px 0px; }
        .contents article .profile h2 span {
          font-size: 18px; }
      .contents article .profile h3 {
        font-size: 18px;
        margin-bottom: 32px; }
        .contents article .profile h3 span {
          font-size: 12px; }
      .contents article .profile iframe {
        position: relative;
        display: block;
        margin: 0px auto; }
        @media screen and (max-width: 669px), print {
          .contents article .profile iframe {
            width: 100%;
            height: 1100px; } }
        @media screen and (min-width: 670px), print {
          .contents article .profile iframe {
            width: 563.26px;
            height: 1000px; } }
      .contents article .profile .section_wrapper {
        display: flex;
        justify-content: center;
        flex-wrap: wrap; }
        .contents article .profile .section_wrapper section {
          position: relative;
          width: 260px;
          margin: 16px 16px 48px;
          font-size: 16px;
          font-weight: 500;
          line-height: 1.5em;
          color: #444; }
          .contents article .profile .section_wrapper section h1 {
            font-size: 12px;
            font-weight: 900;
            line-height: 1.2em;
            color: #888;
            margin-bottom: 12px; }
          .contents article .profile .section_wrapper section h2 {
            font-size: 8px;
            font-weight: 500;
            text-align: left;
            color: #444;
            margin-bottom: 8px; }
          .contents article .profile .section_wrapper section th {
            font-size: 8px;
            text-align: left;
            width: 80px; }
          .contents article .profile .section_wrapper section td {
            font-size: 16px; }
          .contents article .profile .section_wrapper section tr {
            height: 1.5em; }

#article_back {
  z-index: 80;
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.4);
  transition: .5s; }
  #article_back.close {
    background-color: rgba(0, 0, 0, 0);
    display: none; }

#article {
  z-index: 100;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  height: 98%;
  width: 80%;
  min-width: 320px;
  max-width: 960px;
  border-radius: 16px;
  background-color: #fff;
  filter: drop-shadow(0px 0px 30px rgba(0, 0, 0, 0.4));
  overflow: hidden; }
  @media screen and (max-width: 768px) {
    #article {
      width: 90%; } }
  #article .iframe_wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    margin: 0px;
    padding: 0px;
    overflow: auto;
    -webkit-overflow-scrolling: touch; }
  #article .iframe_wrapper {
    -ms-overflow-style: none;
    /* IE対策 */
    overflow: -moz-scrollbars-none;
    /* Firefox対策 */ }
  #article .iframe_wrapper::-webkit-scrollbar {
    /* Google Chrome対策 */
    display: none; }
  #article iframe {
    top: 0;
    left: 0;
    margin: 0px;
    padding: 0px;
    width: 100%;
    height: 100%; }
  #article a {
    position: absolute;
    width: 32px;
    height: 32px;
    border-radius: 16px;
    top: 0px;
    filter: drop-shadow(0px 0px 2px rgba(0, 0, 0, 0.4));
    transition: .2s; }
    #article a:hover {
      transform: rotate(180deg); }
    #article a#close_button {
      left: calc(100% - 32px); }
    #article a#copy_button {
      left: calc(100% - 72px); }
  #article #load {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #FFBE00;
    /*
    https://projects.lukehaas.me/css-loaders/
    https://github.com/lukehaas/css-loaders
    から借用
    */ }
    #article #load p {
      text-align: center;
      position: absolute;
      font-size: 16px;
      top: calc(50vh + 5.5em);
      left: 0px;
      width: 100%; }
      #article #load p a {
        position: relative;
        width: 100%;
        color: #fff;
        filter: drop-shadow(0px 0px 0px rgba(0, 0, 0, 0));
        padding: 16px;
        transition: .2s; }
        #article #load p a:hover {
          filter: drop-shadow(0px 0px 4px rgba(0, 0, 0, 0.4));
          transform: rotate(0deg); }
    #article #load .loader,
    #article #load .loader:before,
    #article #load .loader:after {
      background: #ffffff;
      -webkit-animation: load1 1s infinite ease-in-out;
      animation: load1 1s infinite ease-in-out;
      width: 1em;
      height: 4em; }
    #article #load .loader {
      color: #ffffff;
      text-indent: -9999em;
      margin: 50vh auto;
      position: relative;
      font-size: 11px;
      -webkit-transform: translateZ(0);
      -ms-transform: translateZ(0);
      transform: translateZ(0);
      -webkit-animation-delay: -0.16s;
      animation-delay: -0.16s; }
    #article #load .loader:before,
    #article #load .loader:after {
      position: absolute;
      top: 0;
      content: ''; }
    #article #load .loader:before {
      left: -1.5em;
      -webkit-animation-delay: -0.32s;
      animation-delay: -0.32s; }
    #article #load .loader:after {
      left: 1.5em; }
@-webkit-keyframes load1 {
  0%,
			80%,
			100% {
    box-shadow: 0 0;
    height: 4em; }
  40% {
    box-shadow: 0 -2em;
    height: 5em; } }
@keyframes load1 {
  0%,
			80%,
			100% {
    box-shadow: 0 0;
    height: 4em; }
  40% {
    box-shadow: 0 -2em;
    height: 5em; } }
.invisible_article {
  display: none; }

.visible_article {
  display: block; }

nav {
  position: relative; }
  nav #nav_back {
    z-index: 199;
    position: fixed;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.4);
    transition: .5s; }
    nav #nav_back.close {
      background-color: rgba(0, 0, 0, 0);
      display: none; }
  nav #nav_window {
    z-index: 200;
    position: fixed;
    right: 16px;
    bottom: 16px;
    width: 200px;
    height: 200px;
    border-radius: 32px;
    background-color: #FFBE00;
    filter: drop-shadow(0px 0px 4px rgba(0, 0, 0, 0.4));
    overflow: hidden;
    transition: .3s; }
    nav #nav_window:hover {
      filter: drop-shadow(0px 0px 6px rgba(0, 0, 0, 0.4)); }
    nav #nav_window.close {
      width: 64px;
      height: 64px; }
    nav #nav_window h1 {
      position: absolute;
      right: 0px;
      bottom: 160px;
      width: 136px;
      padding: 0px 32px;
      font-family: 'Noto Serif JP',serif;
      font-size: 12px;
      color: #444; }
    nav #nav_window ul {
      position: absolute;
      right: 0px;
      bottom: 48px;
      width: 136px;
      padding: 0px 32px; }
      nav #nav_window ul li {
        color: #444;
        font-size: 18px;
        font-weight: 900;
        margin-bottom: 24px; }
      nav #nav_window ul a {
        text-decoration: none;
        color: #444; }
        nav #nav_window ul a:hover {
          color: #fff; }
    nav #nav_window img {
      position: absolute;
      right: 18px;
      bottom: 31px;
      width: 28px; }

footer {
  position: relative;
  width: 100%; }
  footer p {
    font-size: 12px;
    text-align: center;
    color: #888;
    margin: 24px auto 12px; }

/*# sourceMappingURL=common.css.map */
