/* ============================================================
   IN YOU PREMIUM — category page styles
   All rules are scoped under .iyp-page to avoid collisions with
   the existing theme CSS. Drop this file into the theme and
   enqueue it (or paste into style.css末尾).
   ============================================================ */

/* ---------- Google Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Noto+Serif+JP:wght@300;400;500;600;700;900&family=Noto+Sans+JP:wght@400;500;700&family=Shippori+Mincho:wght@400;500;600;700;800&display=swap');

/* ---------- Tokens (scoped) ---------- */
.iyp-page {
  --iyp-paper: #fbfaf6;
  --iyp-paper-2: #f3f1ea;
  --iyp-ink: #181613;
  --iyp-ink-2: #2b2620;
  --iyp-ink-3: #5a5147;
  --iyp-ink-4: #807a72;
  --iyp-red: #8a1c1c;
  --iyp-rule: #d8d2c2;

  /* hero (green × gold) */
  --iyp-green-900: #11231a;
  --iyp-green-800: #16291e;
  --iyp-green-700: #1a2e1f;
  --iyp-gold-300: #d8bb7a;
  --iyp-gold-400: #c9a55c;
  --iyp-gold-500: #b9924a;
  --iyp-gold-600: #a98446;
  --iyp-cream-50: #faf6ee;

  --iyp-serif-en: "Cormorant Garamond", "Playfair Display", serif;
  --iyp-serif-en-display: "Playfair Display", serif;
  --iyp-serif-jp: "Shippori Mincho", "Noto Serif JP", "Hiragino Mincho ProN", serif;
  --iyp-display: "DM Serif Display", "Playfair Display", serif;

  background: var(--iyp-paper);
  color: var(--iyp-ink);
  font-family: var(--iyp-serif-jp);
  -webkit-font-smoothing: antialiased;
}

.iyp-page * { box-sizing: border-box; }
.iyp-page a { color: inherit; text-decoration: none; }
.iyp-page img { display: block; max-width: 100%; }

/* Reset theme heading styles inside this scope */
.iyp-page h1,
.iyp-page h2,
.iyp-page h3 {
  margin: 0;
  padding: 0;
  color: inherit;
  font-weight: inherit;
  line-height: inherit;
}

/* ============================================================
   KV — Dark green × gold hero
   ============================================================ */
.iyp-page .iyp-kv {
  position: relative;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(185,146,74,.18), transparent 60%),
    linear-gradient(180deg, var(--iyp-green-800), var(--iyp-green-900) 70%, var(--iyp-green-700));
  color: var(--iyp-cream-50);
  overflow: hidden;
  isolation: isolate;
  margin-bottom: 0;
}
.iyp-page .iyp-kv::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    radial-gradient(1px 1px at 17% 28%, rgba(217,182,108,.35), transparent 60%),
    radial-gradient(1px 1px at 73% 64%, rgba(217,182,108,.28), transparent 60%),
    radial-gradient(1px 1px at 42% 80%, rgba(217,182,108,.22), transparent 60%),
    radial-gradient(1.5px 1.5px at 88% 22%, rgba(217,182,108,.3), transparent 60%),
    radial-gradient(1px 1px at 28% 60%, rgba(217,182,108,.2), transparent 60%);
  pointer-events: none;
  z-index: 0;
}
.iyp-page .iyp-kv::after {
  content: "";
  position: absolute; inset: 22px;
  border: 1px solid rgba(201,165,92,.55);
  pointer-events: none;
  z-index: 1;
}

