:root {
  --iriya-archive-bg: #fffafd;
  --iriya-archive-ink: #4d3b72;
  --iriya-archive-deep: #332452;
  --iriya-archive-muted: #7f7395;
  --iriya-archive-purple: #8d6fbd;
  --iriya-archive-lavender: #f3ecfb;
  --iriya-archive-pink: #f4c7dd;
  --iriya-archive-gold: #c89b45;
  --iriya-archive-border: rgba(119, 94, 157, 0.15);
  --iriya-archive-shadow: 0 18px 42px rgba(86, 63, 126, 0.13);
}

body.blog,
body.archive,
body.search {
  background:
    radial-gradient(circle at 12% 10%, rgba(246, 218, 236, 0.38), transparent 22%),
    radial-gradient(circle at 86% 18%, rgba(218, 203, 244, 0.46), transparent 24%),
    linear-gradient(180deg, #fffafd 0%, #fbf5ff 54%, #fff 100%);
  color: var(--iriya-archive-ink);
}

.iriya-archive {
  overflow: hidden;
  color: var(--iriya-archive-ink);
  background:
    radial-gradient(circle at 4% 28%, rgba(255, 255, 255, 0.96), transparent 16%),
    radial-gradient(circle at 92% 52%, rgba(238, 226, 251, 0.8), transparent 18%),
    linear-gradient(180deg, #fffafd 0%, #fbf6ff 50%, #fff 100%);
}

.iriya-archive * {
  box-sizing: border-box;
}

.iriya-archive a {
  color: inherit;
  text-decoration: none;
}

.iriya-archive-hero {
  position: relative;
  aspect-ratio: 1717 / 737;
  min-height: 0;
  overflow: hidden;
  background: linear-gradient(90deg, #fff8fd, #f5ebfb);
}

.iriya-archive-hero::after {
  content: none;
}

.iriya-archive-hero__image {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: url("../images/archives-hero-pc.webp");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 100% auto;
}

.iriya-archive-hero__inner {
  position: relative;
  z-index: 2;
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
  min-height: inherit;
}

.iriya-archive-category-strip {
  position: relative;
  z-index: 5;
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 10px;
  width: min(1180px, calc(100% - 32px));
  margin: 24px auto 34px;
}

.iriya-archive-category-strip a {
  display: grid;
  place-items: center;
  gap: 10px;
  min-width: 0;
  min-height: 116px;
  padding: 14px 8px;
  border: 1px solid rgba(119, 94, 157, 0.1);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 14px 30px rgba(86, 63, 126, 0.12);
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.iriya-archive-category-strip a:hover,
.iriya-archive-category-strip a.is-current {
  border-color: rgba(200, 155, 69, 0.42);
  transform: translateY(-3px);
  box-shadow: 0 18px 34px rgba(86, 63, 126, 0.16);
}

.iriya-archive-category-strip span {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  color: #b97ab7;
}

.iriya-archive-category-strip svg {
  width: 38px;
  height: 38px;
  fill: currentColor;
  filter: drop-shadow(0 5px 8px rgba(137, 84, 147, 0.12));
}

.iriya-archive-category-strip strong {
  color: #463554;
  font-size: 0.92rem;
  line-height: 1.35;
  text-align: center;
}

.iriya-archive__inner {
  width: min(1280px, calc(100% - 32px));
  margin: 0 auto;
  padding-bottom: 58px;
}

.iriya-archive-section-heading {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 18px;
  margin: 0 0 18px;
}

.iriya-archive-section-heading h2 {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0;
  color: var(--iriya-archive-deep);
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: clamp(1.35rem, 2vw, 1.82rem);
  font-weight: 700;
  letter-spacing: 0.08em;
}

.iriya-archive-section-heading h2::before {
  content: "";
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  background: linear-gradient(135deg, #e3bd58 0%, #c8952f 58%, #a9781f 100%);
  clip-path: polygon(50% 0, 61% 31%, 95% 31%, 68% 50%, 79% 83%, 50% 63%, 21% 83%, 32% 50%, 5% 31%, 39% 31%);
  filter: drop-shadow(0 2px 2px rgba(129, 85, 28, 0.12));
}

.iriya-archive-ranking {
  margin-bottom: 22px;
}

.iriya-archive-ranking__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  align-items: stretch;
}

.iriya-archive-card {
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--iriya-archive-border);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--iriya-archive-shadow);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.iriya-archive-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 22px 48px rgba(86, 63, 126, 0.16);
}

.iriya-archive-card a {
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

.iriya-archive-card__image {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 40%, rgba(244, 199, 221, 0.52), transparent 34%),
    linear-gradient(135deg, #f8f1ff, #fff);
}

.iriya-archive-card__image img,
.iriya-archive-card__placeholder {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.iriya-archive-card__placeholder {
  display: grid;
  place-items: center;
  color: #a178be;
}

.iriya-archive-card__placeholder svg {
  width: 54px;
  height: 54px;
  fill: currentColor;
  opacity: 0.72;
}

.iriya-archive-card__rank {
  position: absolute;
  top: -10px;
  left: -6px;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 62px;
  height: 62px;
  border: 2px solid rgba(255, 255, 255, 0.85);
  border-radius: 50%;
  color: #fff;
  font-family: Georgia, serif;
  font-size: 1.6rem;
  background:
    radial-gradient(circle at 35% 25%, #f5d879, #c99026 64%, #a97416);
  box-shadow: 0 9px 18px rgba(128, 81, 25, 0.2);
}

.iriya-archive-card__rank::before {
  content: "";
  position: absolute;
  top: -12px;
  width: 34px;
  height: 18px;
  background: linear-gradient(135deg, #f2cc67, #bf8b2e);
  clip-path: polygon(0 100%, 12% 18%, 35% 55%, 50% 0, 65% 55%, 88% 18%, 100% 100%);
}

.iriya-archive-card__category {
  position: absolute;
  left: 14px;
  bottom: 0;
  z-index: 2;
  max-width: calc(100% - 28px);
  padding: 5px 13px;
  border-radius: 999px 999px 0 0;
  color: #7e5aa2;
  font-size: 0.78rem;
  font-weight: 700;
  background: rgba(250, 235, 249, 0.95);
  box-shadow: 0 -4px 14px rgba(83, 65, 113, 0.08);
}

.iriya-archive-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-width: 0;
  padding: 18px 18px 17px;
}

.iriya-archive-card__body h3 {
  margin: 0;
  color: #302546;
  font-size: 1rem;
  line-height: 1.65;
  letter-spacing: 0.02em;
}

.iriya-archive-card__body p {
  margin: 10px 0 0;
  color: #625773;
  font-size: 0.84rem;
  line-height: 1.7;
}

.iriya-archive-card__body time {
  margin-top: auto;
  padding-top: 14px;
  color: #9d93aa;
  font-size: 0.82rem;
}

.iriya-archive-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 260px;
  gap: 24px;
  align-items: start;
}

.iriya-archive-latest,
.iriya-archive-sidebar,
.iriya-archive-panel {
  min-width: 0;
}

.iriya-archive-panel,
.iriya-archive-widget {
  border: 1px solid var(--iriya-archive-border);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: var(--iriya-archive-shadow);
}

.iriya-archive-panel {
  padding: 20px 18px 24px;
}

.iriya-archive-section-heading--tabs h2::before {
  width: 6px;
  height: 34px;
  border-radius: 999px;
  background: linear-gradient(180deg, #d7b55f, #a980bd);
  clip-path: none;
}

.iriya-archive-latest__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.iriya-archive-sidebar {
  display: grid;
  gap: 18px;
  align-content: start;
}

.iriya-archive-widget {
  padding: 16px;
}

.iriya-archive-widget h2 {
  margin: 0 0 10px;
  padding: 12px;
  border-radius: 8px;
  color: #513c74;
  text-align: center;
  font-size: 1.05rem;
  letter-spacing: 0.06em;
  background: linear-gradient(135deg, rgba(251, 244, 255, 0.95), rgba(255, 250, 253, 0.95));
}

.iriya-archive-category-list {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}

.iriya-archive-category-list li + li {
  border-top: 1px solid rgba(119, 94, 157, 0.13);
}

.iriya-archive-category-list a {
  display: grid;
  grid-template-columns: 28px 1fr 12px;
  gap: 10px;
  align-items: center;
  min-height: 44px;
  color: #5c4b74;
}

.iriya-archive-category-list a::after {
  content: ">";
  color: #9c83b6;
}

.iriya-archive-category-list span {
  display: grid;
  place-items: center;
  color: #b77ab5;
}

.iriya-archive-category-list svg {
  width: 23px;
  height: 23px;
  fill: currentColor;
}

.iriya-archive-category-list strong {
  font-size: 0.92rem;
}

.iriya-archive-tag-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
}

.iriya-archive-tag-cloud a {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  border: 1px solid rgba(119, 94, 157, 0.12);
  border-radius: 999px;
  color: #8c6aa8;
  font-size: 0.82rem;
  background: rgba(255, 255, 255, 0.88);
}

.iriya-archive-bottom-cta a,
.iriya-archive-empty a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 18px;
  border-radius: 8px;
  color: #fff;
  font-weight: 800;
  background: linear-gradient(135deg, #d5a447, #b68127);
  box-shadow: 0 10px 22px rgba(98, 62, 20, 0.16);
}

.iriya-archive-bottom-cta {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(300px, 0.9fr) 260px;
  gap: 24px;
  align-items: center;
  margin-top: 32px;
  padding: 28px 28px;
  border: 1px solid rgba(200, 155, 69, 0.38);
  border-radius: 8px;
  background:
    radial-gradient(circle at 4% 50%, rgba(210, 188, 237, 0.54), transparent 18%),
    linear-gradient(90deg, rgba(255, 255, 255, 0.94), rgba(251, 244, 255, 0.9));
  box-shadow: var(--iriya-archive-shadow);
}

.iriya-archive-bottom-cta::before {
  content: "";
  position: absolute;
  left: 20px;
  bottom: 10px;
  width: 90px;
  height: 90px;
  background:
    linear-gradient(135deg, transparent 46%, rgba(164, 127, 205, 0.42) 47% 52%, transparent 53%),
    radial-gradient(circle at 50% 34%, rgba(216, 200, 241, 0.86), transparent 52%);
  clip-path: polygon(50% 0, 72% 30%, 58% 100%, 42% 100%, 28% 30%);
  opacity: 0.55;
  pointer-events: none;
}

.iriya-archive-bottom-cta > div {
  position: relative;
  z-index: 1;
  padding-left: 76px;
}

.iriya-archive-bottom-cta p,
.iriya-archive-bottom-cta h2 {
  margin: 0;
}

.iriya-archive-bottom-cta p {
  color: #594775;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: 1.24rem;
  font-weight: 700;
  line-height: 1.6;
}

.iriya-archive-bottom-cta h2 {
  color: #35264f;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: clamp(1.45rem, 2.4vw, 2rem);
  line-height: 1.45;
  letter-spacing: 0.05em;
}

.iriya-archive-bottom-cta ul {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.iriya-archive-bottom-cta li {
  display: grid;
  justify-items: center;
  gap: 7px;
  min-width: 0;
  color: #5a4775;
  text-align: center;
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.45;
}

.iriya-archive-bottom-cta svg {
  width: 42px;
  height: 42px;
  padding: 9px;
  border: 1px solid rgba(200, 155, 69, 0.34);
  border-radius: 50%;
  fill: #a77ac0;
  background: rgba(255, 255, 255, 0.86);
}

.iriya-archive-bottom-cta a {
  min-height: 76px;
  text-align: center;
  line-height: 1.5;
  background: linear-gradient(135deg, #9a73c6, #7d56aa);
}

.iriya-archive-empty {
  padding: 48px 20px;
  text-align: center;
}

.iriya-archive-empty h2 {
  margin: 0;
  color: #35264f;
}

.iriya-archive-empty p {
  margin: 12px 0 22px;
  color: #625773;
}

.iriya-archive-pagination {
  display: flex;
  justify-content: center;
  margin-top: 26px;
  text-align: center;
}

.iriya-archive-pagination ul,
.iriya-archive-pagination ul.page-numbers {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: auto;
  height: auto;
  margin: 0;
  padding: 0;
  border: 0;
  list-style: none;
  line-height: normal;
  background: transparent;
}

.iriya-archive-pagination li {
  display: inline-flex;
  margin: 0;
  padding: 0;
}

.iriya-archive-pagination a,
.iriya-archive-pagination span {
  display: grid;
  place-items: center;
  min-width: 38px;
  min-height: 38px;
  border: 1px solid rgba(119, 94, 157, 0.14);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.92);
}

.iriya-archive-pagination .current {
  color: #fff;
  background: #8d6fbd;
}

@media (prefers-reduced-motion: reduce) {
  .iriya-archive-category-strip a,
  .iriya-archive-card {
    transition: none;
  }
}

@media (max-width: 1080px) {
  .iriya-archive-category-strip {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .iriya-archive-bottom-cta {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .iriya-archive-bottom-cta > div {
    padding-left: 0;
  }
}

@media (max-width: 920px) {
  .iriya-archive-ranking__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .iriya-archive-layout {
    grid-template-columns: 1fr;
  }

  .iriya-archive-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .iriya-archive-hero {
    aspect-ratio: 1254 / 1000;
    min-height: 0;
  }

  .iriya-archive-hero__image {
    background-image: url("../images/archives-hero-sp.webp");
    background-position: center center;
    background-size: 100% auto;
  }

  .iriya-archive-hero__inner {
    min-height: inherit;
  }

  .iriya-archive-category-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: min(100% - 22px, 1180px);
    margin-top: 18px;
    gap: 9px;
  }

  .iriya-archive-category-strip a {
    min-height: 84px;
    grid-template-columns: 36px 1fr;
    justify-items: start;
    gap: 8px;
    padding: 12px;
  }

  .iriya-archive-category-strip span {
    width: 36px;
    height: 36px;
  }

  .iriya-archive-category-strip svg {
    width: 30px;
    height: 30px;
  }

  .iriya-archive-category-strip strong {
    text-align: left;
  }

  .iriya-archive__inner {
    width: min(100% - 22px, 1280px);
    padding-bottom: 38px;
  }

  .iriya-archive-ranking__grid,
  .iriya-archive-latest__grid,
  .iriya-archive-sidebar,
  .iriya-archive-bottom-cta ul {
    grid-template-columns: 1fr;
  }

  .iriya-archive-section-heading {
    align-items: flex-start;
  }

  .iriya-archive-panel {
    padding: 16px 12px 20px;
  }

  .iriya-archive-card__body {
    padding: 16px;
  }

  .iriya-archive-bottom-cta {
    padding: 24px 16px;
  }

  .iriya-archive-bottom-cta::before {
    opacity: 0.18;
  }

  .iriya-archive-bottom-cta a {
    min-height: 62px;
  }
}
