*,
:before,
::before,
:after,
::after {
  box-sizing: border-box;
}

* {
  border: 0;
  border-radius: 0;
  margin: 0;
  outline: 0;
  padding: 0;
}

a,
blockquote,
button,
code,
div,
figcaption,
h1,
h2,
h3,
input[type=email],
input[type=text],
input[type=password],
li,
ol,
option,
p,
pre,
select,
span,
strong,
sub,
sup,
td,
textarea,
th,
ul {
  color: #1f1f1f;
}

a,
blockquote,
body,
br,
button,
code,
div,
figure,
figcaption,
h1,
h2,
h3,
html,
iframe,
img,
input,
li,
ol,
option,
p,
pre,
select,
span,
strong,
sub,
sup,
table,
tbody,
td,
th,
thead,
tr,
ul {
  -webkit-appearance: none;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
  font-size: 100%;
  vertical-align: baseline;
}

body {
  font-family: BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "BIZ UDGothic", meiryo, sans-serif;
  font-size: 0;
  line-height: 1;
  -webkit-text-size-adjust: 100%;
}

a {
  background: transparent;
  font-size: 0;
  margin: 0;
  padding: 0;
  text-decoration: none;
  vertical-align: baseline;
}

p a {
  font-size: 100%;
  font-weight: bold;
}

strong {
  font-size: 100%;
  vertical-align: baseline;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

img {
  font-size: 0;
  max-width: 100%;
}

svg {
  border: 0;
  stroke-width: 0;
}

ol,
ul {
  list-style: none;
}

::-webkit-scrollbar {
  display: none;
}

::-webkit-calendar-picker-indicator {
  display: none;
}

::-webkit-resizer {
  display: none;
}

#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 24px 21px;
  }
}
@media (min-width: 761px) {
  .archive-pies {
    padding: 24px 28px 25px;
  }
}

.archive-pies .archive-pie:not(:last-child) {
  margin-bottom: 33px;
}

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