.iyp-page .iyp-kv__inner {
  position: relative;
  z-index: 2;
  max-width: 1100px;
  margin: 0 auto;
  padding: 96px 32px 104px;
  text-align: center;
}
.iyp-page .iyp-kv__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--iyp-serif-en);
  font-style: italic;
  letter-spacing: .42em;
  font-size: 13px;
  color: var(--iyp-gold-300);
  text-transform: uppercase;
}
.iyp-page .iyp-kv__eyebrow::before,
.iyp-page .iyp-kv__eyebrow::after {
  content: "";
  width: 56px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--iyp-gold-400), transparent);
}
.iyp-page .iyp-kv__title {
  margin: 22px 0 0 !important;
  padding: 0 !important;
  font-family: var(--iyp-serif-en-display) !important;
  font-weight: 500 !important;
  font-size: clamp(54px, 8vw, 108px) !important;
  letter-spacing: .06em !important;
  line-height: 1 !important;
  color: var(--iyp-cream-50) !important;
  -webkit-text-fill-color: var(--iyp-cream-50) !important;
  -webkit-text-stroke: 0 !important;
  text-stroke: 0 !important;
  text-shadow: 0 1px 0 rgba(0,0,0,.4) !important;
  background: transparent !important;
  background-image: none !important;
  -webkit-background-clip: border-box !important;
          background-clip: border-box !important;
  border: 0 !important;
  text-align: center !important;
}
.iyp-page .iyp-kv__title .iyp-amp {
  font-style: italic;
  color: var(--iyp-gold-300) !important;
  -webkit-text-fill-color: var(--iyp-gold-300) !important;
  font-weight: 400;
  margin: 0 .04em;
}
.iyp-page .iyp-kv__ornament {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin: 26px 0 0;
  color: var(--iyp-gold-400);
}
.iyp-page .iyp-kv__ornament .iyp-line {
  width: 80px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--iyp-gold-500), transparent);
}
.iyp-page .iyp-kv__ornament .iyp-diamond {
  width: 7px;
  height: 7px;
  background: var(--iyp-gold-400);
  transform: rotate(45deg);
  box-shadow: 0 0 6px rgba(201,165,92,.5);
}
.iyp-page .iyp-kv__subtitle {
  margin: 22px 0 0;
  font-family: var(--iyp-serif-jp);
  font-weight: 400;
  font-size: 18px;
  letter-spacing: .42em;
  color: var(--iyp-cream-50);
  padding-left: .42em;
}
.iyp-page .iyp-kv__lead {
  margin: 36px auto 0;
	padding:0 20px 0;
  max-width: 640px;
  font-family: var(--iyp-serif-jp);
  font-size: 15px;
  line-height: 2.2;
  letter-spacing: .12em;
  color: rgba(250,246,238,.78);
}
.iyp-page .iyp-kv__corners {
  position: absolute;
  inset: 22px;
  pointer-events: none;
  z-index: 2;
}
.iyp-page .iyp-kv__corners span {
  position: absolute;
  width: 28px; height: 28px;
  border: 1px solid var(--iyp-gold-400);
}
.iyp-page .iyp-kv__corners span:nth-child(1) { top: -1px; left: -1px; border-right: 0; border-bottom: 0; }
.iyp-page .iyp-kv__corners span:nth-child(2) { top: -1px; right: -1px; border-left: 0; border-bottom: 0; }
.iyp-page .iyp-kv__corners span:nth-child(3) { bottom: -1px; left: -1px; border-right: 0; border-top: 0; }
.iyp-page .iyp-kv__corners span:nth-child(4) { bottom: -1px; right: -1px; border-left: 0; border-top: 0; }

/* ============================================================
   Intro
   ============================================================ */
.iyp-page .iyp-intro {
  border-bottom: 1px solid var(--iyp-ink);
  padding: 64px 28px 56px;
  background: var(--iyp-paper);
}
.iyp-page .iyp-intro__inner {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 230px 1fr;
  gap: 56px;
  align-items: start;
}
@media (max-width: 760px) {
  .iyp-page .iyp-intro__inner { grid-template-columns: 1fr; gap: 24px; }
}
.iyp-page .iyp-intro__label {
  font-family: var(--iyp-serif-en-display);
  font-style: italic;
  letter-spacing: .22em;
  text-transform: uppercase;
  font-size: 12px;
  color: var(--iyp-red);
  border-top: 2px solid var(--iyp-ink);
  padding-top: 14px;
  line-height: 1.4;
}
.iyp-page .iyp-intro__label strong {
  display: block;
  font-family: var(--iyp-serif-jp);
  font-style: normal;
  font-weight: 700;
  color: var(--iyp-ink);
  font-size: 18px;
  letter-spacing: .26em;
  margin-top: 6px;
}
.iyp-page .iyp-intro__copy {
  font-family: var(--iyp-serif-jp);
  font-weight: 400;
  font-size: 17px;
  line-height: 2.1;
  letter-spacing: .08em;
  color: var(--iyp-ink-2);
  text-wrap: pretty;
}
.iyp-page .iyp-intro__copy p { margin: 0; }
.iyp-page .iyp-intro__copy .iyp-lede::first-letter {
  font-family: var(--iyp-display);
  float: left;
  font-size: 68px;
  line-height: .85;
  padding: 6px 10px 0 0;
  color: var(--iyp-red);
}

