#home-header {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  overflow-y: hidden;
  overflow-x: scroll;
  overscroll-behavior-x: none;
  scrollbar-width: none;
  height: 56px;
  border-bottom: 1px solid #f9f9f9;
}
@media (max-width: 760px) {
  #home-header {
    padding: 0 24px 0;
  }
}
@media (min-width: 761px) {
  #home-header {
    padding: 0 28px 0;
  }
}
#home-header [data-tag] {
  cursor: pointer;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 32px;
  padding: 0 16px;
  border-left: 1px solid transparent;
  border-right: 1px solid transparent;
}
#home-header [data-tag]:not(:last-child) {
  margin-right: 12px;
}
#home-header [data-tag] span {
  font-family: "Rubik", "Noto Sans JP", sans-serif;
  font-weight: 400;
  white-space: nowrap;
  font-size: 13px;
  line-height: 21px;
}
#home-header [data-tag] img {
  position: absolute;
  top: 0;
  width: 12px;
  height: 32px;
  transform: translateZ(0);
}
#home-header [data-tag] img:first-child {
  left: 0;
}
#home-header [data-tag] img:last-child {
  right: 0;
}
#home-header .--left-slide {
  animation: __left 0.15s;
}
#home-header .--right-slide {
  animation: __right 0.15s;
}

@keyframes __left {
  from {
    opacity: 0.3;
    left: 1px;
  }
  to {
    opacity: 1;
    left: 0;
  }
}
@keyframes __right {
  from {
    opacity: 0.3;
    right: 1px;
  }
  to {
    opacity: 1;
    right: 0;
  }
}
#home-pies {
  width: 100%;
}
@media (max-width: 760px) {
  #home-pies {
    padding: 8px 0;
  }
}
@media (min-width: 761px) {
  #home-pies {
    padding: 24px 28px;
  }
}
#home-pies.--change {
  animation: __change 0.2s;
}

@keyframes __change {
  from {
    opacity: 0.6;
  }
  to {
    opacity: 1;
  }
}
@media (max-width: 760px) {
  .archive-pies {
    padding: 20px 0 21px;
  }
}
@media (min-width: 761px) {
  .archive-pies {
    padding: 24px 28px 25px;
  }
}

.archive-pie {
  overflow: hidden;
  width: 100%;
}
@media (max-width: 760px) {
  .archive-pie {
    padding: 12px 24px;
  }
}

@media (max-width: 760px) {
  .archive-pie:not(:last-child) {
    margin-bottom: 0;
  }
}
@media (min-width: 761px) {
  .archive-pie:not(:last-child) {
    margin-bottom: 32px;
  }
}

@media (min-width: 761px) {
  .archive-pie.--with-image {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
  }
}

@media (max-width: 760px) {
  .archive-pie-image {
    display: block;
    width: 100%;
    margin-bottom: 8px;
  }
}
@media (min-width: 761px) {
  .archive-pie-image {
    margin-top: 4px;
    margin-bottom: 4px;
    margin-right: 24px;
  }
}

.archive-pie-image img {
  object-fit: cover;
}
@media (max-width: 760px) {
  .archive-pie-image img {
    --width: calc(100vw - 48px);
    width: var(--width);
    height: calc(var(--width) * 9 / 16);
  }
}
@media (min-width: 761px) {
  .archive-pie-image img {
    width: 192px;
    height: 108px;
  }
}

@media (max-width: 760px) {
  .archive-pie.--with-image .archive-pie-main {
    width: calc(100vw - 40px);
  }
}
@media (min-width: 761px) {
  .archive-pie.--with-image .archive-pie-main {
    width: calc(100% - 192px - 24px);
  }
}

.archive-pie.--no-image .archive-pie-main {
  width: 100%;
  max-width: 510px;
}

.archive-pie-title {
  margin-bottom: 5px;
}

.archive-pie-title a {
  font-family: "Source Serif 4", "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-size: 17px;
  line-height: 25px;
}

#home-page[data-lang=en] .archive-pie-title a {
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-family: "Source Serif 4", serif;
  font-size: 18px;
  font-weight: 600;
}

.archive-pie-meta {
  display: flex;
  align-items: center;
}

.archive-pie-view {
  font-family: "Work Sans", "Noto Sans JP", sans-serif;
  color: #aaa;
  font-size: 13px;
  line-height: 21px;
}

.archive-pie-author,
.archive-pie-time {
  display: flex;
  align-items: center;
  height: 20px;
  font-family: "Work Sans", "Noto Sans JP", sans-serif;
  font-weight: 400;
  color: #aaa;
  font-size: 12px;
  line-height: 20px;
}

.archive-pie-time {
  position: relative;
  padding-left: 16px;
}

.archive-pie-time::before {
  position: absolute;
  top: 9.2px;
  left: 7px;
  display: inline-block;
  font-size: 0;
  content: "";
  background-color: #aaa;
  width: 2px;
  height: 2px;
  border-radius: 1px;
}

.archive-pie-description {
  color: #aaa;
  font-size: 13px;
  line-height: 19px;
  margin-top: 4px;
}

#roll-page-image img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}

#roll-page h1 {
  font-size: 23px;
  line-height: 31px;
}
@media (max-width: 760px) {
  #roll-page h1 {
    padding: 20px 24px 20px;
  }
}
@media (min-width: 761px) {
  #roll-page h1 {
    padding: 22px 32px 20px;
  }
}

#roll-page-description {
  font-size: 15px;
  line-height: 23px;
}
@media (max-width: 760px) {
  #roll-page-description {
    margin: -4px 32px 20px;
  }
}
@media (min-width: 761px) {
  #roll-page-description {
    margin: -4px 40px 20px;
  }
}

@media (max-width: 760px) {
  #roll-page-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0 24px 16px;
  }
}
@media (min-width: 761px) {
  #roll-page-meta {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 0 28px 16px;
  }
}

@media (max-width: 760px) {
  #roll-page-meta > *:first-child {
    margin-bottom: 16px;
  }
}

.page-author {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.page-author-avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 24px;
  overflow: hidden;
  margin-right: 12px;
}

.page-author-avatar img {
  width: 48px;
  height: 48px;
  border-radius: 24px;
  object-fit: cover;
}

.page-author-main {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.page-author-meta {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.page-author-name,
.page-author-time {
  color: #aaa;
  font-size: 13px;
  line-height: 21px;
}

.page-author-bull {
  color: #aaa;
  font-size: 13px;
  line-height: 21px;
  margin: 0 6px;
}

.page-action {
  display: flex;
  align-items: center;
  justify-content: center;
}

.page-action-icon {
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.page-action-icon img {
  height: 22px;
}

.page-view {
  cursor: pointer;
  display: flex;
  align-items: flex-end;
  margin: 2px 24px 0;
  font-family: "Avenir Next", "Segoe UI", "Helvetica Neue", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "BIZ UDGothic", meiryo, sans-serif;
}

.page-view span {
  font-size: 13px;
  line-height: 15px;
}

.page-view span:first-child {
  font-weight: bold;
  margin-right: 6px;
}