@charset "UTF-8";
.p-wrapper {
  margin-top: var(--section-gap);
}
.p-wrapper__inner {
  container-type: inline-size;
  display: grid;
  grid-template-areas: "main side";
  grid-template-columns: 1fr 280px;
  gap: 80px max(50px, 5cqw);
}
@media (max-width: 1024px) {
  .p-wrapper__inner {
    grid-template-areas: "main" "side";
    grid-template-columns: 1fr;
  }
}
.p-wrapper__main {
  grid-area: main;
}
.p-wrapper__side {
  grid-area: side;
}

.p-archive-title {
  --font-size: 7.3rem;
  margin-bottom: var(--section-gap-sm);
}
@media (max-width: 525px) {
  .p-archive-title {
    --font-size: 5.3rem;
  }
}
.p-archive-title__genre {
  display: block;
  font-size: var(--font-size-md);
}
.p-archive-title__value {
  margin-top: 0.15em;
  font-family: var(--font-english);
}

.p-post-list__item {
  --gap-y: 1.75em;
  container: item/inline-size;
}
.p-post-list__link {
  --image-width: clamp(80px, 20%, 130px);
  display: flex;
  column-gap: 4cqw;
}
.p-post-list__link:is(.p-post-list__item:not(:last-child) > *) {
  padding-bottom: var(--gap-y);
}
.p-post-list__link:is(.p-post-list__item:nth-child(n+2) > *) {
  padding-top: var(--gap-y);
  border-top: 1px solid rgba(var(--color-text-rgb), 20%);
}
.p-post-list__thumb {
  align-self: center;
  width: var(--image-width);
  object-fit: cover;
}
.p-post-list__main {
  display: flex;
  flex: 1;
  column-gap: 3cqw;
  align-items: center;
  padding-block: 1em;
}
.p-post-list__body {
  flex: 1;
  align-self: flex-start;
  transition: opacity 0.25s;
}
.p-post-list__body:is(.p-post-list__link:hover *) {
  opacity: 0.75;
}
.p-post-list__meta {
  display: flex;
  margin-bottom: 0.5em;
  font-size: var(--font-size-sm);
}
.p-post-list__date {
  font-family: var(--font-english);
}
.p-post-list__date::after {
  margin-inline: 0.25em;
  font-weight: bold;
  color: var(--color-primary);
  content: "・";
}
.p-post-list__category {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em;
}
.p-post-list__category__item {
  background-color: rgba(var(--color-bg-secondary-rgb), 50%);
}
.p-post-list__title {
  --max-size: 2rem;
  --min-size: 1.6rem;
}
.p-post-list__excerpt {
  margin-top: 1em;
  font-size: var(--font-size-sm);
}
.p-post-list__arrow {
  --size: min(2.2em, 46px);
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--size);
  height: var(--size);
  font-size: clamp(1.4rem, 3.75cqw, 1.85rem);
  line-height: 1;
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
  border-radius: 50%;
  transition: background 0.3s, color 0.12s;
}
.p-post-list__arrow:is(.p-post-list__link:hover *) {
  color: var(--color-text-contrast);
  background-color: var(--color-primary);
}

.p-side {
  container: side/inline-size;
  position: sticky;
  top: calc(var(--header-height) + 20px);
  background-color: var(--color-secondary);
  border-radius: var(--radius-md);
}
.p-side__inner {
  --column-count: 1;
  --column-gap: 0px;
  --row-gap: 0px;
  padding: max(5cqw, 2em);
}
@container side (width > 640px) {
  .p-side__inner {
    --column-count: 2;
  }
}