/* ============================================================
   Wrap + section head
   ============================================================ */
.iyp-page .iyp-wrap {
  max-width: 1280px;
  margin: 0 auto;
  padding: 64px 28px 96px;
}
.iyp-page .iyp-section-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: end;
  gap: 24px;
  border-bottom: 2px solid var(--iyp-ink);
  padding-bottom: 14px;
  margin-bottom: 48px;
}
.iyp-page .iyp-section-head h2,
.iyp-page .iyp-section-head__title {
  margin: 0 !important;
  padding: 0 !important;
  font-family: var(--iyp-display) !important;
  font-weight: 400 !important;
  font-size: clamp(38px, 5vw, 58px) !important;
  line-height: 1 !important;
  letter-spacing: -.01em !important;
  color: var(--iyp-ink) !important;
  background: transparent !important;
  border: 0 !important;
}
.iyp-page .iyp-section-head h2 em,
.iyp-page .iyp-section-head__title em {
  font-style: italic;
  color: var(--iyp-red);
}
.iyp-page .iyp-section-head h2 em {
  font-style: italic;
  color: var(--iyp-red);
}
.iyp-page .iyp-section-head .iyp-meta {
  font-family: var(--iyp-serif-en-display);
  font-style: italic;
  letter-spacing: .18em;
  color: var(--iyp-ink-3);
  font-size: 13px;
  text-transform: uppercase;
}
.iyp-page .iyp-section-head .iyp-count {
  font-family: var(--iyp-display);
  font-size: 22px;
  color: var(--iyp-ink);
}

/* ============================================================
   Featured (first article)
   ============================================================ */
.iyp-page .iyp-featured {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 48px;
  margin-bottom: 80px;
  align-items: stretch;
}
@media (max-width: 860px) {
  .iyp-page .iyp-featured { grid-template-columns: 1fr; gap: 24px; }
}
.iyp-page .iyp-featured__media {
  display: block;
  position: relative;
  width: 100%;
  aspect-ratio: 5 / 4;
  overflow: hidden;
  background: #2a2a2a;
  border: 1px solid var(--iyp-ink);
}
.iyp-page .iyp-featured__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .9s ease;
}
.iyp-page .iyp-featured:hover .iyp-featured__media img { transform: scale(1.03); }
.iyp-page .iyp-featured__no {
  position: absolute;
  top: 0; left: 0;
  background: var(--iyp-paper);
  color: var(--iyp-ink);
  border-right: 1px solid var(--iyp-ink);
  border-bottom: 1px solid var(--iyp-ink);
  padding: 8px 14px 6px;
  font-family: var(--iyp-serif-en-display);
  font-style: italic;
  font-size: 14px;
  letter-spacing: .14em;
}
.iyp-page .iyp-featured__stamp {
  position: absolute;
  top: 14px; right: 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--iyp-ink);
  color: #fff;
  padding: 7px 14px;
  font-family: var(--iyp-serif-en-display);
  font-style: italic;
  letter-spacing: .26em;
  text-transform: uppercase;
  font-size: 11px;
  border: 1px solid #fff;
  outline: 1px solid var(--iyp-ink);
  z-index: 3;
}
.iyp-page .iyp-featured__stamp::before {
  content: "\2605";
  color: var(--iyp-red);
  font-style: normal;
  letter-spacing: 0;
}
.iyp-page .iyp-featured__body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 8px 0;
}
.iyp-page .iyp-featured__tag {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  align-self: flex-start;
  margin-bottom: 22px;
  font-family: var(--iyp-serif-en-display);
  font-style: italic;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--iyp-red);
  font-size: 12px;
}
.iyp-page .iyp-featured__tag::before {
  content: "";
  width: 28px; height: 1px;
  background: var(--iyp-red);
}
.iyp-page .iyp-featured__title {
  margin: 0 0 24px !important;
  padding: 0 !important;
  font-family: var(--iyp-serif-jp) !important;
  font-weight: 700 !important;
  font-size: clamp(24px, 2.8vw, 36px) !important;
  line-height: 1.55 !important;
  letter-spacing: .02em !important;
  color: var(--iyp-ink) !important;
  text-wrap: balance;
  background: transparent !important;
  border: 0 !important;
}
.iyp-page .iyp-featured__title a { color: inherit; }
.iyp-page .iyp-featured__excerpt {
  font-family: var(--iyp-serif-jp);
  font-size: 15px;
  line-height: 2;
  letter-spacing: .06em;
  color: var(--iyp-ink-2);
  margin: 0 0 32px;
  max-width: 38em;
}
.iyp-page .iyp-featured__meta {
  display: flex;
  align-items: center;
  gap: 22px;
  padding-top: 22px;
  border-top: 1px solid var(--iyp-ink);
  flex-wrap: wrap;
}
.iyp-page .iyp-featured__price {
  font-family: var(--iyp-display);
  font-size: 30px;
  color: var(--iyp-red);
  line-height: 1;
}
.iyp-page .iyp-featured__price .iyp-yen { font-size: 18px; margin-right: 2px; }
.iyp-page .iyp-featured__price .iyp-note {
  font-family: var(--iyp-serif-jp);
  font-size: 12px;
  letter-spacing: .22em;
  color: var(--iyp-ink-3);
  margin-left: 10px;
  vertical-align: middle;
}
.iyp-page .iyp-featured__date {
  margin-left: auto;
  font-family: var(--iyp-serif-en-display);
  font-style: italic;
  letter-spacing: .14em;
  font-size: 13px;
  color: var(--iyp-ink-3);
}
.iyp-page .iyp-featured__read {
  margin-left: 16px;
  font-family: var(--iyp-serif-en-display);
  font-style: italic;
  letter-spacing: .18em;
  font-size: 13px;
  color: var(--iyp-ink);
  text-transform: uppercase;
  border-bottom: 1px solid var(--iyp-ink);
  padding-bottom: 2px;
}

