/*
Theme Name: Twenty Twenty-Four Child
Template: twentytwentyfour
Version: 1.0
*/
/* =========================
   Layout reset for TT4 wrapper
   ========================= */

main.wp-block-group.has-global-padding.is-layout-constrained{
  max-width: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* alignfull セクションを制約から解放 */
.wp-block-post-content.is-layout-constrained > section.alignfull{
  max-width: none;
  margin-left: 0;
  margin-right: 0;
}

/* TT4 の自動余白を消す */
.wp-site-blocks > *{
  margin-block-start: 0;
}

main.wp-block-group.has-global-padding.is-layout-constrained > *{
  margin-block-start: 0;
}

main.wp-block-group.has-global-padding.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)){
  max-width: none;
  margin-left: 0;
  margin-right: 0;
}

/* TT4 の左右余白を直接消す */
.wp-site-blocks{
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.has-global-padding{
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.wp-block-post-content.has-global-padding{
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* TT4 の自動余白を消す */

:root :where(.is-layout-constrained) > *{
  margin-block-start: 0 !important;
}

/* =========================
   1. Base
   ========================= */

:root{
  --font-body: "Noto Sans JP", system-ui, -apple-system, sans-serif;
  --font-heading: "Zen Old Mincho", serif;
  --font-script: "Tangerine", serif;

  --color-text: #2b2b2b;
  --color-accent: #c6a46a;
}

/* body */
body{
  font-family: var(--font-body);
  color: var(--color-text);
  line-height: 1.8;
  overflow-x: clip;
}

/* headings */
h1,
h2,
h3,
h4,
h5,
h6,
.wp-block-heading{
  font-family: var(--font-heading);
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.4;
}

/* 英字サブタイトル */
.junka-en,
.sub{
  font-family: var(--font-script);
  letter-spacing: 0.05em;
}

/* ヘッダー */
.wp-block-site-title,
.wp-block-navigation,
.wp-block-navigation a{
  font-family: var(--font-body);
}

.wp-block-site-title,
.site-title{
  margin-left: 40px; /* ←PCは広めがいい */
}

header.wp-block-template-part.scrolled,
.wp-site-blocks > header.scrolled{
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.75) 0%,
    rgba(0,0,0,0.55) 40%,
    rgba(0,0,0,0.25) 70%,
    rgba(0,0,0,0) 100%
  ) !important;
/*backdrop-filter: blur(6px);*/
}

header.wp-block-template-part.scrolled .wp-block-group,
header.wp-block-template-part.scrolled .wp-block-navigation,
.wp-site-blocks > header.scrolled .wp-block-group,
.wp-site-blocks > header.scrolled .wp-block-navigation{
  background: transparent !important;
}

/* =========================
   Body text rule
   ========================= */

p{
  font-size: 17.5px;
  letter-spacing: .04em;
  line-height: 2;
  text-align: justify;
  text-justify: inter-ideograph;
}

/* =========================
   2. Header / Hero
   ========================= */

/* 先頭余白をなくす */
.wp-site-blocks{
  padding-top: 0 !important;
}

/* ヘッダーを上に重ねる */
header.wp-block-template-part,
.wp-site-blocks > header{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.28) 0%,
    rgba(0,0,0,0.16) 45%,
    rgba(0,0,0,0.06) 75%,
    rgba(0,0,0,0) 100%
  ) !important;
/*backdrop-filter: blur(3px);*/
  transition: background .3s ease, backdrop-filter .3s ease;
}

header.wp-block-template-part *{
  background: transparent !important;
}

header a,
header .wp-block-navigation-item__content{
  color: #fff !important;
}

header a{
  position: relative;
  transition: opacity .3s;
}

header a:hover{
  opacity: .85; /* ←少しだけ効かせる */
}

header a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-6px;
  width:0;
  height:1px;
  background:#c6a46a;
  transition:.3s;
}

header a:hover::after{
  width:100%;
}


/* MV */
.wp-block-cover{
  position: relative !important;
}

.wp-block-cover .hero-title{
  position: absolute !important;
  top: 35% !important;
  left: 25% !important;
  z-index: 20 !important;
  text-align: center !important;
  pointer-events: none;
}

.wp-block-cover .junka-ja{
  font-family: var(--font-heading);
  font-size: clamp(56px, 18vw, 140px);
  line-height: 1.05;
  color: #fff;
  text-shadow: 0 6px 30px rgba(0,0,0,.35);
  margin: 0;
  display: block;
  word-break: keep-all;
}

.wp-block-cover .junka-en{
  font-family: var(--font-script) !important;
  font-size: clamp(32px, 4.2vw, 70px);
  letter-spacing: .2em;
  color: #fff;
  margin-top: -10px;
  display: block;
}

.wp-block-cover .wp-block-cover__inner-container{
  position: static !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* =========================
   3. Message
   ========================= */

.wp-block-post-content.is-layout-constrained > section.message-section.alignfull{
  max-width: none;
  margin: 0;
}

.message-section{
  position: relative;
  padding: 100px 0;
  overflow: hidden;
}

.message-section .parallax-bg{
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  z-index: 0;
  transform: scale(1.04);
}

.message-section::before{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.50);
  z-index: 1;
}

.message-inner{
  position: relative;
  z-index: 2;
  max-width: 860px;
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: border-box;
  text-align: center;
  color: #4a3a3a;
}

.message-inner h2{
  margin: 0 0 50px;
}

.message-section p{
  margin: 0 0 24px;
  font-size: 18px;
  line-height: 2.2;
  text-align: center;
}

.message-sign{
  margin-top: 36px;
  font-family: "Shippori Mincho", "Noto Serif JP", serif;
  font-size: 1.5rem !important;
  letter-spacing: .12em;
  line-height: 1.8;
}



@media (max-width: 768px){
  .message-section{
    padding: 56px 0;
  }

  .message-inner{
    padding: 0 20px;
  }

  .message-inner h2{
    margin-bottom: 24px;
  }

  .message-section p{
    font-size: 16px;
    line-height: 2;
  }

  .message-section p br{
    display: none;
  }
}



/* =========================
   4. Biography
   ========================= */

.jp-profile{
  --washi-url: url("https://lovely-junka.com/wp-content/uploads/2026/03/washi-dark6webp.webp");
  --sakura-url: url("https://lovely-junka.com/wp-content/uploads/2026/03/sakura.svg");
  --text: #e7dfd5;
  --gold: #c6a46a;

  position: relative;
  padding: 100px 0;
  background-image: var(--washi-url);
  background-size: cover;
  background-position: center;
  color: var(--text);
}