.p-side-box {
  --gap-x: 2em;
  --gap-y: 2em;
  --border: 1px solid rgba(var(--color-text-rgb), 20%);
}
@container side (width > 640px) {
  .js-has-pseudo [csstools-has-1a-34-19-37-2x-2s-2t-19-2q-33-3c-1m-2w-2p-37-14-17-w-1a-34-19-37-2x-2s-2t-19-2q-33-3c-15]:not(.does-not-exist) {
    padding-right: var(--gap-x);
  }
  .p-side-box:has(+ .p-side-box) {
    padding-right: var(--gap-x);
  }
  .p-side-box + .p-side-box {
    padding-left: var(--gap-x);
    border-left: var(--border);
  }
}
@container side (width <= 640px) {
  .p-side-box + .p-side-box {
    padding-top: var(--gap-y);
    margin-top: var(--gap-y);
    border-top: var(--border);
  }
}
.p-side-box__header {
  margin-bottom: 1em;
}
.p-side-box__heading {
  --padding-top: 0;
  --padding-bottom: 0.1em;
  --min-height: 1.75em;
  --slash-size: 1em;
  --heading-size: var(--font-size-xxxl);
  margin-bottom: 0.15em;
}
.p-side-box__caption {
  display: none;
  width: fit-content;
  margin-right: 1.75em;
  margin-left: auto;
  opacity: 0.5;
}
.p-side-box__list:is(.p-side-box--archive *) {
  letter-spacing: 0.12em;
}
.p-side-box__link {
  --bar-width: 12px;
  --bar-space: 10px;
  position: relative;
  z-index: 0;
  display: inline-flex;
  gap: 0.75em;
  align-items: center;
  padding-block: 0.4em;
  padding-left: calc(var(--bar-width) + var(--bar-space));
}
.p-side-box__link::before {
  position: absolute;
  top: 50%;
  left: 0;
  width: var(--bar-width);
  height: 2px;
  content: "";
  background-color: var(--color-primary);
  opacity: 0;
  transition: opacity 0.25s;
}
.p-side-box__link:hover::before {
  opacity: 1;
}
.p-side-box__link__text {
  transition: opacity 0.2s;
}
.p-side-box__link__text:is(:hover > *) {
  opacity: 0.75;
}

.p-pagination {
  --button-size: 3.1em;
  --button-bg-color: var(--color-primary);
  --button-text-color: var(--color-text-contrast);
  --button-hover-text-color: var(--color-text-contrast);
  --button-hover-bg-color: rgba(var(--color-primary-rgb), 80%);
  --button-disabled-bg-color: rgba(var(--color-primary-rgb), 15%);
  --button-disabled-text-color: rgba(var(--color-primary-rgb), 100%);
  display: flex;
  flex-wrap: wrap;
  gap: 0.6em;
  align-items: center;
  justify-content: center;
  margin-top: 3em;
}
.p-pagination > .page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--button-size);
  height: var(--button-size);
  line-height: 1;
  text-align: center;
  border-radius: var(--radius-md);
}
.p-pagination > .page-numbers[href] {
  position: relative;
  z-index: 0;
  overflow: hidden;
  color: var(--button-text-color);
  background: var(--button-bg-color);
  transition: background 0.25s, color 0.15s;
}
.p-pagination > .page-numbers[href]:hover {
  color: var(--button-hover-text-color);
  background-color: var(--button-hover-bg-color);
}
.p-pagination > .page-numbers.current {
  color: var(--button-disabled-text-color);
  pointer-events: none;
  background-color: var(--button-disabled-bg-color);
}
.p-pagination > .page-numbers.dots {
  width: auto;
  padding-bottom: 0.5em;
}