/* ============================================================
   Grid (2-up)
   ============================================================ */
.iyp-page .iyp-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 72px 56px;
  list-style: none;
  margin: 0;
  padding: 0;
}
@media (max-width: 760px) {
  .iyp-page .iyp-grid { grid-template-columns: 1fr; gap: 56px; }
}

.iyp-page .iyp-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: transparent;
  /* reset li styles from theme */
  width: auto !important;
  float: none !important;
  padding: 0 !important;
  margin: 0;
  list-style: none;
}
.iyp-page .iyp-card__media {
  display: block;
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  border: 1px solid var(--iyp-ink);
  background: #2a2a2a;
}
.iyp-page .iyp-card__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .7s ease;
}
.iyp-page .iyp-card:hover .iyp-card__media img { transform: scale(1.04); }

.iyp-page .iyp-card__no {
  position: absolute;
  top: 0; left: 0;
  background: var(--iyp-paper);
  color: var(--iyp-ink);
  border-right: 1px solid var(--iyp-ink);
  border-bottom: 1px solid var(--iyp-ink);
  padding: 6px 12px 4px;
  font-family: var(--iyp-serif-en-display);
  font-style: italic;
  font-size: 13px;
  letter-spacing: .12em;
}
.iyp-page .iyp-card__stamp {
  position: absolute;
  top: 14px; right: 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--iyp-ink);
  color: #fff;
  padding: 6px 12px;
  font-family: var(--iyp-serif-en-display);
  font-style: italic;
  letter-spacing: .26em;
  text-transform: uppercase;
  font-size: 10px;
  border: 1px solid #fff;
  outline: 1px solid var(--iyp-ink);
}
.iyp-page .iyp-card__stamp::before {
  content: "★";
  color: var(--iyp-red);
  font-style: normal;
  letter-spacing: 0;
}