.jp-profile__inner{
  width: min(1200px, calc(100% - 48px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: 470px 1fr;
  gap: 80px;
  align-items: start;
}

.jp-profile__section-title {
  text-align: center;
  font-family: var(--font-script);
  font-size: clamp(2.8rem, 6vw, 4rem);
  font-weight: 400;
  color: #c9a468;
  margin: 0 0 100px;
  letter-spacing: .05em;
  text-shadow: 0 2px 10px rgba(0,0,0,.6);

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
}

/* 左右ライン */

.jp-profile__section-title::before,
.jp-profile__section-title::after{
  content:"";
  width:70px;
  height:1px;
  background:#c9a468;
  display:block;
  opacity:.7;
}

/* 左 */

.jp-profile__photo{
  margin: 0 0 36px;
}

.jp-profile__photo img{
  width: 100%;
  height: auto;
  display: block;
}

/* バッジ */

.jp-profile__badges{
  display: flex;
  gap: 18px;
}

.badge{
  border: 1px solid rgba(198,164,106,.75);
  border-radius: 999px;
  padding: 18px 14px 34px;
  text-align: center;
  min-height: 170px;
  display: grid;
  align-content: start;
  gap: 6px;
  position: relative;
  flex: 1;
}

.badge__sakura{
  width: 28px;
  height: 28px;
  margin: 0 auto 2px;
  background-image: var(--sakura-url);
  background-size: contain;
  background-repeat: no-repeat;
  opacity: .9;
}

.badge__year{
  font-family: var(--font-heading);
  font-size: 28px;
  line-height: 1.2;
  color: var(--gold);
  letter-spacing: .08em;
}

.badge__title{
  font-size: 16px;
  color: var(--gold);
  letter-spacing: .08em;
}

.badge__sub{
  font-size: 13px;
  line-height: 1.6;
  color: var(--text);
  opacity: .9;
}

/* 右 */

.jp-profile__name{
  margin: 0 0 40px;
  font-family: var(--font-heading);
  font-size: clamp(28px, 3vw, 42px);
  color: var(--gold);
  letter-spacing: .12em;
}

.jp-profile__ruby{
  font-size: .45em;
  opacity: .9;
  letter-spacing: .18em;
}

.jp-profile__meta{
  margin: 0 0 40px;
}

.meta-row{
  display: grid;
  grid-template-columns: 120px 1fr;
  column-gap: 18px;
  align-items: baseline;
  padding: 12px 0;
  border-bottom: 1px solid rgba(198,164,106,.45);
}

.meta-label{
  color: var(--gold);
  font-weight: 600;
  letter-spacing: .08em;
}

.meta-value{
  color: var(--text);
}

.jp-profile__body p{
  margin: 0 0 1.25em;
  line-height: 2.1;
  color: var(--text);
}

.jp-profile__inner > p{
display:none;
}

/* モバイル */

@media (max-width: 900px){
  .jp-profile{
    padding-top: 40px;
    padding-bottom: 80px;
  }

.jp-profile__section-title{
  margin-bottom: 20px;
}

  .jp-profile__inner{
    grid-template-columns: 1fr;
    gap: 48px;
    margin-bottom: -30px;
  }

  .jp-profile__badges{
    gap: 12px;
  }

  .badge{
    min-height: auto;
    padding: 16px 10px 24px;
  }

  .badge__year{
    font-size: 22px;
  }

  .badge__title{
    font-size: 14px;
  }

  .badge__sub{
    font-size: 12px;
    padding-bottom: 20px;
  }

  .jp-profile__name{
    margin-bottom: 28px;
  }

.meta-row{
  grid-template-columns: 100px 1fr;
  column-gap: 14px;
}

  .jp-profile__photo img{
    width: 55%;
    margin: 0 auto;
    display: block;
  }
  .jp-profile__body p{
    font-size: 16px;
    line-height: 2.1;
  }


}


/* =========================
   5. Chronicle
   ========================= */

.chronicle{
  position: relative;
  padding: clamp(64px, 8vw, 96px) 0 90px;
  overflow: hidden;

  background:
    radial-gradient(1200px 800px at 20% 10%, rgba(0,0,0,0.025), transparent 70%),
    radial-gradient(1000px 700px at 80% 30%, rgba(0,0,0,0.02), transparent 75%),
    radial-gradient(900px 600px at 50% 90%, rgba(0,0,0,0.015), transparent 70%),
    repeating-linear-gradient(
      0deg,
      rgba(0,0,0,0.010) 0px,
      rgba(0,0,0,0.010) 1px,
      transparent 1px,
      transparent 2px
    ),
    #f7f5f1;
}

.chronicle__inner{
  width: min(1200px, calc(100% - 24px));
  margin: 0 auto;
  position: relative;
}

.chronicle__head{
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 34px;
}

.chronicle__title{
  margin: 0 0 40px;
  font-family: var(--font-script);
  font-size: clamp(56px, 6vw, 86px);
  font-weight: 400;
  line-height: 1;
  letter-spacing: .02em;
  color: #c79d47;
  text-align: center;
  text-shadow: 0 2px 10px rgba(0,0,0,.6);

  display:flex;
  align-items:center;
  justify-content:center;
  gap:.55em;
}

.chronicle__title::before,
.chronicle__title::after{
  content:"";
  width: clamp(56px, 8vw, 96px);
  height:1px;
  background: rgba(199,157,71,.7);
}

.chronicle__nav{
  pointer-events: none;
}

.chronicle__nav-btn{
  pointer-events: auto;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 80px;
  height: 80px;
  border: 0;
  border-radius: 50%;
  background: rgba(145,134,122,.7);
  backdrop-filter: blur(4px);
  color: #fff;
  display: grid;
  place-items: center;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(0,0,0,.10);
  transition: transform .2s ease, opacity .2s ease, background-color .2s ease;
  padding: 0;
}

.chronicle__nav-btn svg{
  width: 30px;
  height: 30px;
  stroke: currentColor;
  stroke-width: 1.2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.chronicle__nav-btn:hover{
  background: rgba(145,134,122,.9);
  transform: translateY(calc(-50% + 2px));
}

.chronicle__nav-btn:disabled{
  opacity:.25;
  pointer-events:none;
  filter:grayscale(100%);
}

.chronicle__grid{
  transition:opacity .25s ease;
}

.chronicle__nav-btn--prev{
  left: -70px;
}

.chronicle__nav-btn--next{
  right: -70px;
}

.chronicle__viewport{
  position: relative;
}

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

.chronicle-card{
  position: relative;
  overflow: visible;
  display: grid;
  grid-template-rows:
    auto    /* date */
    3.7em   /* title */
    4.5em   /* excerpt */
    70px    /* action */
    120px;  /* image */
  gap: 8px;
  padding: 30px 50px 30px;
  border: 2px solid #c9a468;
  border-radius: 28px;
  color: #cecbc4;
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
}

.chronicle-card:nth-child(odd){
  background: rgba(69,70,72,.95);
}

.chronicle-card:nth-child(even){
  background: linear-gradient(to bottom, #91606a, #7f5058);
}

.chronicle-card::before{
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px solid #c9a468;
  border-radius: 6px;
  pointer-events: none;
  z-index: 1;
  background:
    radial-gradient(circle at 0 0, transparent 18px, #c9a468 18px 19px, transparent 19px) 0 0 / 38px 38px no-repeat,
    radial-gradient(circle at 100% 0, transparent 18px, #c9a468 18px 19px, transparent 19px) 100% 0 / 38px 38px no-repeat,
    radial-gradient(circle at 0 100%, transparent 18px, #c9a468 18px 19px, transparent 19px) 0 100% / 38px 38px no-repeat,
    radial-gradient(circle at 100% 100%, transparent 18px, #c9a468 18px 19px, transparent 19px) 100% 100% / 38px 38px no-repeat;
}

.chronicle-card > *{
  position: relative;
  z-index: 2;
  min-width: 0;
}

.chronicle-card__date{
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: .06em;
  color: #cecbc4;
  opacity: .9;
  text-align: left;
  text-justify: auto;
}

.chronicle-card__title{
  margin: 4px 0 0;
  padding-left: 22px;
  position: relative;
  font-size: 21px;
  line-height: 1.25;
  letter-spacing: .02em;
  color: #cecbc4;
  font-weight: 500;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.chronicle-card__title::before{
  content: "";
  position: absolute;
  left: 0;
  top: .4em;
  width: 12px;
  height: 12px;
  background-image: url("https://lovely-junka.com/wp-content/uploads/2026/03/sakura.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  opacity: .95;
}

.chronicle-card__title a{
  color: inherit;
  text-decoration: none;
}

.chronicle-card__title a:hover{
  opacity: .88;
}

.chronicle-card__excerpt{
  margin: 0;
  font-size: 16px;
  line-height: 1.6;
  letter-spacing: .04em;
  color: #cecbc4;
  opacity: .95;
  text-align: left;
  text-justify: auto;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  margin-bottom: -3px;
}

.chronicle-card__action{
  min-height: 70px;
  display: flex;
  align-items: flex-start; /* ← ここが重要 */
  padding-top: 2px;
  justify-content: flex-end;
}

.chronicle-card__action a::before{
  content: "›";
  margin-right: 6px;
  color: #c9a468;
  font-size: 1.1em;
}

.chronicle-card__btn:hover{
  background: rgba(255,255,255,.10);
  color: #fff;
  transform: translateY(-1px);
}

.chronicle-card__image{
  width: 100%;
  height: 140px;
  margin-top: 0;
  align-self: end;
  overflow: hidden;
  border-radius: 6px;
  background: rgba(255,255,255,.08);
}

.chronicle-card__image img{
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.chronicle-card__image--placeholder{
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  font-size: 15px;
  line-height: 1.6;
  color: rgba(255,255,255,.78);
  background: rgba(255,255,255,.10);
}

.chronicle.is-loading .chronicle__grid{
  opacity: 1;
  transition: none;
}

@media (max-width: 1024px){
  .chronicle__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
  }

  .chronicle__nav-btn--prev{
    left: -10px;
  }

  .chronicle__nav-btn--next{
    right: -10px;
  }
}

@media (max-width: 767px){
  .chronicle{
    padding: 56px 0 82px;
  }

  .chronicle__inner{
    width: min(100%, calc(100% - 28px));
  }

  .chronicle__head{
    margin-bottom: 24px;
  }

  .chronicle__title{
    font-size: 56px;
  }

  .chronicle__title::before,
  .chronicle__title::after{
    width: 36px;
    margin: 0 .35em;
  }

  .chronicle__nav-btn{
    top: auto;
    bottom: -58px;
    width: 44px;
    height: 44px;
  }

  .chronicle__nav-btn--prev{
    left: calc(50% - 52px);
  }

  .chronicle__nav-btn--next{
    right: calc(50% - 52px);
  }

  .chronicle__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }

  .chronicle-card{
    grid-template-rows:
      auto
      3.0em
      4.8em
      34px
      92px;
    gap: 6px;
    padding: 16px 16px 14px;
    border-radius: 20px;
  }

  .chronicle-card::before{
    inset: 10px;
  }

  .chronicle-card__date{
    font-size: 11.5px;
  }

  .chronicle-card__title{
    font-size: 16px;
    line-height: 1.45;
    padding-left: 18px;
  }

  .chronicle-card__excerpt{
    font-size: 12.5px;
    line-height: 1.55;
  }

  .chronicle-card__btn{
    min-height: 28px;
    padding: 0 10px;
    font-size: 11px;
  }

  .chronicle-card__image{
    height: 92px;
  }
}

@media (max-width: 389px){
  .chronicle__grid{
    grid-template-columns: 1fr;
  }

  .chronicle-card{
    grid-template-rows:
      auto
      3.0em
      4.8em
      34px
      120px;
  }

  .chronicle-card__date{
    font-size: 13px;
  }

  .chronicle-card__title{
    font-size: 18px;
  }

  .chronicle-card__excerpt{
    font-size: 14px;
  }

  .chronicle-card__image{
    height: 120px;
  }
}


/* =========================
   6. Discography
   ========================= */

.discography{
  position: relative;
  padding: clamp(64px, 8vw, 96px) 0 100px;
  background-color: #111;
  background-image: url("https://lovely-junka.com/wp-content/uploads/2026/03/tubu-bk-1.png");
  background-repeat: repeat;
  background-size: 120px;
  color: #eee;
}

.discography__inner{
  width: min(1200px, calc(100% - 24px));
  margin: 0 auto;
}

.discography__head{
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin: 0 0 34px;
}

.discography__title{
  margin: 0 0 40px;
  font-family: var(--font-script);
  font-size: clamp(56px, 6vw, 86px);
  font-weight: 400;
  line-height: 1;
  letter-spacing: .02em;
  color: #c79d47;
  text-align: center;
  text-shadow: 0 2px 10px rgba(0,0,0,.25);

  display:flex;
  align-items:center;
  justify-content:center;
  gap:.55em;
}

.discography__title::before,
.discography__title::after{
  content:"";
  width: clamp(56px, 8vw, 96px);
  height:1px;
  background: rgba(199,157,71,.7);
}

.discography__grid{
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 22px 18px;
  align-items: start;
  justify-items: center;
}

.discography-card{
  width: 100%;
  max-width: 150px;
  transition: transform .25s ease, box-shadow .25s ease;
}

.discography-card:hover{
  transform: translateY(-6px);
}

.discography-card a{
  display: block;
  color: inherit;
  text-decoration: none;
  text-align: center;
}

.discography-card__image{
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 6px 16px rgba(0,0,0,.18);
  position: relative;
}

.discography-card__image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}

.discography-card:hover .discography-card__image img{
  transform: scale(1.05);
}

.discography-card:hover .discography-card__image{
  box-shadow: 0 14px 28px rgba(0,0,0,.28);
}

.discography-card__image::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(255,255,255,.35) 0%,
    rgba(255,255,255,0) 40%
  );
  pointer-events: none;
}

.discography-card__title{
  margin: 12px 0 4px;
  font-size: 15px;
  line-height: 1.6;
  letter-spacing: .04em;
  text-align: center;
  color: #dcdcdc;
}

.discography-card__listen{
  font-size: 12px;
  letter-spacing: .04em;
  color: #f3f3f3;
  transition: color .2s ease;
}

.discography-card__listen:hover{
  color: #c79d47;
}

@media (max-width: 1024px){
  .discography__grid{
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 20px 16px;
  }
}

@media (max-width: 767px){
  .discography{
    padding: 56px 0 72px;
  }

  .discography__inner{
    width: min(100%, calc(100% - 28px));
  }

  .discography__head{
    margin-bottom: 24px;
  }

  .discography__title{
    font-size: 48px;
  }

  .discography__title::before,
  .discography__title::after{
    width: 28px;
    margin: 0 .28em;
  }

  .discography__grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px 10px;
  }

  .discography-card{
    max-width: none;
  }

  .discography-card__title{
    font-size: 12px;
    line-height: 1.5;
  }

  .discography-card__listen{
    font-size: 11px;
  }
}


/* =========================
   News
   ========================= */

.news{
  padding: clamp(64px, 8vw, 96px) 0;
  background:#ffffff;
}

.news__inner{
  width:min(960px, calc(100% - 32px));
  margin:0 auto;
}

.news__head{
  text-align:center;
  margin-bottom:36px;
}

.news__title{
  margin:0;
  font-family: var(--font-body);
  font-size:28px;
  font-weight:600;
  letter-spacing:.08em;
  color:#333;
}

.news__list{
  list-style:none;
  padding:0;
  margin:0;
}

.news__item{
  display:flex;
  gap:18px;
  align-items:center;
  padding:14px 0;
  border-bottom:1px solid rgba(199,157,71,.25);
}

.news__date{
  font-size:13px;
  line-height:1.7;
  color:#8a8a8a;
  min-width:90px;
  flex:0 0 90px;
}

.news__link{
  text-decoration:none;
  color:#333;
  line-height:1.7;
  transition: color .2s ease;
}

.news__link:hover{
  color:#c79d47;
}

@media (max-width: 767px){
  .news__inner{
    width:min(100%, calc(100% - 24px));
  }

  .news__item{
    display:block;
    padding:12px 0;
  }

  .news__date{
    display:block;
    min-width:auto;
    margin-bottom:4px;
  }
}

/* =========================
   Footer
   ========================= */

footer.wp-block-template-part,
.wp-site-blocks > footer{
  background:#050505;
  color:#f3f3f3;
  padding:88px 20px 42px;
  text-align:center;
  border-top:1px solid rgba(255,255,255,.08);
}

footer.wp-block-template-part a,
.wp-site-blocks > footer a{
  color:#f3f3f3;
  text-decoration:none;
  transition:color .25s ease,opacity .25s ease,background-color .25s ease,border-color .25s ease;
}

/* footer inner */

.footer-jg{
  width:min(960px,calc(100% - 32px));
  margin:0 auto;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:28px;
}

/* logo */

.footer-jg__title{
  margin:0;
  font-family:var(--font-body);
  font-size:22px;
  font-weight:600;
  letter-spacing:.25em;
  color:#c79d47;
}

/* contact button */

.footer-contact-link{
  margin:0;
  text-align:center;
}

.footer-contact-link a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:220px;
  padding:16px 34px;
  border:1px solid #c79d47;
  border-radius:999px;
  background:transparent;
  color:#c79d47 !important;
  font-size:13px;
  letter-spacing:.18em;
  text-decoration:none;
  transition:background .25s ease,color .25s ease,border-color .25s ease;
}

.footer-contact-link a:hover{
  background:#c79d47;
  color:#050505 !important;
  border-color:#c79d47;
}

/* SNS */

.footer-jg .wp-block-social-links{
  justify-content:center;
  gap:14px;
  margin:0;
}

.footer-jg .wp-social-link{
  background:transparent !important;
  border:1px solid rgba(199,157,71,.6);
  transition:transform .25s ease,background-color .25s ease;
}

.footer-jg .wp-social-link:hover{
  transform:translateY(-2px);
  background:#c79d47 !important;
  border-color:#c79d47;
}

.footer-jg .wp-social-link svg{
  width:20px;
  height:20px;
  fill:#c79d47;
}

.footer-jg .wp-social-link:hover svg{
  fill:#050505;
}

/* copyright */

.footer-copy{
  margin-top:28px;
  font-size:12px;
  letter-spacing:.08em;
  color:rgba(255,255,255,.45);
  text-align:center;
}

/* =========================
   Footer mobile
   ========================= */

@media (max-width:767px){

footer.wp-block-template-part,
.wp-site-blocks > footer{
  padding:72px 16px 34px;
}

.footer-jg{
  gap:24px;
}

.footer-jg__title{
  font-size:18px;
  letter-spacing:.18em;
}

.footer-contact-link a{
  min-width:190px;
  padding:12px 28px;
  font-size:12px;
}

.footer-jg .wp-block-social-links{
  gap:12px;
}

}

/* =========================
   Contact page
   ========================= */

/* ページ高さ */
body.page-id-780 .wp-site-blocks{
  min-height:100vh;
  display:flex;
  flex-direction:column;
}

body.page-id-780 main{
  flex:1 0 auto;
}

body.page-id-780 footer.wp-block-template-part,
body.page-id-780 .wp-site-blocks > footer{
  margin-top:auto;
}

/* content spacing */
body.page-id-780 .entry-content,
body.page-id-780 .wp-block-post-content{
  padding-top:72px;
  padding-bottom:96px;
}

/* page title */
body.page-id-780 .entry-content > h2.wp-block-heading,
body.page-id-780 .wp-block-post-content > h2.wp-block-heading{
  display:block;
  width:100%;
  max-width:680px;
  margin:0 auto 44px !important;
  text-align:center;
  font-size:clamp(26px,3vw,32px);
  line-height:1.25;
  letter-spacing:.14em;
}

/* form */
body.page-id-780 .wpcf7{
  max-width:680px;
  margin:0 auto;
}

body.page-id-780 .wpcf7 p{
  margin:0 0 22px;
  text-align:left;
}

body.page-id-780 .wpcf7 p br{
  display:none;
}

body.page-id-780 .wpcf7 label{
  display:block;
  margin-bottom:3px;
  font-size:13px;
  letter-spacing:.08em;
  font-weight:400;
  color:#333;
}

/* note / required */
body.page-id-780 .form-note{
  text-align:right;
  font-size:12px;
  letter-spacing:.06em;
  color:#666;
  margin:0 0 22px;
}

body.page-id-780 .req{
  color:#c79d47;
  margin-left:4px;
  font-weight:600;
}

/* inputs */
body.page-id-780 .wpcf7 input:not([type="submit"]):not([type="checkbox"]):not([type="radio"]),
body.page-id-780 .wpcf7 textarea{
  width:100%;
  background:#fafafa;
  border:1px solid rgba(0,0,0,.10);
  border-radius:14px;
  padding:14px 16px;
  font-size:15px;
  line-height:1.7;
  box-sizing:border-box;
  margin-top:0;
  transition:border-color .2s ease,box-shadow .2s ease;
}

body.page-id-780 .wpcf7 textarea{
  min-height:220px;
  resize:vertical;
}

body.page-id-780 .wpcf7 input:focus,
body.page-id-780 .wpcf7 textarea:focus{
  outline:none;
  border-color:#c6a75a;
  box-shadow:0 0 0 3px rgba(198,167,90,.18);
}

/* submit */
body.page-id-780 .form-submit{
  margin-top:52px;
  text-align:center;
}

body.page-id-780 .form-submit p{
  margin:0;
}

body.page-id-780 .wpcf7 input[type="submit"]{
  display:block;
  min-width:250px;
  margin:0 auto;
  background:#050505;
  color:#fff;
  border:1px solid #c79d47;
  border-radius:999px;
  padding:18px 34px;
  font-size:14px;
  letter-spacing:.14em;
  cursor:pointer;
  transition:background-color .25s ease,color .25s ease,border-color .25s ease,transform .2s ease;
}

body.page-id-780 .wpcf7 input[type="submit"]:hover{
  background:#c79d47;
  color:#050505;
  border-color:#c79d47;
  transform:translateY(-1px);
}

/* message */
body.page-id-780 .wpcf7-response-output{
  margin:24px 0 0 !important;
  border:1px solid rgba(199,157,71,.35);
  border-radius:12px;
  padding:14px 16px;
  font-size:14px;
  line-height:1.7;
}

body.page-id-780 .wpcf7-not-valid-tip{
  margin-top:6px;
  font-size:12px;
  line-height:1.6;
  color:#b42318;
}

body.page-id-780 .wpcf7-not-valid{
  border-color:#d46a6a !important;
  box-shadow:0 0 0 3px rgba(212,106,106,.12);
}

/* mobile */
@media (max-width:767px){

  body.page-id-780 .entry-content,
  body.page-id-780 .wp-block-post-content{
    padding-top:48px;
    padding-bottom:72px;
  }

  body.page-id-780 .wpcf7{
    max-width:100%;
  }

  body.page-id-780 .wpcf7 p{
    margin-bottom:20px;
  }

  body.page-id-780 .wpcf7 textarea{
    min-height:180px;
  }

  body.page-id-780 .form-submit{
    margin-top:40px;
  }

  body.page-id-780 .wpcf7 input[type="submit"]{
    min-width:160px;
  }
}

/* contactページではフッターボタン非表示 */
body.page-id-780 .footer-contact-link{
  display:none !important;
}body.page-id-780 .req{
  color:#c79d47;
  margin-left:4px;
  font-weight:600;
}

/* mobile */

@media (max-width:767px){

body.page-id-780 .entry-content,
body.page-id-780 .wp-block-post-content{
  padding-top:48px;
  padding-bottom:72px;
  margin: 0 30px 0;
}

body.page-id-780 .wpcf7{
  max-width:100%;
}

body.page-id-780 .wpcf7 p{
  margin-bottom:22px;
}

body.page-id-780 .wpcf7 textarea{
  min-height:180px;
}

body.page-id-780 .wpcf7 input[type="submit"]{
  min-width:160px;
}

}

/* contactページではフッターボタン非表示 */

body.page-id-780 .footer-contact-link{
  display:none !important;
}

/* =========================
   Contact Thanks Page
   ========================= */

body.page-id-794{
  background: #000;
}

body.page-id-794 .wp-site-blocks{
  background: #000;
}

body.page-id-794 main{
  padding: 120px 20px 80px;
  background: #000;
}

body.page-id-794 .entry-content{
  padding-left: 0 !important;
  padding-right: 0 !important;
}

body.page-id-794 .thanks-message{
  max-width: 760px;
  margin: 0 auto;
  padding: 56px 40px;
  background: #f8f6f2;
  border: 1px solid #c79d47;
  border-radius: 18px;
  box-shadow: 0 10px 30px rgba(0,0,0,.15);
  text-align: center;
}

body.page-id-794 .thanks-message h1{
  margin: 0 0 28px;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.7;
  letter-spacing: .08em;
  color: #b9923f;
  text-align: center;
}

body.page-id-794 .thanks-message p{
  margin: 0 0 18px;
  font-size: 16px;
  line-height: 2;
  letter-spacing: .04em;
  color: #333;
  text-align: center;
}

body.page-id-794 .thanks-message p:last-child{
  padding-top: 20px;
  border-top: 1px solid rgba(0,0,0,.15);
  font-size: 14px;
  color: #b9923f;
}

@media (max-width: 767px){

  body.page-id-794 main{
    padding: 88px 20px 64px;
  }

  body.page-id-794 .thanks-message{
    padding: 36px 22px;
    border-radius: 14px;
  }

  body.page-id-794 .thanks-message h1{
    font-size: 28px;
    line-height: 1.6;
    letter-spacing: .06em;
  }

  body.page-id-794 .thanks-message p{
    font-size: 14px;
    line-height: 2;
  }

}

/* thanksページでは問い合わせボタンを隠す */
body.page-id-794 .footer-contact-link{
  display:none;
}

body.page-id-794 .footer-jg{
  padding-top:60px;
}


/* 送信内容エリア */
body.page-id-794 .thanks-detail{
  margin-top: 40px;
  padding-top: 30px;
  border-top: 1px solid rgba(0,0,0,.15);
  text-align: left;
}

body.page-id-794 .thanks-detail h2{
  margin: 0 0 24px;
  font-size: 18px;
  text-align: center;
  color: #b9923f;
  letter-spacing: .08em;
}

body.page-id-794 .thanks-detail-list{
  margin: 0;
}

body.page-id-794 .thanks-detail-row{
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 16px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(0,0,0,.08);
}

body.page-id-794 .thanks-detail-row:last-child{
  border-bottom: none;
}

body.page-id-794 .thanks-detail-row dt{
  margin: 0;
  font-weight: 400;
  color: #b9923f;
}

body.page-id-794 .thanks-detail-row dd{
  margin: 0;
  line-height: 1.9;
  color: #333;
  white-space: pre-wrap;
  word-break: break-word;
}

body.page-id-794 .thanks-detail-row--message dd{
  min-height: 5em;
}

body.page-id-794 .thanks-notice{
  margin-top: 28px;
  padding: 20px 22px;
  background: #f3eee4;
  border: 1px solid rgba(185,146,63,.28);
  border-radius: 10px;
  text-align: left;
}

body.page-id-794 .thanks-notice p{
  margin: 0 0 10px;
  font-size: 14px;
  line-height: 1.9;
  letter-spacing: .02em;
  color: #5a4a2f;
  text-align: left;
}

body.page-id-794 .thanks-notice p:last-child{
  margin-bottom: 0;
  padding-top: 0;
  border-top: none;
  font-size: 14px;
  color: #5a4a2f;
}

@media (max-width: 767px){

  body.page-id-794 .thanks-detail-row{
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 12px 0;
  }
  body.page-id-794 .thanks-notice{
    margin-top: 24px;
    padding: 16px 16px;
  }

  body.page-id-794 .thanks-notice p{
    font-size: 13px;
    line-height: 1.8;
  }

}



@media (max-width: 767px){
  .home .has-global-padding > .alignfull{
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}

@media (max-width: 767px){

  /* MV全体 */
  .wp-block-cover.alignfull{
    min-height: 62svh !important;
  }

  /* 背景画像の見せ位置を左へ */
  .wp-block-cover.alignfull > .wp-block-cover__image-background{
    object-position: 58% 70% !important;
  }

  /* タイトルを左へ */
  .wp-block-cover.alignfull .hero-title{
    position: absolute;
    left: 34% !important;
    top: 44% !important;
    transform: translate(-50%, -50%);
    width: auto;
    text-align: center;
    z-index: 2;
  }

 /* サイトタイトル（JUNKAGARDEN）を左から離す */
  .wp-block-site-title,
  .site-title{
    margin-left: 20px;
  }

  .wp-block-cover.alignfull .junka-ja{
    font-size: clamp(72px, 21vw, 120px);
    line-height: .95;
  }

  .wp-block-cover.alignfull .junka-en{
    font-size: clamp(24px, 7vw, 38px);
    margin-top: 6px;
  }
}

/* =========================
   Chronicle card alignment
   ========================= */

.chronicle-card{
  display: grid;
  grid-template-rows:
    auto   /* date */
    auto   /* title */
    auto   /* excerpt */
    auto   /* image */
    auto;  /* action */
  row-gap: 14px;
  align-content: start;
}

.chronicle-card__date,
.chronicle-card__title,
.chronicle-card__excerpt,
.chronicle-card__image,
.chronicle-card__action{
  margin: 0;
}

.chronicle-card__excerpt{
  min-height: 5.6em; /* だいたい3行分の保険。不要なら消してOK */
}

.chronicle-card__image{
  margin-top: 4px;
}

.chronicle-card__image img{
  display: block;
  width: 100%;
  height: auto;
}

.chronicle-card__action{
  min-height: 2em;
  display: flex;
  align-items: flex-start;
}

.chronicle-card__btn{
  display: inline-block;
  line-height: 1.6;
}

.chronicle-card__btn--ghost{
  visibility: hidden;
  pointer-events: none;
}
/* Chronicle action */

.chronicle-card__action{
  margin-top:-3px;
  min-height:1.2em;
}

.chronicle-card__btn{
  font-size:13px;
  line-height:1.4;
  color:#caa55b;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:6px;
  opacity:.9;
  transition:opacity .2s ease;
}

.chronicle-card__btn::before{
  content:"›";
  font-size:16px;
  line-height:1;
  color:#caa55b;
}

.chronicle-card__btn:hover{
  opacity:1;
}

.chronicle-card__btn--ghost{
  visibility:hidden;
  pointer-events:none;
}
.chronicle-card__title{
  margin: 0;
  min-height: 2.8em;
  line-height: 1.4;
}

@media (max-width: 768px){

  .chronicle__grid{
    grid-template-columns: 1fr !important;
    gap: 24px;
  }

  .chronicle-card{
    row-gap: 10px;
  }

  .chronicle-card__title{
    min-height: auto;
    line-height: 1.45;
  }

  .chronicle-card__excerpt{
    min-height: auto;
    line-height: 1.75;
  }

  .chronicle-card__title,
  .chronicle-card__excerpt{
    display: block !important;
    -webkit-line-clamp: unset !important;
    -webkit-box-orient: unset !important;
    overflow: visible !important;
    text-overflow: unset !important;
    white-space: normal !important;
  }

  .chronicle-card__btn{
    font-size: 12px;
  }
}

@media (max-width: 768px){

  .chronicle-card__image{
    aspect-ratio: auto !important;
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
  }

  .chronicle-card__image img{
    width: 100%;
    height: auto !important;
    aspect-ratio: auto !important;
    object-fit: contain !important;
    display: block;
  }

}

@media (max-width: 768px){

  .chronicle-card{
    padding: 28px 30px 22px;
    row-gap: 14px;
  }

  .chronicle-card__date{
    margin-bottom: 2px;
  }

  .chronicle-card__title{
    min-height: auto;
    line-height: 1.5;
  }

  .chronicle-card__excerpt{
    min-height: auto;
    line-height: 1.8;
  }

  .chronicle-card__image{
    margin-top: 10px;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    border-radius: 10px;
  }

  .chronicle-card__image img{
    width: 100%;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center 38%;
    display: block;
  }

  .chronicle-card__action{
    margin-top: -10px;
  }
}

.chronicle-card__image{
  margin-top: 10px;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 12px;
}

.chronicle-card__image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 38%;
  display: block;
}


/* =========================
   Chronicle 詳細ページ
   ========================= */

/* ページ全体の上側 */
body.single-chronicle main#wp--skip-link--target{
  padding-top: 0;
}

/* 上部のタイトルエリア全体 */
body.single-chronicle main > .wp-block-group.has-global-padding.is-layout-constrained{
  width: min(100% - 40px, 920px);
  max-width: 920px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 56px !important;
  padding-bottom: 24px !important;
}

/* アイキャッチ */
body.single-chronicle .wp-block-post-featured-image{
  margin: 0 0 32px 0 !important;
}

body.single-chronicle .wp-block-post-featured-image img{
  display: block;
  width: 100%;
  border-radius: 14px;
}

/* タイトル */
body.single-chronicle .wp-block-post-title{
  margin: 0 0 14px 0 !important;
  font-size: clamp(30px, 4vw, 42px) !important;
  line-height: 1.45 !important;
  letter-spacing: .04em;
}

/* 日付・メタ行 */
body.single-chronicle .wp-block-post-date{
  font-size: 14px;
  letter-spacing: .08em;
  color: #8a7d72;
}

/* 区切りの — を消す */
body.single-chronicle .wp-block-template-part .has-contrast-2-color{
  display: none;
}

/* by を消す */
body.single-chronicle .wp-block-template-part p.has-small-font-size{
  display: none;
}

/* 本文エリア */
body.single-chronicle .entry-content.wp-block-post-content{
  width: min(100% - 40px, 760px);
  max-width: 760px;
  margin: 0 auto;
  font-size: 17px;
  line-height: 2;
}

/* 本文の段落 */
body.single-chronicle .entry-content.wp-block-post-content p{
  margin-bottom: 1.2em;
}

/* SNSボタンを消す */
body.single-chronicle .veu_socialSet{
  display: none !important;
}

/* 本文の下側エリア */
body.single-chronicle main > .wp-block-group.has-global-padding.is-layout-constrained[style*="padding-bottom"]{
  width: min(100% - 40px, 760px);
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 40px !important;
}

/* 区切り線 */
body.single-chronicle .wp-block-separator{
  margin-bottom: 24px !important;
}

/* 前後ナビ */
body.single-chronicle nav[aria-label="投稿"]{
  padding-top: 24px !important;
  padding-bottom: 8px !important;
}

/* 前リンク */
body.single-chronicle .wp-block-post-navigation-link a{
  text-decoration: none;
  color: #5d4638;
  line-height: 1.7;
}

/* スマホ */
@media (max-width: 768px){

  body.single-chronicle main > .wp-block-group.has-global-padding.is-layout-constrained{
    width: calc(100% - 40px);
    padding-top: 34px !important;
    padding-bottom: 18px !important;
  }

  body.single-chronicle .wp-block-post-title{
    font-size: 28px !important;
  }

  body.single-chronicle .entry-content.wp-block-post-content{
    width: calc(100% - 40px);
    font-size: 16px;
    line-height: 1.95;
  }

  body.single-chronicle main > .wp-block-group.has-global-padding.is-layout-constrained[style*="padding-bottom"]{
    width: calc(100% - 40px);
  }

}

/* =========================
   Chronicle 詳細ページ 微調整
   ========================= */

/* 上の画像を少し自然な位置に戻す */
body.single-chronicle .wp-block-post-featured-image{
  width: min(100% - 40px, 760px) !important;
  max-width: 760px !important;
  margin: 0 auto 32px !important;
}

body.single-chronicle .wp-block-post-featured-image img{
  display: block !important;
  width: 100% !important;
  height: auto !important;
  object-fit: contain !important;
  object-position: center center !important;
  margin: 0 auto !important;
  border-radius: 14px !important;
}

/* タイトル・日付・本文も画像幅にそろえる */
body.single-chronicle .wp-block-post-title,
body.single-chronicle .entry-content.wp-block-post-content,
body.single-chronicle .wp-block-post-date,
body.single-chronicle .wp-block-post-date time{
  width: auto;
}

body.single-chronicle .wp-block-post-title,
body.single-chronicle .entry-content.wp-block-post-content,
body.single-chronicle .wp-block-post-date{
  max-width: 760px;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* いちばん下の前後ナビを消す */
body.single-chronicle nav[aria-label="投稿"]{
  display: none !important;
}

/* 区切り線も不要なら消す */
body.single-chronicle .wp-block-separator{
  display: none !important;
}

body.single-chronicle .chronicle-detail-image{
  width: min(100% - 40px, 760px);
  max-width: 760px;
  margin: 0 auto 36px;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 14px;
}

body.single-chronicle .chronicle-detail-image__img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  display: block;
}

@media (max-width: 768px){
  body.single-chronicle .chronicle-detail-image{
    aspect-ratio: 4 / 3;
  }
}

/* Chronicle タイトル装飾 */

.single-chronicle .entry-title,
.single-chronicle .wp-block-post-title{
  position: relative;
  text-align: center;
  margin-bottom: 40px;
}

.single-chronicle .entry-title::after,
.single-chronicle .wp-block-post-title::after{
  content:"";
  display:block;
  width:60px;
  height:1px;
  background:#c8a86b;
  margin:20px auto 0;
}



.single-chronicle .entry-content,
.single-chronicle .wp-block-post-content{
  padding:0 10px;
}

.single-chronicle .entry-content::after,
.single-chronicle .wp-block-post-content::after{
  content:"";
  display:block;
  width:120px;
  height:1px;
  background:#c8a86b;
  margin:60px auto 0;
}

/* =========================
   Chronicle 詳細ページ ラベル演出
   ========================= */

body.single-chronicle .wp-block-post-title{
  position: relative;
  text-align: center;
  margin-top: 0 !important;
}



/* 日付も少しなじませる */
body.single-chronicle .wp-block-post-date{
  text-align: center;
  font-size: 13px;
  letter-spacing: .14em;
  color: #9a8b7a;
}



/* =========================
   Chronicle タイトル演出
   ========================= */

body.single-chronicle .wp-block-post-title{
  text-align:center;
  position:relative;
  margin-top:30px;
}



/* タイトル下のライン */

body.single-chronicle .wp-block-post-title::after{
  content:"";
  display:block;
  width:auto;
  height:1px;
  background:#c8a86b;
  margin:30px auto 0;
}

body.single-chronicle{
  background:#f8f6f2;
}

body.single-chronicle .wp-block-post-title{
  white-space: pre-line;
}

.discography-card__listen-wrap{
  margin-top:18px;
  padding-top:16px;
  position:relative;
}

.discography-card__listen-wrap::before{
  content:"";
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:70%;
  height:1px;
  background:rgba(200,168,107,0.45);
}

/* =========================
   Single detail common width
   ========================= */

:root{
  --detail-text-width: 760px;
  --detail-kv-width: 980px;
}

/* Chronicle 詳細 */
body.single-chronicle .chronicle-detail-image,
body.single-chronicle .wp-block-post-featured-image{
  width: min(100% - 40px, var(--detail-kv-width)) !important;
  max-width: var(--detail-kv-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

body.single-chronicle .chronicle-detail-image{
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 14px;
}

body.single-chronicle .chronicle-detail-image__img,
body.single-chronicle .wp-block-post-featured-image img{
  width: 100%;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 30%;
  display: block;
  border-radius: 14px;
}

body.single-chronicle .chronicle-date{
  text-align: center;
  font-size: 14px;
  letter-spacing: .2em;
  color: #c9a96a; /* ゴールド */
  margin: 16px 0 24px;
  font-feature-settings: "palt";
}

/* Chronicle 本文幅 */
body.single-chronicle .wp-block-post-title,
body.single-chronicle .wp-block-post-date,
body.single-chronicle .entry-content.wp-block-post-content{
  width: min(100% - 40px, var(--detail-text-width));
  max-width: var(--detail-text-width);
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Discography 詳細用（先に仕込んでOK） */
body.single-discography .wp-block-post-featured-image{
  width: min(100% - 40px, var(--detail-kv-width)) !important;
  max-width: var(--detail-kv-width) !important;
  margin: 0 auto 32px !important;
}

body.single-discography .wp-block-post-featured-image img{
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
  border-radius: 14px;
}

body.single-discography .wp-block-post-title,
body.single-discography .entry-content.wp-block-post-content,
body.single-discography .wp-block-post-date{
  width: min(100% - 40px, var(--detail-text-width));
  max-width: var(--detail-text-width);
  margin-left: auto !important;
  margin-right: auto !important;
}

@media (max-width: 768px){
  :root{
    --detail-kv-width: 100%;
  }
}

/* =========================
   Discography detail layout
   ========================= */

/* 詳細ページではデフォルトのアイキャッチを消す */
body.single-discography .wp-block-post-featured-image{
  display: none;
}

body.single-discography .discography-hero{
  margin: 0 0 56px;
}

body.single-discography .discography-cover{
  max-width: 500px;
  margin: 0 auto;
}

body.single-discography .discography-cover img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 16px;
}

body.single-discography{
  background: #f3f3f3;
}

body.single-discography .entry-content{
  max-width: none;
}

body.single-discography .wp-block-post-featured-image{
  margin: 0;
}

body.single-discography .wp-block-post-featured-image img{
  display: block;
  width: 100%;
  height: auto;
  border-radius: 16px;
}

/* 全体の中央幅 */
body.single-discography .entry-content.wp-block-post-content{
  width: min(1000px, calc(100% - 48px));
  margin: 0 auto;
}


/* リード文 */
body.single-discography .discography-lead{
  max-width: 760px;
  margin: 0 auto 46px;
  text-align: center;
  font-size: 18px;
  line-height: 2;
  letter-spacing: 0.08em;
}

/* ジャケット画像 */
body.single-discography .wp-block-post-featured-image{
  max-width: 500px;
  margin: 0 auto 58px;
}

/* 本文 */
body.single-discography .entry-content.wp-block-post-content > p{
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
  font-size: 17.5px;
  line-height: 2.05;
  letter-spacing: 0.02em;
}

body.single-discography .entry-content.wp-block-post-content > p + p{
  margin-top: 0.7em;
}

/* エピソード見出し風 */
body.single-discography .entry-content.wp-block-post-content > p strong,
body.single-discography .entry-content.wp-block-post-content > p b{
  font-weight: 700;
}

body.single-discography .discography-hero{
  max-width: 760px;
  margin: 0 auto 64px;
  text-align: center;
}

body.single-discography .discography-lead{
  max-width: 760px;
  margin: 0 auto 36px;
  font-size: 18px;
  line-height: 2;
  letter-spacing: 0.06em;
}

body.single-discography .discography-cover{
  max-width: 560px;
  margin: 0 auto 56px;
}

body.single-discography .discography-cover img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 16px;
}

/* 作品情報帯 */
.discography-meta-wrap{
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-top: 72px;
  padding: 68px 0 68px;
  background: #e7e7e7;
}

.discography-meta-grid{
  width: min(760px, calc(100% - 48px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
}

.discography-meta-box h2{
  font-size: 18px;
  line-height: 1.5;
  margin: 0 0 28px;
  font-weight: 700;
}

.discography-meta-box{
  font-size: 16px;
}

.discography-meta-list{
  margin: 0;
}

.discography-meta-list > div{
  margin: 0 0 8px;
}

.discography-meta-list dt{
  display: inline;
  font-weight: 700;
}

.discography-meta-list dt::after{
  content: "：";
}

.discography-meta-list dd{
  display: inline;
  margin: 0;
}

.discography-track-list{
  margin: 0;
  padding-left: 1.2em;
}

.discography-track-list li{
  margin: 0 0 10px;
  line-height: 1.9;
}

/* YouTubeエリア */
.discography-movie{
  width: min(1000px, calc(100% - 48px));
  margin: 0 auto;
  padding: 64px 0 90px;
}

.discography-movie-grid{
  display: grid;
  gap: 42px;
}

.discography-movie-grid.is-double{
  grid-template-columns: 1fr 1fr;
}

.discography-movie-grid.is-single{
  grid-template-columns: 1fr;
  max-width: 420px;
  margin: 0 auto;
}

.discography-movie-item{
  background: #000;
}

.discography-movie-item iframe{
  width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
  display: block;
}

/* YouTube未設定時の仮箱を置きたいなら使う */
.discography-movie-item.is-placeholder{
  aspect-ratio: 16 / 9;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 24px;
}

/* スマホ */
@media (max-width: 767px){

  body.single-discography .entry-content.wp-block-post-content{
    width: min(100%, calc(100% - 32px));
  }

  body.single-discography h1.wp-block-post-title{
    font-size: 42px;
    margin: 56px 0 24px;
  }

  body.single-discography .discography-lead{
    font-size: 16px;
    line-height: 1.9;
    margin-bottom: 30px;
  }

  body.single-discography .wp-block-post-featured-image{
    max-width: 100%;
    margin-bottom: 38px;
  }

  body.single-discography .entry-content.wp-block-post-content > p{
    font-size: 16px;
    line-height: 1.95;
  }

  .discography-meta-wrap{
    margin-top: 48px;
    padding: 40px 0;
  }

  .discography-meta-grid{
    width: min(100%, calc(100% - 32px));
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .discography-movie{
    width: min(100%, calc(100% - 32px));
    padding: 72px 0 100px;
  }

  .discography-movie-grid.is-double,
  .discography-movie-grid.is-single{
    grid-template-columns: 1fr;
    max-width: none;
  }
}


/* Discography 詳細ページのSNSシェアを消す */
body.single-discography .veu_socialSet{
  display: none !important;
}

/* Discography YouTube */
.discography-movie{
  max-width: 1000px;
  margin: 0 auto;
  padding: 72px 24px 90px;
}

.discography-movie-grid{
  display: grid;
  gap: 40px;
}

.discography-movie-grid.is-double{
  grid-template-columns: 1fr 1fr;
}

.discography-movie-grid.is-single{
  grid-template-columns: 1fr;
  max-width: 640px;
  margin: 0 auto;
}

.discography-movie-item iframe{
  width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
  display: block;
}

/* Discography 金ラベル */
.discography-label{
  text-align:center;
  font-size:14px;
  letter-spacing:0.35em;
  color:#c6a062;
  margin-top:40px;
  margin-bottom:14px;
}

/* 金ライン */
.discography-divider{
  width:70px;
  height:2px;
  background:#c6a062;
  margin:0 auto 28px;
}

/* SP */
@media (max-width: 767px){
  .discography-movie{
    padding: 48px 20px 64px;
  }

  .discography-movie-grid.is-double,
  .discography-movie-grid.is-single{
    grid-template-columns: 1fr;
    max-width: none;
  }
}

/* =========================
   Custom Effects
   ========================= */
header .wp-block-site-title{
  margin-left: 20px !important;
}

header .wp-block-site-title a{
  font-size: 19px !important;
  letter-spacing: 0.14em !important;
  font-weight: 600 !important;
  color: #fff !important;
  text-decoration: none !important;
}

header .wp-block-navigation
header .wp-block-navigation__container{
  gap: 34px !important;
}

header a::after{
  display: none !important;
}

header .wp-block-navigation a,
header .wp-block-site-title a{
  color: #fff;
  transition: all .3s ease;
  letter-spacing: 0.08em;

}

header .wp-block-navigation a:hover,
header .wp-block-site-title a:hover{
  color: #8f08b5 !important;
  text-shadow: 0 0 6px rgba(255,255,255,0.8) !important;
}

header a:focus,
header a:active,
header a:focus-visible{
  outline: none !important;
  box-shadow: none !important;
}


/* =========================
   chronicle-card
   ========================= */

.chronicle-card__image{
  width: 100%;
  height: 140px;
  overflow: hidden;
  border-radius: 18px;
  display: block;
}

.chronicle-card__image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.chronicle-card__image--placeholder img{
  object-fit: cover;
}


/* =========================
   single-chronicle-content
   ========================= */

.chronicle-main-visual{
  max-width: 760px;
  margin: 0 auto 48px;
}

.chronicle-main-visual img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 16px;
}

body.single-chronicle .chronicle-main-visual{
  padding: 0 16px;
}
/* Chronicle 詳細画像を Discography と同じ幅にする */
body.single-chronicle .chronicle-detail-image{
  max-width: 560px !important;
  margin: 0 auto 56px !important;
  padding: 0 !important;
}

body.single-chronicle .chronicle-detail-image__img{
  width: 100%;
  height: auto !important;
  display: block;
  border-radius: 16px;
  object-fit: cover;
}

body.single-chronicle .chronicle-lead{
  max-width: 760px;
  margin: 0 auto 36px;
  text-align: center;
  font-size: 18px;
  line-height: 2;
  letter-spacing: .06em;
}


/* ========================================
   Detail hero image unified crop
   Discography / Chronicle 共通
   ======================================== */

/* 同じ箱サイズにする */
body.single-discography .discography-cover,
body.single-chronicle .chronicle-detail-image{
  width: min(100% - 40px, 560px) !important;
  max-width: 560px !important;
  margin: 0 auto 56px !important;
  aspect-ratio: 16 / 9 !important;
  overflow: hidden !important;
  border-radius: 16px !important;
  padding: 0 !important;
}

/* 中の画像を同じようにトリミング */
body.single-discography .discography-cover img,
body.single-chronicle .chronicle-detail-image__img{
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
  border-radius: 16px !important;
}

/* ========================================
   Single detail pages: fixed header overlap fix
   ======================================== */

body.single-chronicle .wp-site-blocks,
body.single-discography .wp-site-blocks{
  padding-top: 110px !important;
}

@media (max-width: 767px){
  body.single-chronicle .wp-site-blocks,
  body.single-discography .wp-site-blocks{
    padding-top: 88px !important;
  }
}

/* ========================================
   Chronicle detail layout
   Discography に寄せて統一
   ======================================== */

/* 全体の中央幅 */
body.single-chronicle .wp-block-post-title,
body.single-chronicle .chronicle-date,
body.single-chronicle .chronicle-lead,
body.single-chronicle .chronicle-detail-image,
body.single-chronicle .entry-content.wp-block-post-content{
  width: min(100%, calc(100% - 48px));
  margin-left: auto;
  margin-right: auto;
}


/* タイトル上ラベル */
body.single-chronicle .wp-block-post-title::before{
  margin-bottom: 14px;
  font-size: 14px;
  letter-spacing: 0.35em;
}

/* タイトル下ライン */
body.single-chronicle .wp-block-post-title::after{
  width: auto;
  margin: 30px auto 0;
}

/* 日付 */
body.single-chronicle .chronicle-date{
  max-width: 760px;
  margin: 14px auto 24px;
  text-align: center;
  font-size: 13px;
  line-height: 1.8;
  letter-spacing: 0.08em;
  color: #c6a062;
}

/* リード文 */
body.single-chronicle .chronicle-lead{
  max-width: 760px;
  margin: 0 auto 36px;
  text-align: center;
  font-size: 18px;
  line-height: 2;
  letter-spacing: 0.06em;
}

/* 詳細画像 */
body.single-chronicle .chronicle-detail-image{
  max-width: 560px;
  margin: 0 auto 56px;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 16px;
}

body.single-chronicle .chronicle-detail-image__img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  border-radius: 16px;
}

/* 本文 */
body.single-chronicle .entry-content.wp-block-post-content{
  max-width: 760px;
}

body.single-chronicle .entry-content.wp-block-post-content > p{
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
  font-size: 17.5px;
  line-height: 2.05;
  letter-spacing: 0.02em;
}

body.single-chronicle .entry-content.wp-block-post-content > p + p{
  margin-top: 0.7em;
}

/* 自動リード強調を無効化 */
body.single-chronicle .entry-content > p:first-of-type,
body.single-chronicle .wp-block-post-content > p:first-of-type{
  font-size: 17.5px;
  line-height: 2.05;
  letter-spacing: 0.02em;
}

/* スマホ */
@media (max-width: 767px){
  body.single-chronicle .wp-block-post-title{
    font-size: 42px;
    margin-bottom: 16px;
  }

  body.single-chronicle .chronicle-date{
    margin: 14px auto 22px;
    font-size: 13px;
  }

  body.single-chronicle .chronicle-lead{
    margin-bottom: 30px;
    font-size: 16px;
    line-height: 1.9;
  }

  body.single-chronicle .chronicle-detail-image{
    max-width: 100%;
    margin-bottom: 38px;
  }

  body.single-chronicle .entry-content.wp-block-post-content > p{
    font-size: 16px;
    line-height: 1.95;
  }
}

/* ========================================
   Single title unified（新タイトル用）
   ======================================== */

body.single-chronicle .chronicle-display-title,
body.single-discography .discography-display-title{
  max-width: 760px;
  width: min(100%, calc(100% - 48px));
  margin: 0 auto 18px;
  text-align: center;
  font-size: clamp(30px, 3.6vw, 44px);
  line-height: 1.05;
  letter-spacing: 0.04em;
  white-space: normal;
}

body.single-chronicle .chronicle-display-title br,
body.single-discography .discography-display-title br{
  line-height: 0.6;
}

/* ラベル共通 */
.discography-label,
.chronicle-label{
  font-size: 14px;
  letter-spacing: 0.3em;
  text-align: center;
  color: #c6a062;
  margin-bottom: 10px;
}

/* 下線 */
.discography-divider,
.chronicle-divider{
  width: 60px;
  height: 2px;
  background: #c6a062;
  margin: 0 auto 24px;
}

/* ラベル */
.discography-label,
.chronicle-label{
  margin-bottom: 10px !important;
}

/* 線 */
.discography-divider,
.chronicle-divider{
  margin: 0 auto 24px !important;
}

/* タイトル */
body.single-chronicle .wp-block-post-title,
body.single-discography .wp-block-post-title{
  margin-top: 0 !important;
}

/* Disco タイトル下ライン */
body.single-discography .wp-block-post-title::after{
  content: "";
  display: block;
  width: auto;
  height: 1px;
  background: #c6a062;
  margin: 30px auto 30px;
}

/* ========================================
   タブレット・スマホ横はPC寄りに戻す
   ======================================== */
@media (min-width: 641px) and (max-width: 900px){

  /* Chronicle */
  .chronicle__inner{
    width: min(1200px, calc(100% - 32px)) !important;
  }

  .chronicle__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 18px !important;
  }

  .chronicle-card{
    padding: 22px 22px 18px !important;
  }

  .chronicle-card__image{
    height: 120px !important;
  }

  /* Discography */
  .discography__inner{
    width: min(1200px, calc(100% - 32px)) !important;
  }

  .discography__grid{
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 16px 12px !important;
  }

  .discography-card{
    max-width: none !important;
  }

  /* News */
  .news__inner{
    width: min(960px, calc(100% - 32px)) !important;
  }
}

/* ========================================
   Responsive cleanup
   スマホ横・タブレット崩れ修正
   style.css のいちばん最後に追加
   ======================================== */

/* ------------------------
   1) 共通：横スクロール予防
------------------------ */
html,
body{
  overflow-x: hidden;
}

img{
  max-width: 100%;
  height: auto;
}

/* ------------------------
   2) スマホ縦（〜640px）
------------------------ */
@media (max-width: 640px){

  p{
    font-size: 15.5px;
    line-height: 1.95;
    letter-spacing: .03em;
  }

  .message-section{
    padding: 48px 18px;
  }

  .message-inner{
    width: min(100%, calc(100% - 12px));
  }

  .message-section p{
    font-size: 15.5px;
    line-height: 2;
  }

  .jp-profile{
    padding: 52px 0 68px;
  }

  .jp-profile__inner{
    width: min(100%, calc(100% - 28px));
    gap: 34px;
  }

  .jp-profile__section-title{
    margin-bottom: 26px;
    font-size: clamp(2.2rem, 10vw, 3rem);
  }

  .jp-profile__photo img{
    width: 60%;
  }

  .jp-profile__badges{
    gap: 10px;
  }

  .badge{
    padding: 14px 8px 18px;
  }

  .badge__year{
    font-size: 18px;
  }

  .badge__title{
    font-size: 12px;
  }

  .badge__sub{
    font-size: 10.5px;
    line-height: 1.5;
  }

  .meta-row{
    grid-template-columns: 86px 1fr;
    column-gap: 10px;
    padding: 10px 0;
  }

  .meta-label,
  .meta-value{
    font-size: 13px;
  }

  /* Chronicle */
  .chronicle{
    padding: 52px 0 72px;
  }

  .chronicle__inner{
    width: min(100%, calc(100% - 24px));
  }

  .chronicle__title{
    font-size: 44px;
    margin-bottom: 26px;
  }

  .chronicle__title::before,
  .chronicle__title::after{
    width: 26px;
  }

  .chronicle__grid{
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .chronicle-card{
    padding: 20px 37px 16px !important;
    row-gap: 10px !important;
    border-radius: 18px;
  }

  .chronicle-card__date{
    font-size: 11px;
  }

  .chronicle-card__title{
    font-size: 15px;
    line-height: 1.45;
    min-height: auto;
  }

  .chronicle-card__excerpt{
    font-size: 12px;
    line-height: 1.65;
    min-height: auto;
  }

  .chronicle-card__image{
    height: 130px !important;
    aspect-ratio: auto !important;
    border-radius: 10px;
  }

  .chronicle-card__image img{
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 10px;
  }

  .chronicle__nav-btn{
    width: 42px;
    height: 42px;
    bottom: -54px;
  }

  /* Discography */
  .discography{
    padding: 52px 0 66px;
  }

  .discography__inner{
    width: min(100%, calc(100% - 24px));
  }

  .discography__title{
    font-size: 42px;
    margin-bottom: 26px;
  }

  .discography__title::before,
  .discography__title::after{
    width: 24px;
  }

  .discography__grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px 10px;
  }

  .discography-card__title{
    font-size: 11.5px;
    line-height: 1.45;
  }

  .discography-card__listen{
    font-size: 10.5px;
  }

  .news{
    padding: 52px 0;
  }

  .news__inner{
    width: min(100%, calc(100% - 24px));
  }

  .news__title{
    font-size: 24px;
  }
}

/* ------------------------
   3) スマホ横〜タブレット（641〜1024px）
   ここをPC寄りに整える
------------------------ */
@media (min-width: 641px) and (max-width: 1024px){

  p{
    font-size: 16px;
    line-height: 1.9;
    letter-spacing: .03em;
  }

  .wp-block-site-title,
  .site-title{
    margin-left: 24px;
  }

  /* MV */
  .wp-block-cover.alignfull{
    min-height: 72svh !important;
  }

  .wp-block-cover.alignfull > .wp-block-cover__image-background{
    object-position: 60% 50% !important;
  }

  .wp-block-cover .hero-title,
  .wp-block-cover.alignfull .hero-title{
    left: 27% !important;
    top: 39% !important;
    transform: translate(-50%, -50%);
  }

  .wp-block-cover .junka-ja,
  .wp-block-cover.alignfull .junka-ja{
    font-size: clamp(64px, 10vw, 96px);
    line-height: 1;
  }

  .wp-block-cover .junka-en,
  .wp-block-cover.alignfull .junka-en{
    font-size: clamp(28px, 4vw, 44px);
    margin-top: 2px;
  }

  /* Message */
  .message-section{
    padding: 72px 28px;
  }

  .message-inner{
    width: min(860px, calc(100% - 24px));
  }

  .message-section p{
    font-size: 16px;
    line-height: 2.05;
  }

  /* Biography */
  .jp-profile{
    padding: 72px 0 82px;
  }

  .jp-profile__section-title{
    margin-bottom: 44px;
    font-size: clamp(2.5rem, 6vw, 3.4rem);
  }

  .jp-profile__inner{
    width: min(100%, calc(100% - 36px));
    grid-template-columns: 320px 1fr;
    gap: 36px;
  }

  .jp-profile__photo img{
    width: 100%;
    max-width: 300px;
    margin: 0 auto;
  }

  .jp-profile__badges{
    gap: 12px;
  }

  .badge{
    min-height: 150px;
    padding: 14px 10px 22px;
  }

  .badge__year{
    font-size: 22px;
  }

  .badge__title{
    font-size: 13px;
  }

  .badge__sub{
    font-size: 11px;
    line-height: 1.5;
  }

  .jp-profile__name{
    margin-bottom: 24px;
    font-size: clamp(26px, 3vw, 36px);
  }

  .meta-row{
    grid-template-columns: 96px 1fr;
    column-gap: 14px;
  }

  .meta-label,
  .meta-value{
    font-size: 14px;
  }

  .jp-profile__body p{
    font-size: 15.5px;
    line-height: 1.95;
  }

  /* Chronicle */
  .chronicle{
    padding: 68px 0 86px;
  }

  .chronicle__inner{
    width: min(100%, calc(100% - 36px)) !important;
  }

  .chronicle__title{
    font-size: clamp(48px, 6vw, 68px);
    margin-bottom: 28px;
  }

  .chronicle__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 18px !important;
  }

  .chronicle-card{
    padding: 22px 18px 18px !important;
    row-gap: 10px !important;
    border-radius: 22px;
  }

  .chronicle-card__date{
    font-size: 12px;
  }

  .chronicle-card__title{
    font-size: 17px;
    line-height: 1.4;
    min-height: auto;
  }

  .chronicle-card__excerpt{
    font-size: 13px;
    line-height: 1.65;
    min-height: auto;
  }

  .chronicle-card__action{
    margin-top: 0 !important;
  }

  .chronicle-card__image{
    height: 118px !important;
    border-radius: 12px;
  }

  .chronicle-card__image img{
    height: 100% !important;
    object-fit: cover !important;
  }

  .chronicle__nav-btn{
    width: 54px;
    height: 54px;
  }

  .chronicle__nav-btn--prev{
    left: -8px;
  }

  .chronicle__nav-btn--next{
    right: -8px;
  }

  /* Discography */
  .discography{
    padding: 68px 0 82px;
  }

  .discography__inner{
    width: min(100%, calc(100% - 36px)) !important;
  }

  .discography__title{
    font-size: clamp(48px, 6vw, 68px);
    margin-bottom: 28px;
  }

  .discography__grid{
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 18px 14px !important;
  }

  .discography-card{
    max-width: none !important;
  }

  .discography-card__title{
    font-size: 13px;
    line-height: 1.5;
  }

  .discography-card__listen{
    font-size: 11px;
  }

  /* News */
  .news{
    padding: 68px 0;
  }

  .news__inner{
    width: min(960px, calc(100% - 36px)) !important;
  }

  .news__title{
    font-size: 26px;
  }

  .news__date{
    min-width: 82px;
    flex-basis: 82px;
    font-size: 12px;
  }

  .news__link{
    font-size: 14px;
    line-height: 1.65;
  }

  /* Footer */
  .footer-jg{
    gap: 24px;
  }

  .footer-contact-link a{
    min-width: 200px;
    padding: 14px 30px;
    font-size: 12px;
  }
}

/* ------------------------
   4) 横向きスマホだけ少し補正
------------------------ */
@media (max-width: 932px) and (orientation: landscape){

  .wp-block-cover.alignfull{
    min-height: 100svh !important;
  }

  .wp-block-cover .hero-title,
  .wp-block-cover.alignfull .hero-title{
    left: 26% !important;
    top: 42% !important;
  }

  .wp-block-cover .junka-ja,
  .wp-block-cover.alignfull .junka-ja{
    font-size: clamp(52px, 8vw, 84px);
  }

  .wp-block-cover .junka-en,
  .wp-block-cover.alignfull .junka-en{
    font-size: clamp(22px, 3.2vw, 34px);
  }

  .chronicle__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .discography__grid{
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}

/* ========================================
   2列版の余白・カード切れ調整
   いちばん最後に追記
   ======================================== */
@media (min-width: 641px) and (max-width: 1024px){

  /* セクション全体の左右余白を増やす */
  .chronicle__inner,
  .discography__inner,
  .news__inner,
  .jp-profile__inner,
  .message-inner{
    width: min(1200px, calc(100% - 56px)) !important;
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
  }

  /* Chronicle 2列の間隔を少し広げる */
  .chronicle__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 20px !important;
  }

  /* カードを少しだけ軽くする */
  .chronicle-card{
    box-sizing: border-box;
    padding: 20px 18px 16px !important;
    border-radius: 22px !important;
  }

  /* 内側の飾り罫線を少し内縮み */
  .chronicle-card::before{
    inset: 12px !important;
  }

  /* タイトル・抜粋の固定高さがきつい場合の保険 */
  .chronicle-card__title,
  .chronicle-card__excerpt{
    min-height: auto !important;
  }

  /* 画像まわりの圧迫感を少し軽減 */
  .chronicle-card__image{
    height: 110px !important;
    border-radius: 10px !important;
    overflow: hidden !important;
  }

  .chronicle-card__image img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  /* Discography も外側で切れにくくする */
  .discography__grid{
    gap: 18px 40px !important;
  }

  .discography-card{
    box-sizing: border-box;
    min-width: 0;
  }

  .discography-card__image{
    border-radius: 8px;
    overflow: hidden;
  }
}

body.home{
  --wp--style--root--padding-left: 0px;
  --wp--style--root--padding-right: 0px;
}

/* タブレット〜スマホ横 */
@media (min-width: 768px) and (max-width: 1024px){

  .chronicle-card{
    padding: 30px 50px 24px !important;
    row-gap: 14px !important;
  }

  .chronicle-card::before{
    inset: 16px !important;
  }

  .chronicle-card__title{
    padding-left: 20px !important;
  }

  .chronicle-card__image{
    height: 150px !important;   /* ← 110px ではなく大きくする */
    margin-top: 14px !important;
    border-radius: 12px !important;
    overflow: hidden !important;
  }

  .chronicle-card__image img{
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
  }
}
/* フォーカス枠の調整 */
a:focus,
button:focus{
  outline: none;
}

a:focus-visible,
button:focus-visible{
  outline: 1.5px solid #c9a063;
  outline-offset: 3px;
}

/* =========================
   Discography links（完成版）
   ========================= */

/* リンク全体ラップ */
.discography-card__listen-wrap{
  text-align: center;
  margin-top: 8px;
}

/* 詳細リンク（弱め・上品） */
.discography-card__detail{
  display: block;
  margin-bottom: 8px;
  font-size: 13px;
  line-height: 1.6;
  letter-spacing: .08em;
  color: #c79d47;
  text-decoration: none;
  transition: opacity .25s ease;
}

/* ホバー */
.discography-card__detail:hover{
  opacity: .7;
}

/* 聴いてみる（主役） */
.discography-card__listen{
  display: inline-block;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: .06em;
  color: #fff;
  text-decoration: none;
  transition: opacity .25s ease;
}

/* ホバー */
.discography-card__listen:hover{
  opacity: .7;
}

/* スマホでもバランス崩れないように */
@media (max-width: 767px){

  .discography-card__detail{
    font-size: 12.5px;
  }

  .discography-card__listen{
    font-size: 13px;
  }
}

/* =========================
   single post：SNS非表示
   ========================= */
body.single-post .veu_socialSet{
  display: none !important;
}

/* =========================
   single post：フッター下部吸着
   ========================= */
body.single-post .wp-site-blocks{
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

body.single-post main{
  flex: 1 0 auto;
}

body.single-post footer.wp-block-template-part,
body.single-post .wp-site-blocks > footer{
  margin-top: auto;
}

/* ========================================
   全ページ：フッターを下に吸着
   ======================================== */

html, body{
  height: 100%;
}

.wp-site-blocks{
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* メインコンテンツを伸ばす */
.wp-site-blocks > main{
  flex: 1 0 auto;
}

/* フッターを下へ */
.wp-site-blocks > footer,
footer.wp-block-template-part{
  margin-top: auto;
}

.meta-row{
  min-height: 72px;
  display: flex;
  align-items: center;
  padding: 0; /* 念のため */
}

.meta-label,
.meta-value{
  margin: 0;
  line-height: 1.4;
  display: flex;
  align-items: center;
}


html{
  -webkit-text-size-adjust: 100%;
}

.parallax-bg{
  will-change: transform;
  transform: translate3d(0,0,0);
}

/* =========================
   Scroll reveal
   まとめてどん版
   ========================= */

.reveal-target{
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .9s ease, transform .9s ease;
  will-change: opacity, transform;
}

.reveal-target.is-visible{
  opacity: 1;
  transform: translateY(0);
}

/* 少しだけ差をつけたい時 */
.reveal-target.reveal-soft{
  transform: translateY(18px);
  transition-duration: .8s;
}

@media (prefers-reduced-motion: reduce){
  .reveal-target{
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}