.p-post__header {
  padding-bottom: 2.5em;
  margin-bottom: 3.5em;
  border-bottom: 1px solid rgba(var(--color-text-rgb), 35%);
}
.p-post__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75em;
  align-items: center;
  margin-bottom: 0.5em;
}
.p-post__date {
  font-size: var(--font-size-lg);
  letter-spacing: 0.12em;
}
.p-post__category {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em;
  font-size: var(--font-size-xs);
  line-height: 1;
}
.p-post__category__link {
  --button-bg-color: var(--color-primary);
  --button-text-color: var(--color-text-contrast);
  --button-hover-text-color: var(--color-text-contrast);
  --button-hover-bg-color: rgba(var(--color-primary-rgb), 80%);
  --button-height: 2.45em;
  z-index: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  height: var(--button-height);
  padding: 0.25em 1em;
  overflow: hidden;
  color: var(--button-text-color);
  text-align: center;
  background: var(--button-bg-color);
  transition: background 0.25s, color 0.15s;
}
.p-post__category__link:hover {
  color: var(--button-hover-text-color);
  background-color: var(--button-hover-bg-color);
}
.p-post__eyecatch {
  width: 100%;
  margin-bottom: 3.5em;
  overflow: hidden;
  border-radius: var(--radius-md);
}
.p-post__eyecatch > img {
  display: block;
  width: 100%;
}
.p-post__body {
  max-width: 700px;
  margin-inline: auto;
}
.p-post__body h1,
.p-post__body h2,
.p-post__body h3,
.p-post__body h4,
.p-post__body h5,
.p-post__body h6 {
  --bar-width: 8px;
  position: relative;
  padding-left: calc(var(--bar-width) * 3);
  margin-bottom: 1em;
  font-weight: bold;
  line-height: 1.45;
}
.p-post__body h1::before,
.p-post__body h2::before,
.p-post__body h3::before,
.p-post__body h4::before,
.p-post__body h5::before,
.p-post__body h6::before {
  position: absolute;
  top: 0.1em;
  bottom: 0.1em;
  left: 0;
  width: var(--bar-width);
  margin-top: 0.1em;
  content: "";
  background-color: currentcolor;
}
.p-post__body h1 {
  font-size: 1.6em;
}
.p-post__body h2 {
  font-size: 1.45em;
}
.p-post__body h3 {
  font-size: 1.3em;
}
.p-post__body h4 {
  font-size: 1.2em;
}
.p-post__body h5 {
  font-size: 1.12em;
}
.p-post__body h6 {
  font-size: 1em;
}
.p-post__body img {
  max-width: 100%;
}
.p-post__body iframe {
  max-width: 100%;
  margin-top: 1em;
  margin-bottom: 1em;
}
.p-post__body iframe[src^="https://www.youtube.com/"] {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}
.p-post__body iframe[src^="https://www.google.com/maps/"] {
  width: 100%;
  height: auto;
  max-height: 500px;
  aspect-ratio: 1.35/1;
}
.p-post__body ul,
.p-post__body ol {
  list-style: none;
}
.p-post__body ul {
  --prefix: "・";
}
.p-post__body ol {
  --prefix: counter(list) ".";
  counter-reset: list;
}
.p-post__body ol > li {
  counter-increment: list;
}
.p-post__body li {
  position: relative;
  padding-left: 1.3em;
}
.p-post__body li::before {
  position: absolute;
  top: 0;
  left: 0;
  content: var(--prefix);
}
.p-post__body p + p {
  margin-top: 1em;
}
.p-post__body a {
  text-decoration: underline;
  text-underline-offset: 0.15em;
  transition: opacity 0.2s;
}
.p-post__body a:hover {
  opacity: 0.65;
}
.p-post__body hr {
  --border-width: 3px;
  --dot-gap-ratio: 2;
  position: relative;
  padding-top: var(--border-width);
  margin: 1em 0;
  border: none;
}
.p-post__body hr::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--border-width);
  content: "";
  background: radial-gradient(circle farthest-side, currentcolor, currentcolor calc(100% / (var(--dot-gap-ratio) + 1)), transparent calc(100% / (var(--dot-gap-ratio) + 1)));
  background-repeat: repeat-x;
  background-position: left;
  background-size: calc(var(--border-width) * (var(--dot-gap-ratio) + 1)) var(--border-width);
}
.p-post__footer {
  margin-top: 3em;
}

.p-post-nav {
  position: relative;
  z-index: 0;
  max-width: 700px;
  margin-inline: auto;
}
.p-post-nav__prev-next {
  --border: 1px solid rgba(var(--color-text-rgb), 50%);
  position: relative;
  display: grid;
  grid-template-areas: "prev next";
  grid-template-columns: 1fr 1fr;
  margin-bottom: 3em;
  border-top: var(--border);
  border-bottom: var(--border);
}
.p-post-nav__prev-next::before {
  position: absolute;
  top: 1em;
  bottom: 1em;
  left: 50%;
  z-index: -1;
  width: 1px;
  content: "";
  background-color: var(--color-text);
  opacity: 0.25;
}
.p-post-nav__prev-next__link {
  display: flex;
  column-gap: 1em;
  align-items: center;
  justify-content: center;
  padding: 1.5em 1em;
  transition: color 0.25s;
}
.p-post-nav__prev-next__link:hover {
  color: var(--color-primary);
}
.p-post-nav__prev-next__link.is-prev {
  grid-area: prev;
}
.p-post-nav__prev-next__link.is-next {
  grid-area: next;
}
.p-post-nav__index {
  --button-bg-color: var(--color-primary);
  --button-text-color: var(--color-text-contrast);
  --button-hover-text-color: var(--color-text-contrast);
  --button-hover-bg-color: rgba(var(--color-primary-rgb), 80%);
  display: flex;
  gap: 0.75em;
  align-items: center;
  justify-content: center;
  width: 15em;
  padding: 1em 2em;
  margin-inline: auto;
  line-height: 1;
  color: var(--button-text-color);
  background: var(--button-bg-color);
  border-radius: var(--radius-md);
  transition: background 0.25s, color 0.15s;
}
.p-post-nav__index:hover {
  color: var(--button-hover-text-color);
  background-color: var(--button-hover-bg-color);
}
.p-post-nav__index__icon {
  margin-top: 0.13em;
}