.iyp-page .iyp-card__body { padding: 22px 4px 0; }
.iyp-page .iyp-card__tag {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--iyp-serif-en-display);
  font-style: italic;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--iyp-red);
  font-size: 11px;
  margin-bottom: 12px;
}
.iyp-page .iyp-card__tag::before {
  content: "";
  width: 22px; height: 1px;
  background: var(--iyp-red);
}
.iyp-page .iyp-card__title {
  margin: 0 !important;
  padding: 0 !important;
  font-family: var(--iyp-serif-jp) !important;
  font-weight: 700 !important;
  font-size: 20px !important;
  line-height: 1.6 !important;
  letter-spacing: .02em !important;
  color: var(--iyp-ink) !important;
  text-wrap: pretty;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  background: transparent !important;
  border: 0 !important;
}
.iyp-page .iyp-card__title a { color: inherit; }
.iyp-page .iyp-card__title:hover,
.iyp-page .iyp-card__title a:hover { color: var(--iyp-red); }
.iyp-page .iyp-card__meta {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--iyp-ink);
  display: flex;
  align-items: baseline;
  gap: 16px;
}
.iyp-page .iyp-card__price {
  font-family: var(--iyp-display);
  font-size: 22px;
  color: var(--iyp-red);
  line-height: 1;
}
.iyp-page .iyp-card__price .iyp-yen { font-size: 14px; margin-right: 1px; }
.iyp-page .iyp-card__price .iyp-note {
  font-family: var(--iyp-serif-jp);
  font-size: 11px;
  letter-spacing: .2em;
  color: var(--iyp-ink-3);
  margin-left: 8px;
  vertical-align: middle;
}
.iyp-page .iyp-card__date {
  margin-left: auto;
  font-family: var(--iyp-serif-en-display);
  font-style: italic;
  letter-spacing: .14em;
  font-size: 12px;
  color: var(--iyp-ink-3);
}

/* ============================================================
   Pagination (overrides default theme pagination inside .iyp-page)
   ============================================================ */
.iyp-page .iyp-pager,
.iyp-page .pagenation,
.iyp-page .pagination,
.iyp-page .wp-pagenavi {
  margin-top: 80px;
  padding-top: 32px;
  border-top: 2px solid var(--iyp-ink);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--iyp-serif-en-display);
}
.iyp-page .iyp-pager a,
.iyp-page .iyp-pager span,
.iyp-page .pagenation a,
.iyp-page .pagenation span,
.iyp-page .pagination a,
.iyp-page .pagination span,
.iyp-page .wp-pagenavi a,
.iyp-page .wp-pagenavi span {
  min-width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  font-size: 15px;
  letter-spacing: .08em;
  color: var(--iyp-ink-3);
  border: 0;
  background: transparent;
  padding: 0 10px;
}
.iyp-page .iyp-pager .current,
.iyp-page .pagenation .current,
.iyp-page .pagination .current,
.iyp-page .wp-pagenavi .current {
  color: #fff;
  background: var(--iyp-ink);
}
.iyp-page .iyp-pager a:hover,
.iyp-page .pagenation a:hover,
.iyp-page .pagination a:hover,
.iyp-page .wp-pagenavi a:hover { color: var(--iyp-red); }

/* ============================================================
   Bottom note band
   ============================================================ */
.iyp-page .iyp-note-band {
  background: var(--iyp-ink);
  color: #f1ead7;
  padding: 16px 28px;
  text-align: center;
  font-family: var(--iyp-serif-jp);
  font-size: 13px;
  letter-spacing: .22em;
}
.iyp-page .iyp-note-band em {
  font-family: var(--iyp-serif-en-display);
  font-style: italic;
  color: #e7c98c;
  margin-right: 12px;
  letter-spacing: .26em;
  text-transform: uppercase;
}

/* ============================================================
   Container override: this category page is full-width
   The existing theme uses .column--wrap / .column--main with
   max-widths. Inside .iyp-page we reset them.
   ============================================================ */
.iyp-page.column--wrap,
.iyp-page .column--wrap {
  max-width: none;
  width: 100%;
  padding: 0;
  margin: 0;
}
.iyp-page .column--main {
  max-width: none;
  width: 100%;
  padding: 0;
  margin: 0;
  float: none;
}

/* Hide the legacy list when the premium markup is rendered */
.iyp-page .list--article { display: none !important; }

/* Ensure layout containers keep their padding even if the theme tries to reset */
.iyp-page .iyp-wrap {
  padding-left: 28px !important;
  padding-right: 28px !important;
  max-width: 1280px !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  box-sizing: border-box !important;
}
.iyp-page .iyp-intro {
  padding-left: 28px !important;
  padding-right: 28px !important;
}
.iyp-page .iyp-kv__inner {
  padding-left: 32px !important;
  padding-right: 32px !important;
  box-sizing: border-box !important;
}
.iyp-page .iyp-intro__inner,
.iyp-page .iyp-featured__media,
.iyp-page .iyp-card__media {
  max-width: 100% !important;
  box-sizing: border-box !important;
}
.iyp-page .iyp-grid {
  width: 100% !important;
  box-sizing: border-box !important;
}

