@charset "UTF-8";
.p-wrapper {
  padding-top: 120px;
  padding-bottom: 220px;
  background-color: rgba(var(--color-bg-secondary-rgb), 25%);
}
@media (max-width: 525px) {
  .p-wrapper {
    padding-top: 80px;
    padding-bottom: 180px;
  }
}
.p-wrapper__inner {
  container-type: inline-size;
  display: grid;
  grid-template-areas: "main side";
  grid-template-columns: 1fr 260px;
  gap: 80px 50px;
}
@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: 2em;
}
@media (max-width: 525px) {
  .p-archive-title {
    --font-size: 5.3rem;
  }
}
.p-archive-title__genre {
  font-family: var(--font-english);
  font-size: 0.95em;
}
.p-archive-title__genre::after {
  margin-right: 0.5em;
  margin-left: 0.2em;
  content: ":";
}
.p-archive-title__value {
  margin-top: 0.1em;
  font-family: var(--font-english);
}

.p-post-list {
  display: grid;
  gap: 3em;
}
.p-post-list__link {
  --row-gap: 1.5em;
  --column-gap: 0;
  --gap-top: 1.5em;
  --gap-left: 3em;
  --bg-padding-top: 2em;
  --bg-padding-bottom: 2em;
  transition: opacity 0.2s;
}
@container image-section (max-width: 550px) {
  .p-post-list__link {
    --gap-top: 30cqw;
    --gap-left: 0;
  }
}
.p-post-list__link:hover {
  opacity: 0.7;
}
.p-post-list__thumb {
  aspect-ratio: 1.45/1;
  object-fit: cover;
}
.p-post-list__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75em;
  align-items: center;
  margin-bottom: 0.5em;
}
.p-post-list__date {
  font-family: var(--font-english);
}
.p-post-list__category {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em;
  font-size: var(--font-size-sm);
  line-height: 1;
}
.p-post-list__category__item {
  padding: 0.5em 1em;
  background-color: rgba(var(--color-bg-secondary-rgb), 50%);
}
.p-post-list__body {
  padding-right: min(2em, var(--container-padding));
  padding-left: min(2em, var(--container-padding));
}
.p-post-list__title {
  margin-bottom: 0.5em;
}
.p-post-list__excerpt {
  font-size: var(--font-size-sm);
}

.p-side {
  container-type: inline-size;
  position: sticky;
  top: calc(var(--header-height) + 20px);
}
.p-side__inner {
  --column-count: 1;
  --column-gap: 5em;
  --row-gap: 5em;
}
@container (width > 640px) {
  .p-side__inner {
    --column-count: 2;
  }
}

.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;
  font-family: var(--font-english);
}
.p-side-box__caption {
  display: none;
  width: -moz-fit-content;
  width: fit-content;
  margin-right: 1.75em;
  margin-left: auto;
  opacity: 0.5;
}
.p-side-box__list:is(.p-side-box--archive *) {
  font-family: var(--font-english);
}
.p-side-box__link {
  position: relative;
  z-index: 0;
  display: flex;
  gap: 0.75em;
  align-items: center;
  padding: 0.35em 1em;
  transition: all 0.18s;
}
.p-side-box__link:hover {
  opacity: 0.5;
}
.p-side-box__link::before {
  position: relative;
  width: 0.65em;
  height: 1px;
  content: "";
  background: currentcolor;
  opacity: 0.8;
}
.p-side-box__link__text {
  position: relative;
  font-variant-numeric: tabular-nums;
  transition: transform 0.18s;
}
.p-side-box__link__text:is(:hover > *) {
  transform: translateX(0.25em);
}

.p-pagination {
  --button-size: 3.1em;
  --button-color: var(--color-primary);
  --button-text-color: var(--color-text-contrast);
  --button-hover-color: rgba(var(--color-text-contrast-rgb), 35%);
  --button-disabled-bg-color: rgba(var(--color-bg-secondary-rgb), 50%);
  --button-disabled-text-color: rgba(var(--color-text-primary-rgb), 50%);
  display: flex;
  flex-wrap: wrap;
  gap: 0.6em;
  align-items: center;
  justify-content: center;
  margin-top: 3em;
}
.p-pagination:where(body[data-theme=gold] *) {
  --button-color: linear-gradient(var(--slash-deg), var(--color-wheat), var(--color-ocher));
}
.p-pagination:where(body[data-theme=blue] *) {
  --button-color: rgba(var(--color-primary-rgb), 65%);
}
.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;
}
.p-pagination > .page-numbers[href] {
  position: relative;
  position: relative;
  z-index: 0;
  overflow: hidden;
  color: var(--button-text-color);
  background: var(--button-color);
}
.p-pagination > .page-numbers[href]::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: calc(100% + var(--button-size));
  height: 100%;
  margin-left: calc(var(--button-size) * 0.5 * -1);
  cursor: inherit;
  content: "";
  background: var(--button-hover-color);
  transform: skewX(var(--slash-deg));
  animation-name: button-hover-out;
  animation-duration: 0.45s;
  animation-timing-function: var(--ease-out-quart);
  animation-fill-mode: forwards;
}
@keyframes button-hover {
  0% {
    opacity: 0;
    transform: skewX(var(--slash-deg)) translateX(-100%);
  }
  100% {
    opacity: 1;
    transform: skewX(var(--slash-deg)) translateX(0);
  }
}
@keyframes button-hover-out {
  0% {
    opacity: 1;
    transform: skewX(var(--slash-deg)) translateX(0);
  }
  50% {
    opacity: 0.5;
  }
  100% {
    opacity: 0;
    transform: skewX(var(--slash-deg)) translateX(100%);
  }
}
.p-pagination > .page-numbers[href]:hover::before {
  animation-name: button-hover;
  animation-duration: 0.45s;
  animation-timing-function: var(--ease-out-quart);
  animation-fill-mode: forwards;
}

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

