@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;
}

.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__pie-list {
  width: 100%;
}
@media (max-width: 760px) {
  .home__pie-list {
    padding: 8px 0;
  }
}
@media (min-width: 761px) {
  .home__pie-list {
    padding: 24px 28px;
  }
}
.home__pie-list.--change {
  animation: __change 0.2s;
}

@keyframes __change {
  from {
    opacity: 0.6;
  }
  to {
    opacity: 1;
  }
}
#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;
}

.user-page__info {
  display: flex;
  width: 100%;
}
@media (max-width: 760px) {
  .user-page__info {
    align-items: flex-start;
    justify-content: flex-start;
  }
}
@media (min-width: 761px) {
  .user-page__info {
    align-items: flex-start;
    justify-content: space-between;
  }
}

.user-page__banner {
  width: 100%;
}
.user-page__banner:empty {
  display: none;
}
.user-page__banner img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}

.user-page__avatar {
  margin-top: 16px;
  margin-left: 16px;
  width: 96px;
  height: 96px;
  border-radius: 48px;
  overflow: hidden;
}

.user-page__avatar img {
  width: 96px;
  height: 96px;
  border-radius: 48px;
  object-fit: cover;
}

.user-page__user-main {
  width: calc(100% - 112px);
}

@media (max-width: 760px) {
  .user-page__primary {
    display: flex;
    flex-direction: column-reverse;
    align-items: flex-end;
    padding: 24px 24px 0 0;
  }
}
@media (min-width: 761px) {
  .user-page__primary {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 24px 24px 20px 24px;
  }
}

.user-page__display-name {
  font-family: "Source Serif 4", "Noto Serif JP", serif;
  overflow-x: hidden;
  max-width: 200px;
  font-size: 20px;
  line-height: 28px;
}
@media (max-width: 760px) {
  .user-page__display-name {
    margin-top: 20px;
  }
}

.user-page__bio {
  font-family: "Source Serif 4", "Noto Serif JP", serif;
  font-size: 14px;
  line-height: 22px;
}
@media (min-width: 761px) {
  .user-page__bio {
    max-width: 480px;
  }
}

@media (max-width: 760px) {
  .user-page__bio.--in-main {
    display: none;
  }
}
@media (min-width: 761px) {
  .user-page__bio.--in-main {
    padding-left: 24px;
  }
}

.user-page__bio.--outside-header {
  padding: 24px 24px 0;
}
@media (min-width: 761px) {
  .user-page__bio.--outside-header {
    display: none;
  }
}