/* ============================================================
   Mobile tweaks
   ============================================================ */
@media (max-width: 760px) {
  .iyp-page .iyp-kv__inner { padding: 56px 20px 60px !important; }
  .iyp-page .iyp-kv__title { font-size: clamp(40px, 12vw, 64px) !important; letter-spacing: .04em !important; }
  .iyp-page .iyp-kv__eyebrow { font-size: 10px; letter-spacing: .28em; }
  .iyp-page .iyp-kv__eyebrow::before,
  .iyp-page .iyp-kv__eyebrow::after { width: 28px; }
  .iyp-page .iyp-kv__subtitle { font-size: 15px; letter-spacing: .32em; }
  .iyp-page .iyp-kv__lead { font-size: 13px; line-height: 2; letter-spacing: .08em; }

  .iyp-page .iyp-intro { padding: 44px 20px 40px !important; }
  .iyp-page .iyp-intro__copy { font-size: 15px; line-height: 2; }
  .iyp-page .iyp-intro__copy .iyp-lede::first-letter { font-size: 52px; padding: 4px 8px 0 0; }

  .iyp-page .iyp-wrap { padding: 48px 20px 64px !important; }

  .iyp-page .iyp-section-head {
    grid-template-columns: 1fr auto;
    align-items: baseline;
    gap: 12px;
    padding-bottom: 12px;
    margin-bottom: 32px;
  }
  .iyp-page .iyp-section-head__title,
  .iyp-page .iyp-section-head h2 { font-size: 30px !important; }
  .iyp-page .iyp-section-head .iyp-meta { display: none; }
  .iyp-page .iyp-section-head .iyp-count { font-size: 18px; }

  .iyp-page .iyp-featured { gap: 18px; margin-bottom: 56px; }
  .iyp-page .iyp-featured__media { aspect-ratio: 4 / 3; }
  .iyp-page .iyp-featured__title { font-size: 20px !important; margin-bottom: 16px !important; }
  .iyp-page .iyp-featured__excerpt { font-size: 13px; line-height: 1.9; margin-bottom: 22px; }
  .iyp-page .iyp-featured__meta { gap: 12px; padding-top: 16px; }
  .iyp-page .iyp-featured__price { font-size: 22px; }
  .iyp-page .iyp-featured__price .iyp-yen { font-size: 14px; }
  .iyp-page .iyp-featured__date { font-size: 11px; }
  .iyp-page .iyp-featured__read { margin-left: auto; font-size: 11px; }

  .iyp-page .iyp-grid { gap: 40px; }
  .iyp-page .iyp-card__media { aspect-ratio: 16 / 10; }
  .iyp-page .iyp-card__body { padding: 18px 2px 0; }
  .iyp-page .iyp-card__title { font-size: 16px !important; line-height: 1.55 !important; }
  .iyp-page .iyp-card__tag { font-size: 10px; letter-spacing: .22em; }
  .iyp-page .iyp-card__meta { gap: 10px; }
  .iyp-page .iyp-card__price { font-size: 18px; }
  .iyp-page .iyp-card__price .iyp-yen { font-size: 12px; }
  .iyp-page .iyp-card__price .iyp-note { font-size: 10px; letter-spacing: .16em; margin-left: 6px; }
  .iyp-page .iyp-card__date { font-size: 11px; }
  .iyp-page .iyp-card__stamp { font-size: 9px; padding: 5px 9px; letter-spacing: .22em; top: 10px; right: 10px; }
  .iyp-page .iyp-card__no { font-size: 11px; padding: 5px 9px 3px; }

  .iyp-page .iyp-note-band { font-size: 11px; letter-spacing: .14em; padding: 14px 18px; line-height: 1.8; }
  .iyp-page .iyp-note-band em { font-size: 11px; letter-spacing: .2em; margin-right: 8px; display: block; margin-bottom: 4px; }
}

/* ensure no horizontal overflow on the whole scope */
.iyp-page { overflow-x: hidden; }