.p-post__main {
  padding: max(var(--container-padding), 36px) var(--container-padding);
  background-color: var(--color-bg-primary);
}
@media (max-width: 768px) {
  .p-post__main {
    margin-inline: calc(50% - 50 * var(--vw));
  }
}
.p-post__header {
  margin-bottom: 2.5em;
}
.p-post__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75em;
  align-items: center;
  margin-bottom: 0.5em;
}
.p-post__date {
  font-family: var(--font-english);
  font-size: var(--font-size-lg);
  font-weight: bold;
}
.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-color: var(--color-primary);
  --button-text-color: var(--color-text-contrast);
  --button-hover-color: rgba(var(--color-text-contrast-rgb), 35%);
  --button-height: 2.45em;
  position: relative;
  z-index: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: -moz-fit-content;
  width: fit-content;
  height: var(--button-height);
  padding: 0.25em 1em;
  overflow: hidden;
  color: var(--button-text-color);
  text-align: center;
  background: var(--button-color);
}
.p-post__category__link:where(body[data-theme=gold] *) {
  --button-color: linear-gradient(var(--slash-deg), var(--color-wheat), var(--color-ocher));
}
.p-post__category__link:where(body[data-theme=blue] *) {
  --button-color: rgba(var(--color-primary-rgb), 65%);
}
.p-post__category__link::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: calc(100% + var(--button-height));
  height: 100%;
  margin-left: calc(var(--button-height) * 0.5 * -1);
  cursor: inherit;
  content: "";
  background: var(--button-hover-color);
  transform: skewX(var(--slash-deg));
  animation-name: button-hover-out;
  animation-duration: 0.6s;
  animation-timing-function: var(--ease-out-quart);
  animation-fill-mode: forwards;
}
@keyframes button-hover {
  0% {
    opacity: 0;
    transform: skewX(var(--slash-deg)) translateX(-100%);
  }
  100% {
    opacity: 1;
    transform: skewX(var(--slash-deg)) translateX(0);
  }
}
@keyframes button-hover-out {
  0% {
    opacity: 1;
    transform: skewX(var(--slash-deg)) translateX(0);
  }
  50% {
    opacity: 0.5;
  }
  100% {
    opacity: 0;
    transform: skewX(var(--slash-deg)) translateX(100%);
  }
}
.p-post__category__link:hover::before {
  animation-name: button-hover;
  animation-duration: 0.6s;
  animation-timing-function: var(--ease-out-quart);
  animation-fill-mode: forwards;
}

.p-post__title {
  --slash-size: 1.5em;
  --min-height: 2.25em;
}
.p-post__eyecatch {
  width: 100%;
  margin-top: 1em;
}
.p-post__eyecatch > img {
  display: block;
  width: 100%;
}
.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-height: 2px;
  --border-filled-width: 8px;
  --border-gap-width: 8px;
  position: relative;
  padding-top: var(--border-height);
  margin: 1em 0;
  border: none;
}
.p-post__body hr::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--border-height);
  content: "";
  background-image: linear-gradient(to right, currentcolor, currentcolor var(--border-filled-width), transparent var(--border-filled-width));
  background-repeat: repeat-x;
  background-size: calc(var(--border-filled-width) + var(--border-gap-width)) var(--border-height);
}
.p-post__footer {
  margin-top: 3em;
}

.p-post-nav__list {
  display: flex;
  gap: min(1em, 3cqw);
  align-items: center;
  justify-content: space-between;
}
.p-post-nav__item {
  flex: 1;
  max-width: 220px;
}
.p-post-nav__link {
  display: flex;
  gap: 1em;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-width: unset;
  padding-right: 1.5em;
  padding-left: 0.5em;
  text-align: center;
}
.p-post-nav__link:where(.is-next) {
  padding-right: 1em;
  padding-left: 1em;
}
@container (width <= 600px) {
  .p-post-nav__link {
    gap: 0.5em;
    padding-right: 0.5em;
    padding-left: 0.5em;
    font-size: var(--font-size-sm);
  }
}
.p-post-nav__link::after {
  display: none;
}