.user-page__user-controller {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.user-page__user-tabs a {
  font-size: 15px;
  line-height: 23px;
}

.user-page__aside {
  display: flex;
  align-items: center;
  justify-content: center;
}

.user-page__action {
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 16px;
}

.user-page__action img {
  height: 22px;
}

.user-page__stat {
  cursor: pointer;
  display: flex;
  align-items: flex-end;
  margin: 2px 8px 0 24px;
}

.user-page__stat span {
  font-family: "Rubik", "Noto Sans JP", sans-serif;
  font-size: 13px;
  line-height: 15px;
}

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

.user-page__nav {
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 24px;
}

.user-page__tabs {
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 760px) {
  .user-page__tabs {
    margin-left: 24px;
  }
}
@media (min-width: 761px) {
  .user-page__tabs {
    margin-left: 28px;
  }
}

.user-page__tabs a {
  font-family: "Rubik", "Noto Sans JP", sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  line-height: 18px;
  height: 32px;
}
@media (max-width: 760px) {
  .user-page__tabs a {
    padding: 0 16px;
  }
}
@media (min-width: 761px) {
  .user-page__tabs a {
    padding: 0 20px;
  }
}

.user-page__tabs > a:first-child {
  margin-right: 16px;
}

.user-page__tab-selected {
  font-weight: bold;
  position: relative;
}

.user-page__tab-selected::before {
  position: absolute;
  display: inline-block;
  content: "";
  top: 0;
  bottom: 0;
  left: 0;
  width: 8px;
  border-top: 1px solid #3d3d3d;
  border-left: 1px solid #3d3d3d;
  border-bottom: 1px solid #3d3d3d;
  border-top-left-radius: 2px;
  border-bottom-left-radius: 2px;
}

.user-page__tab-selected::after {
  position: absolute;
  display: inline-block;
  content: "";
  top: 0;
  bottom: 0;
  right: 0;
  width: 8px;
  border-top: 1px solid #3d3d3d;
  border-right: 1px solid #3d3d3d;
  border-bottom: 1px solid #3d3d3d;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 2px;
}

.user-page__pager {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.user-page__pager.--close {
  display: none;
}

.user-page__counter {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
@media (max-width: 760px) {
  .user-page__counter {
    display: none;
  }
}
@media (min-width: 761px) {
  .user-page__counter {
    padding-right: 8px;
  }
}

.user-page__counter span:first-child,
.user-page__counter span:last-child {
  font-family: "Rubik", "Noto Sans JP", sans-serif;
  font-size: 13px;
  line-height: 16px;
  height: 16px;
}

.user-page__counter > span:nth-child(2) {
  font-size: 12px;
  line-height: 16px;
  height: 16px;
  margin: 0 6px;
}

.user-page__controls {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-right: 32px;
}

.user-page__controls > div.--close {
  display: none;
}

.user-page__controls a {
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  margin-left: 24px;
}

.user-page__controls img {
  width: 24px;
}

.user-page__controls img.--previous {
  transform: scale(-1, -1);
}

.user-page__guide-wrapper {
  display: flex;
  justify-content: center;
}
@media (max-width: 760px) {
  .user-page__guide-wrapper {
    padding: 24px 0 0;
  }
}
@media (min-width: 761px) {
  .user-page__guide-wrapper {
    padding: 28px 28px 0;
  }
}

.user-page__guide {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  border-radius: 20px;
  background: #fafafa;
  width: 100%;
  max-width: 560px;
}
@media (max-width: 760px) {
  .user-page__guide {
    padding: 52px calc(28px + 6px) calc(28px - 4px);
  }
}
@media (min-width: 761px) {
  .user-page__guide {
    padding: 44px calc(32px + 6px) calc(32px - 4px);
  }
}

.user-page__guide-title {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 48px;
  border-radius: 24px;
  position: absolute;
  top: -23px;
  font-family: "Source Serif 4", "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 15px;
  line-height: 28px;
  background-color: white;
  border: 1px dotted #e7e7e7;
  padding: 0 22px;
}

.user-page__guide-body {
  width: 100%;
}

.user-page__guide-section {
  margin-bottom: 32px;
}
.user-page__guide-section:last-child {
  margin-bottom: 0;
}

.user-page__guide-section h2 {
  font-family: "Source Serif 4", "Noto Serif JP", serif;
  font-size: 17px;
  font-weight: 500;
  line-height: 25px;
  margin-bottom: 10px;
}

.user-page__guide-section p {
  font-family: "Work Sans", "Noto Sans JP", sans-serif;
  font-size: 14px;
  line-height: 22px;
  color: #888;
  margin-bottom: 4px;
}

.user-page__guide-section ul {
  font-family: "Work Sans", "Noto Sans JP", sans-serif;
  font-size: 14px;
  line-height: 22px;
  color: #888;
  margin: 8px 0 0;
  padding-left: 20px;
}

.user-page__guide-section li {
  position: relative;
  padding-left: 10px;
  font-size: 14px;
  line-height: 22px;
  margin-bottom: 2px;
  color: #888;
}
.user-page__guide-section li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 2px;
  height: 2px;
  background-color: #888;
  border-radius: 50%;
}

.user-page__guide-section .--highlight {
  color: #eb711a;
  font-weight: 500;
}

.user-page__guide-consoles {
  padding: 12px 0 0 20px;
}

.user-page__guide-console:not(:last-child) {
  margin-bottom: 14px;
}

.user-page__guide-console div {
  position: relative;
  padding: 4px 22px;
}

.user-page__guide-console div::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 0;
  bottom: 0;
  width: 1px;
  background-color: #1f1f1f;
}

.user-page__guide-console h3 {
  font-family: "Source Serif 4", "Noto Serif JP", serif;
  font-size: 14px;
  font-weight: 500;
  line-height: 22px;
  margin-bottom: 4px;
}

.user-page__guide-console p {
  font-family: "Work Sans", "Noto Sans JP", sans-serif;
  font-size: 12px;
  line-height: 1.4;
}

.user-page__guide-console div p {
  margin-bottom: 4px;
}

.user-page__guide-console div p:last-child {
  margin-bottom: 0;
}

.user-page__inline-icon {
  width: 16px;
  height: 16px;
  vertical-align: middle;
  margin: 0 2px;
}

.user-page__content {
  width: 100%;
}
@media (max-width: 760px) {
  .user-page__content {
    padding: 8px 0;
  }
}
@media (min-width: 761px) {
  .user-page__content {
    padding: 24px 28px;
  }
}
.user-page__content.--change {
  animation: __change 0.2s;
}

@keyframes __change {
  from {
    opacity: 0.6;
  }
  to {
    opacity: 1;
  }
}
@media (max-width: 760px) {
  .user-page__empty-state {
    padding: 40px 24px;
  }
}
@media (min-width: 761px) {
  .user-page__empty-state {
    padding: 48px 28px;
  }
}

.user-page__empty-message {
  font-family: "Work Sans", "Noto Sans JP", sans-serif;
  font-size: 14px;
  line-height: 22px;
  color: #aaa;
  text-align: center;
}