/* ===== TRAUM MAGAZINE v5 — Real Magazine, Not a Website ===== */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;700;900&family=Bebas+Neue&family=DM+Serif+Display:ital@0;1&family=Outfit:wght@200;300;400;600&display=swap');

:root {
  --yellow: #FFD600;
  --gold: #c8a800;
  --black: #0e0e0e;
  --white: #fff;
  --sans: 'Noto Sans JP', sans-serif;
  --latin: 'Outfit', sans-serif;
  --display: 'Bebas Neue', sans-serif;
  --serif: 'DM Serif Display', serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body { background: #000; margin: 0; }

/* =========================
   SPREAD — every "page"
   ========================= */
.spread {
  position: relative;
  width: 100%;
  max-width: 1100px;
  min-height: 100vh;
  margin: 0 auto;
  overflow: hidden;
  color: #fff;
}

/* Full-bleed photo placeholder */
.photo-fill {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background-size: cover;
  background-position: center;
}
.photo-fill > span {
  font-family: var(--display);
  font-size: 0.7rem;
  letter-spacing: 0.5em;
  color: rgba(255,255,255,0.06);
  text-transform: uppercase;
}
/* Tonal placeholders */
.photo-fill--warm   { background: linear-gradient(160deg, #5a4018, #9a7030, #6a4a18); }
.photo-fill--cool   { background: linear-gradient(160deg, #1a2a3a, #2a4a5a, #1a2a3a); }
.photo-fill--amber  { background: linear-gradient(160deg, #5a3a08, #8a6020, #5a3a08); }
.photo-fill--green  { background: linear-gradient(160deg, #1a3a18, #2a5a28, #1a3a18); }
.photo-fill--purple { background: linear-gradient(160deg, #2a1a3a, #4a2a5a, #2a1a3a); }
.photo-fill--yellow { background: linear-gradient(135deg, #FFD600, #FFB800, #FFD600); }
.photo-fill--gold   { background: linear-gradient(135deg, #FFD600, #e8c000, #FFB800); }
.photo-fill--dark   { background: linear-gradient(160deg, #0e0e0e, #1a1a1a, #0e0e0e); }
.photo-fill--dark2  { background: linear-gradient(160deg, #141410, #1e1e18, #141410); }
.photo-fill--warm2  { background: linear-gradient(140deg, #6a4a18, #9a7838, #5a3a10); }
.photo-fill--warm3  { background: linear-gradient(170deg, #4a3a18, #7a6030, #4a3010); }
.photo-fill--tips   { background: linear-gradient(135deg, #3a2a08, #6a5020, #9a7830, #5a4018); }
.photo-fill--office { background: linear-gradient(160deg, #2a2a20, #4a4a38, #2a2a20); }
.photo-fill--battle { background: linear-gradient(160deg, #1a0a1a, #2a1a30, #1a0a20); }
.photo-fill--office2 { background: linear-gradient(160deg, #2a2820, #3a3830, #2a2820); }
.photo-fill--tech   { background: linear-gradient(160deg, #0a1a2a, #1a2a3a, #0a1520); }
.photo-fill--warm4  { background: linear-gradient(160deg, #5a4020, #8a6838, #5a4020); }
.photo-fill--contents { background: linear-gradient(160deg, #1a1808, #2a2510, #1a1808); }
.photo-fill--next   { background: linear-gradient(160deg, #2a2008, #4a3818, #2a2008); }

/* Page number */
.page-num {
  position: absolute;
  bottom: 20px;
  right: 30px;
  font-family: var(--display);
  font-size: 0.65rem;
  letter-spacing: 0.3em;
  color: rgba(255,255,255,0.2);
  z-index: 10;
}

/* ================================================================
   COVER
   ================================================================ */
.cover .photo-fill {
  background: linear-gradient(160deg, #4a3a10, #8a7030, #c9a040, #7a6020, #3a2a08);
}
.cover__dim {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.4) 0%, transparent 25%, transparent 55%, rgba(0,0,0,0.75) 100%);
}

.cover__ui {
  position: absolute; top: 28px; left: 35px; right: 35px; z-index: 5;
  display: flex; justify-content: space-between;
  font-family: var(--latin); font-size: 0.55rem; letter-spacing: 0.25em;
  color: rgba(255,255,255,0.45); text-transform: uppercase;
}

.cover__logo {
  position: absolute; top: 55px; left: 0; right: 0; z-index: 4;
  text-align: center;
  font-family: var(--display);
  font-size: clamp(6rem, 18vw, 12rem);
  letter-spacing: 0.12em;
  color: var(--yellow);
  line-height: 0.82;
  text-shadow: 0 4px 30px rgba(0,0,0,0.4);
  mix-blend-mode: screen;
}
.cover__sub {
  position: absolute; top: calc(55px + clamp(5rem,15vw,10rem)); left: 0; right: 0; z-index: 4;
  text-align: center;
  font-family: var(--serif); font-style: italic;
  font-size: clamp(0.8rem, 1.5vw, 1.1rem);
  letter-spacing: 0.65em; color: rgba(255,255,255,0.5);
}

.cover__bottom {
  position: absolute; bottom: 35px; left: 35px; right: 35px; z-index: 5;
  display: flex; justify-content: space-between; align-items: flex-end;
}
.cover__bottom small {
  display: block; font-family: var(--display); font-size: 0.5rem;
  letter-spacing: 0.5em; color: var(--yellow); margin-bottom: 6px;
}
.cover__bottom h2 {
  font-family: var(--sans); font-size: clamp(2.5rem, 6vw, 4rem);
  font-weight: 900; line-height: 1;
  text-shadow: 0 2px 8px rgba(0,0,0,0.5);
}
.cover__bottom > div:first-child p {
  font-family: var(--latin); font-size: 0.65rem; letter-spacing: 0.1em;
  color: rgba(255,255,255,0.5); margin-top: 5px;
}
.cover__right { text-align: right; max-width: 40%; }
.cover__headline {
  font-family: var(--sans); font-size: clamp(1rem, 2vw, 1.4rem);
  font-weight: 700; line-height: 1.6;
  text-shadow: 0 1px 6px rgba(0,0,0,0.5);
}
.cover__topics {
  font-family: var(--latin); font-size: 0.5rem; letter-spacing: 0.08em;
  color: rgba(255,255,255,0.3); margin-top: 8px;
}

/* ================================================================
   INTERVIEW (photo + text integrated)
   ================================================================ */
.interview__dim {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(90deg, transparent 30%, rgba(0,0,0,0.85) 65%),
    linear-gradient(180deg, rgba(0,0,0,0.2) 0%, transparent 30%, transparent 70%, rgba(0,0,0,0.3) 100%);
}

.interview__layer {
  position: relative; z-index: 2;
  min-height: 100vh;
  display: flex; flex-direction: column; justify-content: center;
  padding: 60px 55px 60px 50%;
}

.interview__label {
  font-family: var(--display);
  font-size: 0.6rem; letter-spacing: 0.5em; color: var(--yellow);
  text-transform: uppercase;
}

.interview__name {
  font-family: var(--sans); font-size: clamp(3.5rem, 8vw, 6rem);
  font-weight: 900; line-height: 0.95; margin: 8px 0 0;
  text-shadow: 0 2px 12px rgba(0,0,0,0.4);
}
.interview__name-en {
  font-family: var(--display); font-size: 1.2rem;
  letter-spacing: 0.4em; color: var(--yellow);
  margin-bottom: 25px;
}

.interview__quote {
  font-family: var(--serif); font-size: clamp(1.1rem, 2vw, 1.4rem);
  font-style: italic; line-height: 2;
  color: var(--yellow);
  margin-bottom: 22px;
  padding-left: 18px;
  border-left: 2px solid rgba(255,214,0,0.4);
}

.interview__body p {
  font-family: var(--latin); font-size: 0.82rem;
  color: rgba(255,255,255,0.7); line-height: 2; margin-bottom: 10px;
}

.dropcap {
  float: left;
  font-family: var(--sans); font-size: 3rem; font-weight: 900;
  line-height: 0.85; margin: 4px 8px 0 0;
  color: var(--yellow);
}

.interview__stats {
  display: flex; gap: 30px; margin: 25px 0 15px;
  padding: 18px 0; border-top: 1px solid rgba(255,255,255,0.1);
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.interview__stats div { text-align: center; }
.interview__stats b {
  display: block; font-family: var(--display);
  font-size: 2rem; color: var(--yellow); line-height: 1;
}
.interview__stats small {
  font-family: var(--latin); font-size: 0.55rem;
  letter-spacing: 0.15em; color: rgba(255,255,255,0.35); text-transform: uppercase;
}

.interview__profile {
  font-family: var(--latin); font-size: 0.65rem;
  color: rgba(255,255,255,0.3); letter-spacing: 0.05em;
}

/* ================================================================
   PICK UP — Individual liver pages
   ================================================================ */
.pickup { min-height: 85vh; }

.pickup__dim {
  position: absolute; inset: 0; z-index: 1;
}
.pickup__dim--right {
  background: linear-gradient(90deg, transparent 40%, rgba(0,0,0,0.88) 70%);
}
.pickup__dim--left {
  background: linear-gradient(270deg, transparent 40%, rgba(0,0,0,0.88) 70%);
}

.pickup__text {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; justify-content: center;
  min-height: 85vh; max-width: 42%; padding: 60px 45px;
}
.pickup__text--right { margin-left: auto; }
.pickup__text--left  { margin-right: auto; }

.pickup__label {
  font-family: var(--display); font-size: 0.55rem;
  letter-spacing: 0.5em; color: var(--yellow); text-transform: uppercase;
}
.pickup__name {
  font-family: var(--sans); font-size: clamp(2.5rem, 5vw, 3.5rem);
  font-weight: 900; line-height: 1; margin: 8px 0 2px;
}
.pickup__name-en {
  font-family: var(--display); font-size: 0.9rem;
  letter-spacing: 0.35em; color: var(--yellow); margin-bottom: 12px;
}
.pickup__meta {
  font-family: var(--latin); font-size: 0.6rem;
  color: rgba(255,255,255,0.4); letter-spacing: 0.04em; margin-bottom: 18px;
}

.pickup__text blockquote {
  font-family: var(--serif); font-size: 0.95rem; font-style: italic;
  line-height: 1.9; color: var(--yellow);
  padding-left: 16px; border-left: 2px solid rgba(255,214,0,0.35);
  margin-bottom: 16px;
}

.pickup__desc {
  font-family: var(--latin); font-size: 0.78rem;
  color: rgba(255,255,255,0.55); line-height: 1.9;
}

/* ================================================================
   PICK UP DUO — Split spread
   ================================================================ */
.pickup-duo {
  display: grid; grid-template-columns: 1fr 1fr;
  min-height: 85vh; padding: 0;
}
.pickup-duo__left,
.pickup-duo__right {
  position: relative; overflow: hidden;
}
.pickup-duo__dim {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(0deg, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.15) 45%, transparent 100%);
}
.pickup-duo__text {
  position: relative; z-index: 2;
  min-height: 85vh;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 35px 30px;
}
.pickup-duo__text small {
  font-family: var(--display); font-size: 0.5rem;
  letter-spacing: 0.45em; color: var(--yellow); text-transform: uppercase;
}
.pickup-duo__text h3 {
  font-family: var(--sans); font-size: 2.2rem; font-weight: 900; margin: 6px 0 2px;
}
.pickup-duo__text h3 span {
  font-family: var(--display); font-size: 0.7rem;
  letter-spacing: 0.3em; color: var(--yellow); margin-left: 8px;
}
.pickup-duo__text > p {
  font-family: var(--latin); font-size: 0.58rem;
  color: rgba(255,255,255,0.4); margin-bottom: 12px;
}
.pickup-duo__text blockquote {
  font-family: var(--serif); font-size: 0.85rem; font-style: italic;
  color: rgba(255,214,0,0.8); line-height: 1.8;
  padding-left: 12px; border-left: 2px solid rgba(255,214,0,0.3);
}

/* ================================================================
   CONTENTS + GREETING (P2)
   ================================================================ */
.contents-page__dim {
  position: absolute; inset: 0; z-index: 1;
  background: rgba(0,0,0,0.82);
}
.contents-page__layout {
  position: relative; z-index: 2;
  min-height: 100vh;
  display: grid; grid-template-columns: 1fr 1fr;
}
.contents-page__toc {
  padding: 70px 50px;
  display: flex; flex-direction: column; justify-content: center;
  border-right: 1px solid rgba(255,214,0,0.1);
}
.contents-page__toc h2 {
  font-family: var(--display); font-size: 2.5rem;
  letter-spacing: 0.2em; color: var(--yellow); margin-bottom: 30px;
}
.contents-page__toc ul {
  list-style: none; display: flex; flex-direction: column; gap: 14px;
}
.contents-page__toc li {
  font-family: var(--latin); font-size: 0.82rem;
  color: rgba(255,255,255,0.6); display: flex; gap: 18px; align-items: baseline;
}
.contents-page__toc li span {
  font-family: var(--display); font-size: 1.1rem;
  color: var(--yellow); opacity: 0.5; min-width: 28px;
}

.contents-page__greeting {
  padding: 70px 45px;
  display: flex; flex-direction: column; justify-content: center;
}
.contents-page__greeting-photo {
  width: 90px; height: 90px; border-radius: 50%;
  background: linear-gradient(135deg, #3a3020, #5a4830);
  border: 2px solid rgba(255,214,0,0.2);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--display); font-size: 0.5rem;
  letter-spacing: 0.3em; color: rgba(255,255,255,0.08);
  margin-bottom: 20px;
}
.contents-page__greeting h3 {
  font-family: var(--sans); font-size: 1.2rem; font-weight: 700;
  color: #fff; margin-bottom: 14px;
}
.contents-page__greeting > p {
  font-family: var(--latin); font-size: 0.8rem;
  color: rgba(255,255,255,0.55); line-height: 2;
}
.contents-page__sign {
  margin-top: 20px;
  font-family: var(--sans); font-size: 0.9rem; font-weight: 500;
  color: rgba(255,255,255,0.7); line-height: 1.6;
}
.contents-page__sign small {
  font-family: var(--latin); font-size: 0.65rem;
  color: rgba(255,255,255,0.35); letter-spacing: 0.05em;
}

/* ================================================================
   LISTENER'S VOICE (P6)
   ================================================================ */
.listener__dim {
  position: absolute; inset: 0; z-index: 1;
  background: rgba(0,0,0,0.8);
}
.listener__layer {
  position: relative; z-index: 2;
  min-height: 100vh;
  display: flex; flex-direction: column; justify-content: center;
  padding: 70px 55px;
}
.listener__layer > small {
  font-family: var(--display); font-size: 0.55rem;
  letter-spacing: 0.5em; color: var(--yellow); text-transform: uppercase;
}
.listener__layer > h2 {
  font-family: var(--sans); font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 900; color: #fff; margin-bottom: 40px;
}

.listener__voices {
  display: flex; flex-direction: column; gap: 30px;
}
.listener__voice {
  display: flex; gap: 20px; align-items: flex-start;
  padding: 25px;
  background: rgba(255,255,255,0.04);
  border-left: 3px solid rgba(255,214,0,0.25);
}
.listener__icon {
  font-size: 1.8rem; flex: 0 0 auto; margin-top: 2px;
}
.listener__who {
  font-family: var(--sans); font-size: 0.78rem; font-weight: 500;
  color: rgba(255,255,255,0.6); margin-bottom: 8px;
}
.listener__who small {
  font-family: var(--latin); font-size: 0.6rem;
  color: rgba(255,255,255,0.3); letter-spacing: 0.05em;
}
.listener__voice blockquote {
  font-family: var(--serif); font-size: 0.9rem; font-style: italic;
  color: rgba(255,255,255,0.7); line-height: 1.9;
}

/* ================================================================
   NEXT ISSUE (P15)
   ================================================================ */
.next-issue__dim {
  position: absolute; inset: 0; z-index: 1;
  background: rgba(0,0,0,0.7);
}
.next-issue__layer {
  position: relative; z-index: 2;
  min-height: 100vh;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 80px 50px;
}
.next-issue__layer > small {
  font-family: var(--display); font-size: 0.55rem;
  letter-spacing: 0.5em; color: var(--yellow); text-transform: uppercase;
}
.next-issue__layer > h2 {
  font-family: var(--sans); font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 900; color: #fff; margin-bottom: 10px;
}
.next-issue__vol {
  font-family: var(--display); font-size: 1rem;
  letter-spacing: 0.3em; color: var(--yellow); opacity: 0.6;
  margin-bottom: 25px;
}
.next-issue__preview {
  font-family: var(--serif); font-size: 1.1rem; font-style: italic;
  color: rgba(255,255,255,0.6); line-height: 2;
  margin-bottom: 30px;
}
.next-issue__cta {
  font-family: var(--latin); font-size: 0.7rem;
  letter-spacing: 0.15em; color: rgba(255,255,255,0.3);
}

/* ================================================================
   FEATURE PORTRAIT (写真全面+名前だけ大きく)
   ================================================================ */
.feature-portrait__dim {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(0deg, rgba(0,0,0,0.6) 0%, transparent 35%, transparent 80%, rgba(0,0,0,0.25) 100%);
}
.feature-portrait__text {
  position: absolute; bottom: 50px; left: 50px; z-index: 2;
}
.feature-portrait__text small {
  font-family: var(--display); font-size: 0.55rem;
  letter-spacing: 0.5em; color: var(--yellow); text-transform: uppercase;
}
.feature-portrait__text h2 {
  font-family: var(--sans); font-size: clamp(5rem, 14vw, 10rem);
  font-weight: 900; line-height: 0.9;
  text-shadow: 0 4px 20px rgba(0,0,0,0.4);
}
.feature-portrait__text p {
  font-family: var(--display); font-size: clamp(1.2rem, 3vw, 2rem);
  letter-spacing: 0.5em; color: var(--yellow);
}

/* ================================================================
   INTERVIEW PAGE 2 (左テキスト)
   ================================================================ */
.interview-2__dim {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(270deg, transparent 35%, rgba(0,0,0,0.88) 65%);
}
.interview-2__layer {
  position: relative; z-index: 2;
  min-height: 100vh;
  display: flex; flex-direction: column; justify-content: center;
  padding: 60px 50px;
  max-width: 50%;
}
.interview-2__body p {
  font-family: var(--latin); font-size: 0.85rem;
  color: rgba(255,255,255,0.7); line-height: 2.1; margin-bottom: 14px;
}
.interview-2__stats {
  display: flex; gap: 25px; margin: 25px 0;
  padding: 20px 0;
  border-top: 1px solid rgba(255,255,255,0.1);
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.interview-2__stats div { text-align: center; }
.interview-2__stats b {
  display: block; font-family: var(--display);
  font-size: 1.8rem; color: var(--yellow); line-height: 1;
}
.interview-2__stats small {
  font-family: var(--latin); font-size: 0.5rem;
  letter-spacing: 0.12em; color: rgba(255,255,255,0.3); text-transform: uppercase;
}
.interview-2__closing {
  font-family: var(--serif); font-size: 1.1rem; font-style: italic;
  color: var(--yellow); line-height: 1.9; margin-top: 10px;
}

/* ================================================================
   TIPS (写真全面+暗くしてテキスト)
   ================================================================ */
.tips-spread__dim {
  position: absolute; inset: 0; z-index: 1;
  background: rgba(0,0,0,0.7);
}
.tips-spread__layer {
  position: relative; z-index: 2;
  min-height: 100vh;
  display: flex; flex-direction: column; justify-content: center;
  padding: 70px 60px;
}
.tips-spread__layer > small {
  font-family: var(--display); font-size: 0.55rem;
  letter-spacing: 0.5em; color: var(--yellow); text-transform: uppercase;
}
.tips-spread__layer > h2 {
  font-family: var(--sans); font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 900; color: #fff; line-height: 1.5; margin-bottom: 40px;
}
.tips-spread__layer > h2 em {
  font-family: var(--display); font-style: normal;
  font-size: 1.5em; color: var(--yellow); opacity: 0.4;
}

.tips-spread__grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 25px;
}
.tips-spread__item {
  padding: 25px;
  background: rgba(255,255,255,0.06);
  border-left: 3px solid rgba(255,214,0,0.3);
}
.tips-spread__item > span {
  font-family: var(--display); font-size: 2rem;
  color: var(--yellow); opacity: 0.3; display: block; margin-bottom: 8px;
}
.tips-spread__item h4 {
  font-family: var(--sans); font-size: 0.9rem; font-weight: 700;
  color: #fff; margin-bottom: 6px;
}
.tips-spread__item p {
  font-family: var(--latin); font-size: 0.78rem;
  color: rgba(255,255,255,0.5); line-height: 1.8;
}

/* ================================================================
   ABOUT (写真全面+センターテキスト)
   ================================================================ */
.about-spread__dim {
  position: absolute; inset: 0; z-index: 1;
  background: rgba(0,0,0,0.55);
}
.about-spread__layer {
  position: relative; z-index: 2;
  min-height: 100vh;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 80px 50px;
}
.about-spread__logo {
  font-family: var(--display); font-size: clamp(3.5rem, 8vw, 6rem);
  letter-spacing: 0.3em; text-indent: 0.3em; color: #fff;
  line-height: 1;
}
.about-spread__ent {
  font-family: var(--serif); font-style: italic;
  font-size: 0.85rem; letter-spacing: 0.35em;
  color: var(--yellow); opacity: 0.6; margin-bottom: 35px;
}
.about-spread__catch {
  font-family: var(--sans); font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 900; color: #fff; line-height: 1.5; margin-bottom: 20px;
  text-shadow: 0 2px 10px rgba(0,0,0,0.4);
}
.about-spread__body {
  font-family: var(--latin); font-size: 0.85rem;
  color: rgba(255,255,255,0.6); line-height: 2.2; max-width: 480px; margin-bottom: 30px;
}
.about-spread__url {
  font-family: var(--display); font-size: 1.5rem; letter-spacing: 0.15em;
  color: var(--yellow);
}

/* ================================================================
   STAFF (マネージャー紹介)
   ================================================================ */
.staff-spread__dim {
  position: absolute; inset: 0; z-index: 1;
  background: rgba(0,0,0,0.75);
}
.staff-spread__layer {
  position: relative; z-index: 2;
  min-height: 100vh;
  display: flex; flex-direction: column; justify-content: center;
  padding: 70px 55px;
}
.staff-spread__layer > small {
  font-family: var(--display); font-size: 0.55rem;
  letter-spacing: 0.5em; color: var(--yellow); text-transform: uppercase;
}
.staff-spread__layer > h2 {
  font-family: var(--sans); font-size: clamp(1.8rem, 3.5vw, 2.5rem);
  font-weight: 900; color: #fff; line-height: 1.5; margin-bottom: 45px;
}

.staff-spread__members {
  display: flex; flex-direction: column; gap: 35px;
}

.staff-member {
  display: flex; gap: 25px; align-items: center;
}

.staff-member__photo {
  width: 120px; height: 120px; flex: 0 0 120px;
  border-radius: 50%;
  background: linear-gradient(135deg, #3a3020, #5a4830);
  border: 2px solid rgba(255,214,0,0.2);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--display); font-size: 0.6rem;
  letter-spacing: 0.3em; color: rgba(255,255,255,0.08);
}

.staff-member__info h4 {
  font-family: var(--sans); font-size: 1.2rem; font-weight: 700;
  color: #fff; margin-bottom: 2px;
}

.staff-member__role {
  font-family: var(--display); font-size: 0.6rem;
  letter-spacing: 0.3em; color: var(--yellow); margin-bottom: 10px;
}

.staff-member__msg {
  font-family: var(--serif); font-size: 0.88rem; font-style: italic;
  color: rgba(255,255,255,0.55); line-height: 1.7;
}

@media (max-width: 768px) {
  .staff-spread__layer { padding: 50px 25px; }
  .staff-member { flex-direction: column; text-align: center; gap: 15px; }
  .staff-member__photo { width: 100px; height: 100px; flex: 0 0 100px; }
}

/* ================================================================
   SERVICES COMBINED (PK Link & Livra 1ページ)
   ================================================================ */
.svc-combined { min-height: 85vh; }
.svc-combined__layout {
  position: relative; z-index: 1;
  min-height: 85vh;
  display: grid; grid-template-columns: 1fr auto 1fr;
  align-items: center; gap: 40px;
  padding: 60px 50px;
  color: #fff;
}
.svc-combined__divider {
  width: 1px; height: 200px;
  background: linear-gradient(180deg, transparent, var(--yellow), transparent);
}
.svc-combined__item { text-align: center; }
.svc-combined__icon { font-size: 2.2rem; display: block; margin-bottom: 10px; }
.svc-combined__item h3 {
  font-family: var(--display); font-size: 2rem;
  letter-spacing: 0.25em; text-indent: 0.25em;
}
.svc-combined__tag {
  font-family: var(--serif); font-size: 0.8rem; font-style: italic;
  color: var(--yellow); margin-bottom: 14px;
}
.svc-combined__desc {
  font-family: var(--latin); font-size: 0.75rem;
  color: rgba(255,255,255,0.45); line-height: 1.8; margin-bottom: 14px;
}
.svc-combined__cta {
  font-family: var(--display); font-size: 1rem;
  letter-spacing: 0.1em; color: var(--yellow);
}

/* ================================================================
   BACK COVER
   ================================================================ */
.back-spread { color: var(--black); min-height: 45vh; }
.back-spread .photo-fill--yellow { z-index: 0; }
.back-spread__content {
  position: relative; z-index: 1;
  min-height: 45vh;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 50px; gap: 6px;
}
.back-spread__content h2 {
  font-family: var(--display); font-size: 3.5rem;
  letter-spacing: 0.4em; text-indent: 0.4em; color: var(--black);
}
.back-spread__mag {
  font-family: var(--serif); font-style: italic;
  font-size: 0.85rem; letter-spacing: 0.5em; color: rgba(0,0,0,0.3);
}
.back-spread__qr {
  width: 80px; height: 80px; margin: 14px 0;
  background: #fff; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--display); font-size: 0.6rem; color: #ccc; letter-spacing: 0.3em;
  box-shadow: 0 3px 10px rgba(0,0,0,0.06);
}
.back-spread__content > p {
  font-family: var(--latin); font-size: 0.7rem; color: rgba(0,0,0,0.35);
}
.back-spread__content > small {
  font-size: 0.55rem; color: rgba(0,0,0,0.2); margin-top: 6px;
}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 768px) {
  .cover__bottom { flex-direction: column; gap: 15px; align-items: flex-start; }
  .cover__right { text-align: left; max-width: 100%; }

  .interview__dim {
    background:
      linear-gradient(180deg, transparent 20%, rgba(0,0,0,0.85) 55%);
  }
  .interview__layer { padding: 40px 25px; padding-top: 45vh; }
  .interview__name { font-size: 3.5rem; }

  .pickup__dim--right,
  .pickup__dim--left {
    background: linear-gradient(0deg, rgba(0,0,0,0.88) 40%, transparent 80%);
  }
  .pickup__text { max-width: 100%; padding: 0 25px 40px; margin: 0; justify-content: flex-end; }

  .pickup-duo { grid-template-columns: 1fr; }

  .feature-portrait__text { left: 25px; bottom: 30px; }
  .feature-portrait__text h2 { font-size: 4rem; }

  .interview-2__dim { background: linear-gradient(0deg, rgba(0,0,0,0.88) 50%, transparent 100%); }
  .interview-2__layer { max-width: 100%; padding: 0 25px 40px; padding-top: 50vh; }

  .tips-spread__layer { padding: 50px 25px; }
  .tips-spread__grid { grid-template-columns: 1fr; }

  .about-spread__layer { padding: 50px 25px; }

  .svc-combined__layout { grid-template-columns: 1fr; }
  .svc-combined__divider { width: 150px; height: 1px; margin: 0 auto; }
  .contents-page__layout { grid-template-columns: 1fr; }
  .contents-page__toc { border-right: none; border-bottom: 1px solid rgba(255,214,0,0.1); padding: 50px 25px; }
  .contents-page__greeting { padding: 40px 25px; }
  .listener__layer { padding: 50px 25px; }
  .listener__voice { flex-direction: column; gap: 10px; }
  .next-issue__layer { padding: 50px 25px; }
}

/* ================================================================
   PRINT
   ================================================================ */
@media print {
  body { background: #fff; }
  .spread {
    width: 210mm; min-height: 297mm; max-width: none; margin: 0;
    page-break-after: always; page-break-inside: avoid;
    -webkit-print-color-adjust: exact; print-color-adjust: exact;
  }
}

/* ================================================================
   ANIMATION
   ================================================================ */
@media (prefers-reduced-motion: no-preference) {
  .cover__logo { animation: fadeIn 1s ease-out; }
  .cover__bottom { animation: slideUp 0.8s ease-out 0.3s both; }

  @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
  @keyframes slideUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
  }
}
