/* magazine.css — magazine.html 전용 셀렉터 (.mv-*, .mag-*).
   store.css에서 정밀 추출 (2026-05-24). cascade는 store.css 후행 로드 필수.
   @media 안 매거진 룰 + 그룹 셀렉터(매거진+비매거진 혼재)는 store.css에 잔존. */


.mv-cover-glyph { position: relative; }

.mv-cover-glyph .fx-1 { top: 4%;  left: 6%;  width: 10px; height: 10px; animation-delay: 0s;  }

.mv-cover-glyph .fx-2 { top: 14%; right: 8%; width: 8px;  height: 8px;  animation-delay: .9s; }

.mv-cover[data-id="C01"] .fx, .mv-cover[data-id="C02"] .fx,
.mv-cover[data-id="C03"] .fx, .mv-cover[data-id="C04"] .fx { background-color: #86C24A; }   /* A 생명과 온기 */

.mv-cover[data-id="C05"] .fx, .mv-cover[data-id="C06"] .fx,
.mv-cover[data-id="C07"] .fx, .mv-cover[data-id="C08"] .fx { background-color: #5BBBD7; }   /* B 파동과 자유 */

.mv-cover[data-id="C09"] .fx, .mv-cover[data-id="C10"] .fx,
.mv-cover[data-id="C11"] .fx, .mv-cover[data-id="C12"] .fx { background-color: #9747FF; }   /* C 관조와 통찰 */

.mv-cover[data-id="C13"] .fx, .mv-cover[data-id="C14"] .fx,
.mv-cover[data-id="C15"] .fx, .mv-cover[data-id="C16"] .fx { background-color: #C2A663; }   /* D 현실과 원칙 */

.mag-v2 {
  padding: clamp(60px, 7vw, 100px) var(--pad-x) clamp(40px, 5vw, 70px);
  position: relative;
}

.mag-v2-layout {
  display: grid;
  grid-template-columns: minmax(260px, 1.05fr) minmax(0, 2.5fr) minmax(180px, 0.8fr);
  gap: clamp(20px, 2.4vw, 36px);
  align-items: stretch;
  position: relative;
}

.mag-v2-slogan {
  position: relative;
  padding: 6px 4px 0;
  display: flex; flex-direction: column;
}

.mv-eyebrow {
  align-self: flex-start;
  font-family: var(--f-mono); font-size: 10.5px; font-weight: 700;
  letter-spacing: .14em; color: var(--c-ink);
  background: var(--c-ink); color: var(--c-yellow);
  padding: 5px 12px; border-radius: var(--r-pill);
  margin-bottom: 22px;
}

.mv-headline {
  font-family: var(--f-head); font-weight: var(--w-h);
  font-size: clamp(34px, 3.8vw, 52px); line-height: 1.02;
  letter-spacing: -.045em; margin: 0 0 18px;
  color: var(--c-ink);
  /* 한국어 단어 단위 줄바꿈 — "16유형 매거진" 같은 단어 중간 줄바꿈 방지 */
  word-break: keep-all;
  overflow-wrap: break-word;
}

.mv-headline .mv-dot { color: var(--c-accent); }

.mv-sub {
  font-size: 14.5px; line-height: 1.6;
  color: var(--c-ink); opacity: .82;
  margin: 0 0 22px;
}

.mv-ctas { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 26px; }

.mv-cta {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 16px; border-radius: var(--r-pill);
  border: 2.5px solid var(--c-ink);
  font-family: var(--f-head); font-weight: var(--w-h); font-size: 13px;
  letter-spacing: -.01em; color: var(--c-ink);
  box-shadow: var(--shadow-cta);
  transition: transform .12s ease;
}

.mv-cta:hover { transform: translate(-2px, -2px); box-shadow: 5px 5px 0 0 var(--c-ink); }

.mv-cta i { font-style: normal; font-size: 14px; }

.mv-cta-pink   { background: var(--c-accent);  color: #fff; }

.mv-cta-cyan   { background: var(--c-accent-2); color: #fff; }

.mv-cta-yellow { background: var(--c-yellow);  color: var(--c-ink); }

.mv-stamp-row {
  display: flex; align-items: center; gap: 18px; margin-top: auto;
  padding-top: 14px;
}

.mv-newdrop {
  position: relative;
  background: var(--c-yellow);
  border: 2.5px solid var(--c-ink);
  width: 88px; height: 88px; flex-shrink: 0;
  border-radius: 50%;
  display: grid; place-items: center; text-align: center; line-height: 1.05;
  font-family: var(--f-head); color: var(--c-ink);
  transform: rotate(-8deg);
  box-shadow: 4px 4px 0 0 var(--c-ink);
  animation: mv-bob 5.5s ease-in-out infinite;
}

.mv-newdrop small {
  font-family: var(--f-mono); font-size: 10px; font-weight: 700;
  letter-spacing: .12em; display: block;
}

.mv-newdrop strong {
  font-weight: var(--w-h); font-size: 14px; display: block; margin-top: 2px;
  letter-spacing: -.02em;
}

.mv-vol-ticket {
  position: relative;
  background: var(--c-accent);
  color: #fff;
  border: 2.5px solid var(--c-ink);
  border-radius: 22px;
  padding: 8px 18px 8px 14px;
  display: inline-flex; align-items: center; gap: 10px;
  box-shadow: 4px 4px 0 0 var(--c-ink);
  transform: rotate(-3deg);
  flex-shrink: 0;
}

.mv-vol-ticket::before,
.mv-vol-ticket::after {
  content: ''; position: absolute; top: 50%;
  width: 12px; height: 12px; background: var(--c-paper);
  border: 2.5px solid var(--c-ink); border-radius: 50%;
  transform: translateY(-50%);
}

.mv-vol-ticket::before { left: -8px; }

.mv-vol-ticket::after  { right: -8px; }

.mv-globe {
  font-style: normal; font-size: 14px;
  background: #fff; border: 2px solid var(--c-ink);
  width: 22px; height: 22px; border-radius: 50%;
  display: grid; place-items: center;
  filter: grayscale(.2);
}

.mv-vol-text { display: flex; flex-direction: column; line-height: 1; }

.mv-vol-text em {
  font-style: normal; font-family: var(--f-mono); font-size: 9px;
  letter-spacing: .12em; opacity: .92; font-weight: 600;
}

.mv-vol-text b {
  font-family: var(--f-head); font-weight: var(--w-h); font-size: 15px;
  letter-spacing: -.01em; margin-top: 2px;
}

.mv-vol-barcode {
  width: 26px; height: 16px;
  background: repeating-linear-gradient(
    90deg, #fff 0 1.5px, transparent 1.5px 3px,
    #fff 3px 4.5px, transparent 4.5px 7px
  );
  opacity: .9;
}

.mag-v2-wall {
  position: relative;
  /* 이미지 #3/#5 매거진 벽 진열대 효과 — 그리드 자체에 wrapper 박스 */
  background: var(--c-paper);
  border: 3px solid var(--c-ink);
  border-radius: 18px;
  padding: 18px;
  box-shadow: 8px 8px 0 0 var(--c-ink);
}

.mv-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  grid-auto-rows: 1fr;
  gap: 10px;
  aspect-ratio: 5 / 5.4;
}

.mv-cover {
  position: relative;
  background: var(--cv-bg, #FFEEF6);
  border: 2px solid var(--c-ink);
  border-radius: 8px;
  padding: 8px 8px 8px;
  display: flex; flex-direction: column;
  cursor: pointer;
  overflow: hidden;
  transition: transform .15s cubic-bezier(.34,1.6,.64,1), box-shadow .15s, z-index 0s;
  min-width: 0;
  /* 기본 그림자: 진열대 위 부유 (모바일 reflow 시 자석 그룹핑 시각화) */
  box-shadow: 2px 2px 0 0 var(--c-ink);
}

.mv-cover:hover {
  transform: translateY(-4px) rotate(-1deg) scale(1.04);
  z-index: 5;
  box-shadow: 3px 6px 0 0 var(--c-ink);
}

.mv-cover:focus-visible { outline: 3px solid var(--c-yellow); outline-offset: 2px; }

.mv-cover-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  font-family: var(--f-mono); font-size: 7.5px; font-weight: 700;
  letter-spacing: .08em; color: var(--c-ink);
  opacity: .8;
}

.mv-cover-head .mv-pen { opacity: .55; font-size: 8px; }

.mv-cover-title {
  margin-top: 2px;
  font-family: var(--f-head); font-weight: var(--w-h);
  font-size: 11.5px; letter-spacing: -.02em; line-height: 1.1;
  color: var(--c-ink);
}

.mv-cover-title small {
  font-family: var(--f-mono); font-size: 8.5px; font-weight: 700;
  letter-spacing: .04em;
  display: block; margin-bottom: 1px; opacity: .65;
}

.mv-cover-glyph {
  flex: 1 1 auto;
  display: flex; align-items: center; justify-content: center;
  margin: 6px 0 4px;
  width: 100%;
  aspect-ratio: 1 / 1;
  min-height: 96px;
  overflow: visible;
  background: transparent;     /* cover의 family 색이 그대로 노출 */
  border: 0;
}

.mv-cover-glyph img {
  width: 100%; height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 3px 5px rgba(21,19,26,.16));
  transition: transform .22s cubic-bezier(.34,1.4,.64,1), filter .22s;
}

.mv-cover:hover .mv-cover-glyph img {
  transform: rotate(-2deg) scale(1.06) translateY(-2px);
  filter: drop-shadow(0 8px 12px rgba(21,19,26,.26));
}

.mv-cover-bar {
  margin-top: auto;
  height: 4px;
  border-radius: 2px;
  background: rgba(21,19,26,.85);
  opacity: .35;
}

.mv-hero {
  position: relative;
  border: 2.5px solid var(--c-ink);
  border-radius: 14px;
  background:
    linear-gradient(135deg,
      #9747FF 0%,
      #FF4D8F 38%,
      #3FBFE0 72%,
      #FFD600 100%);
  color: #fff;
  display: flex; flex-direction: column;
  padding: 16px 18px;
  box-shadow: 6px 6px 0 0 var(--c-ink);
  overflow: hidden;
  z-index: 2;
}

.mv-hero-top {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 4px;
}

.mv-hero-cs {
  display: inline-flex; align-items: center;
  background: rgba(21,19,26,.95); color: #fff;
  padding: 6px 12px; border-radius: var(--r-pill);
  font-family: var(--f-mono); font-size: 10px; font-weight: 700;
  letter-spacing: .12em;
}

.mv-hero-issue {
  font-family: var(--f-head); font-weight: var(--w-h);
  text-align: right; line-height: 1; color: #fff;
  text-shadow: 0 1px 0 rgba(21,19,26,.25);
}

.mv-hero-issue small {
  display: block; font-family: var(--f-mono); font-size: 9.5px;
  font-weight: 700; letter-spacing: .12em; opacity: .9;
}

.mv-hero-issue strong { font-size: clamp(20px, 1.8vw, 28px); }

.mv-hero-title {
  font-family: var(--f-head); font-weight: var(--w-h);
  font-size: clamp(48px, 5.8vw, 92px); line-height: 0.92;
  letter-spacing: -.04em;
  text-shadow: 0 2px 0 rgba(21,19,26,.18);
  margin: 6px 0 4px;
}

.mv-hero-pill {
  align-self: center;
  background: rgba(21,19,26,.95); color: #fff;
  padding: 6px 14px; border-radius: var(--r-pill);
  font-family: var(--f-head); font-weight: var(--w-h); font-size: 11px;
  letter-spacing: -.01em;
  margin: 2px 0 8px;
}

.mv-hero-door {
  flex: 1;
  display: grid; place-items: center;
  margin: 4px 0;
  min-height: 0;
}

.mv-hero-door svg { width: 78%; height: 100%; max-height: 100%; }

.mv-hero-bottom {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 8px;
  padding-top: 6px;
  border-top: 1.5px dashed rgba(255,255,255,.55);
}

.mv-hero-club {
  font-family: var(--f-head); font-weight: var(--w-h);
  font-size: 12px; line-height: 1.05; letter-spacing: -.01em;
}

.mv-hero-club small {
  display: block; font-family: var(--f-mono); font-size: 8px; font-weight: 700;
  letter-spacing: .12em; opacity: .85; margin-top: 1px;
}

.mv-hero-seal {
  background: rgba(21,19,26,.92); color: #fff;
  border-radius: 50%;
  width: 46px; height: 46px;
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 7px;
  text-align: center; line-height: 1.15;
  letter-spacing: .06em;
  flex-shrink: 0;
}

.mv-hero-seal b { font-family: var(--f-head); font-size: 8px; letter-spacing: 0; }

.mv-magwall-stamp {
  position: absolute;
  left: 4px; bottom: -28px;
  background: var(--c-ink);
  color: #fff;
  font-family: var(--f-head); font-weight: var(--w-h); font-size: 11px;
  letter-spacing: .04em; line-height: 1.05;
  text-align: center;
  width: 90px; height: 90px;
  display: grid; place-items: center;
  /* 12-spike star */
  clip-path: polygon(
    50% 0%, 58% 18%, 78% 12%, 70% 32%,
    92% 30%, 78% 50%, 100% 60%, 78% 66%,
    88% 84%, 68% 78%, 60% 96%, 50% 80%,
    40% 96%, 32% 78%, 12% 84%, 22% 66%,
    0% 60%, 22% 50%, 8% 30%, 30% 32%,
    22% 12%, 42% 18%
  );
  transform: rotate(-12deg);
  animation: mv-bob 6s ease-in-out infinite;
  z-index: 3;
}

.mag-v2-side {
  display: flex; flex-direction: column;
  gap: 18px;
  padding-top: 4px;
  position: relative;
}

.mv-side-chips { display: flex; flex-direction: column; gap: 12px; }

.mv-pill {
  position: relative;
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 12px 22px;
  border: 2.5px solid var(--c-ink);
  border-radius: 26px;
  font-family: var(--f-head); font-weight: var(--w-h); font-size: 15px;
  letter-spacing: -.01em;
  box-shadow: 4px 4px 0 0 var(--c-ink);
  transform: rotate(-4deg);
  transition: transform .15s ease, box-shadow .15s ease;
  min-width: 110px; justify-content: center;
}

.mv-pill:nth-child(2) { transform: rotate(3deg); }

.mv-pill:nth-child(3) { transform: rotate(-2deg); }

.mv-pill:hover {
  transform: rotate(0) translate(-2px, -2px);
  box-shadow: 6px 6px 0 0 var(--c-ink);
}

.mv-pill-dot {
  width: 12px; height: 12px; border-radius: 50%;
  background: #fff; border: 2px solid var(--c-ink);
  display: inline-block;
}

.mv-pill-pink   { background: var(--c-accent);   color: #fff; }

.mv-pill-yellow { background: var(--c-yellow);   color: var(--c-ink); }

.mv-pill-cyan   { background: var(--c-accent-2); color: #fff; }

.mv-quote {
  position: relative;
  background: #fff;
  border: 2.5px solid var(--c-ink);
  border-radius: 14px;
  padding: 14px 16px 14px 16px;
  margin: 0;
  box-shadow: 4px 4px 0 0 var(--c-ink);
  color: var(--c-ink);
}

.mv-quote::after {
  /* 말풍선 꼬리 */
  content: ''; position: absolute; left: -10px; top: 22px;
  width: 16px; height: 14px;
  background: #fff;
  border-left: 2.5px solid var(--c-ink);
  border-bottom: 2.5px solid var(--c-ink);
  transform: skewY(20deg);
}

.mv-quote p {
  margin: 0; font-size: 12.5px; line-height: 1.5;
  font-weight: 600;
}

.mv-quote p b { color: var(--c-accent); font-weight: var(--w-h); }

.mv-q-mark {
  font-family: 'DM Mono', serif; font-weight: 700;
  font-size: 34px; line-height: 0.6;
  color: var(--c-accent);
  display: inline-block; margin-bottom: -8px;
}

.mv-q-close { float: right; transform: translateY(8px); }

.mv-newissue {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--c-accent-2);
  color: var(--c-ink);
  border: 2.5px solid var(--c-ink);
  border-radius: 8px;
  padding: 10px 12px 10px 16px;
  box-shadow: 4px 4px 0 0 var(--c-ink);
  margin-top: 4px;
  transform: rotate(-3deg);
  transition: transform .15s ease, box-shadow .15s ease;
}

.mv-newissue:hover {
  transform: rotate(0) translate(-2px, -2px);
  box-shadow: 6px 6px 0 0 var(--c-ink);
}

.mv-ni-text { display: flex; flex-direction: column; line-height: 1.15; }

.mv-ni-text strong {
  font-family: var(--f-head); font-weight: var(--w-h); font-size: 12.5px;
  letter-spacing: -.01em;
}

.mv-ni-text small {
  font-family: var(--f-body); font-size: 10.5px;
  font-weight: 600; opacity: .92; margin-top: 1px;
}

.mv-ni-arrow {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--c-yellow); border: 2px solid var(--c-ink);
  display: grid; place-items: center;
  font-family: var(--f-head); font-weight: var(--w-h); font-size: 14px;
  flex-shrink: 0;
}

.mv-catstrip {
  margin-top: 36px;
  background: var(--c-ink); color: #fff;
  border: 2.5px solid var(--c-ink);
  border-radius: var(--r-pill);
  padding: 12px 22px;
  display: flex; gap: 22px; flex-wrap: wrap; justify-content: center;
  font-family: var(--f-mono); font-size: 12.5px; font-weight: 700;
  letter-spacing: .12em;
}

.mv-catstrip span { display: inline-flex; align-items: center; gap: 8px; }

.mv-catstrip .dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; }

.mag-modal__grid {
  display: grid;
  grid-template-columns: minmax(280px, 0.88fr) minmax(0, 1.12fr);
  gap: clamp(20px, 3vw, 34px);
  align-items: start;
}

.mag-modal__cover {
  display: grid;
  gap: 14px;
  padding: clamp(18px, 2vw, 24px);
  border: 3px solid var(--c-ink);
  border-radius: 26px;
  box-shadow: 8px 8px 0 0 var(--c-ink);
  background:
    linear-gradient(140deg, var(--mag-primary, #FF4D8F), var(--mag-secondary, #FFD24D));
  color: #fff;
}

.mag-modal__cover-top,
.mag-modal__cover-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.mag-modal__cover-top span,
.mag-modal__cover-top b,
.mag-modal__cover-body small,
.mag-modal__readers small,
.mag-modal__editor small,
.mag-modal__section small,
.mag-modal__eyebrow {
  font-family: var(--f-mono);
  letter-spacing: .1em;
}

.mag-modal__cover-top span,
.mag-modal__cover-top b {
  padding: 6px 10px;
  border-radius: 999px;
  border: 2px solid var(--c-ink);
  background: rgba(21,19,26,.94);
  color: #fff;
  font-size: 10.5px;
  font-weight: 800;
}

.mag-modal__cover-body {
  display: grid;
  gap: 10px;
}

.mag-modal__cover-body small {
  justify-self: start;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.2);
  border: 2px solid rgba(21,19,26,.88);
  font-size: 10px;
  font-weight: 800;
}

.mag-modal__cover-body strong {
  font-family: var(--f-head);
  font-size: clamp(34px, 4.2vw, 52px);
  line-height: .94;
  letter-spacing: -.04em;
  text-shadow: 0 2px 0 rgba(21,19,26,.18);
}

.mag-modal__cover-body p {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  opacity: .92;
}

.mag-modal__art {
  margin: 0;
  min-height: 260px;
  padding: 18px;
  border-radius: 22px;
  border: 2.5px solid var(--c-ink);
  background: rgba(255,255,255,.18);
  display: grid;
  place-items: center;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.16);
}

.mag-modal__img {
  width: min(88%, 320px);
  max-width: 100%;
  object-fit: contain;
  filter: drop-shadow(6px 12px 0 rgba(21,19,26,.18));
}

.mag-modal__cover-footer span {
  padding: 6px 10px;
  border-radius: 999px;
  border: 2px solid var(--c-ink);
  background: rgba(255,255,255,.95);
  color: var(--c-ink);
  font-size: 11px;
  font-weight: 800;
}

.mag-modal__body {
  min-width: 0;
  display: grid;
  gap: 14px;
}

.mag-modal__eyebrow {
  justify-self: start;
  padding: 6px 12px;
  border-radius: 999px;
  background: var(--mag-primary, #FF4D8F);
  color: #fff;
  border: 2px solid var(--c-ink);
  box-shadow: 3px 3px 0 0 var(--c-ink);
  font-size: 10.5px;
  font-weight: 800;
}

.mag-modal__title {
  margin: -4px 0 0;
  font-family: var(--f-head);
  font-size: 18px;
  line-height: 1.3;
}

.mag-modal__deck,
.mag-modal__quote,
.mag-modal__editor p,
.mag-modal__section p,
.mag-modal__readers li {
  font-size: 14px;
  line-height: 1.7;
}

.mag-modal__deck {
  margin: 0;
  color: var(--c-ink);
  opacity: .84;
}

.mag-modal__quote {
  margin: 0;
  padding: 16px 18px;
  border: 2px solid var(--c-ink);
  border-radius: 18px;
  background: var(--mag-soft, #F7F0FF);
  box-shadow: 3px 3px 0 0 var(--c-ink);
  font-family: var(--f-head);
  font-style: italic;
}

.mag-modal__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.mag-modal__chips span {
  padding: 6px 12px;
  border-radius: 999px;
  border: 2px solid var(--c-ink);
  background: #fff;
  font-size: 12px;
  font-weight: 800;
}

.mag-modal__editor,
.mag-modal__readers {
  display: grid;
  gap: 8px;
  padding: 16px 18px;
  border: 2px solid var(--c-ink);
  border-radius: 20px;
  background: rgba(255,255,255,.92);
}

.mag-modal__editor small,
.mag-modal__readers small,
.mag-modal__section small {
  font-size: 10.5px;
  font-weight: 800;
  color: var(--c-mute);
}

.mag-modal__editor p {
  margin: 0;
}

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

.mag-modal__section {
  display: grid;
  gap: 8px;
  padding: 14px;
  border: 2px solid var(--c-ink);
  border-radius: 18px;
  box-shadow: 3px 3px 0 0 var(--c-ink);
}

.mag-modal__section--1 { background: #fff0d9; }

.mag-modal__section--2 { background: #ebf8ff; }

.mag-modal__section--3 { background: #f6ebff; }

.mag-modal__section strong,
.mag-modal__readers strong {
  font-size: 15px;
  line-height: 1.4;
}

.mag-modal__section p {
  margin: 0;
}

.mag-modal__readers ul {
  margin: 0;
  padding-left: 18px;
}

.mag-modal__actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.mag-modal__ghost {
  appearance: none;
  border: 2.5px solid var(--c-ink);
  border-radius: 999px;
  padding: 12px 18px;
  background: #fff;
  color: var(--c-ink);
  font-size: 14px;
  font-weight: 800;
}


/* ─── 매거진 반응형 @media 룰 — store.css L889-1564 영역에서 정밀 이전 (2026-05-24). */

/* === 영역 A === L889-925 magazine wall @media + @keyframes mv-bob */
/* ─── MAGAZINE WALL v2 (샘플3.png 벤치마크: 좌:슬로건 / 중:5×4 커버그리드 / 우:사이드칩+인용+리본 / 하단:카테고리 도트 띠) ─── */
@media (max-width: 1180px){
  .mag-v2-layout { grid-template-columns: 1fr; }
}

/* ── 좌측 슬로건 ── */

/* 좌하단 노란 NEW DROP 원 + Vol.16 티켓 */
@keyframes mv-bob {
  0%,100% { transform: rotate(-8deg) translateY(0); }
  50%     { transform: rotate(-6deg) translateY(-2px); }
}

/* ── 중앙 매거진 그리드 ── */
@media (max-width: 1180px){
  .mv-grid { aspect-ratio: 5 / 6; }
}
@media (max-width: 720px){
  /* 2-col 자석 reflow — 3-col은 카드가 너무 좁아 텍스트 세로 압축 발생 */
  .mv-grid { grid-template-columns: repeat(2, 1fr); aspect-ratio: auto; gap: 8px; }
  /* hero(16 TYPES) full-row 최상단 강제 — 명시 cols 유지 시 implicit grid 어긋남 */
  .mv-hero {
    grid-column: 1 / -1;
    grid-row: auto;
    aspect-ratio: 3 / 2;
    order: -1;
    min-height: 200px;
  }
  .mv-magwall-stamp { left: auto; right: 8px; bottom: -10px; }
  /* 카드 글자 압축 방지 — 한국어 단어 단위 줄바꿈 */
  .mv-cover { word-break: keep-all; overflow-wrap: break-word; }
}
@media (max-width: 420px){
  /* 1-col fallback — 매우 좁은 화면 */
  .mv-grid { grid-template-columns: 1fr; gap: 10px; }
  .mv-hero { aspect-ratio: 4 / 2.6; min-height: 180px; }
}

/* === 영역 B === L932-937 @media min-width:721px .mv-hero */
@media (min-width: 721px) {
  .mv-hero {
    grid-column: 3 / span 2;
    grid-row: 2 / span 2;
  }
}

/* === 영역 D === L1331-1346 매거진 사이드 @media (mag-v2-side, mv-side-chips, mv-quote, mv-newissue) */
/* ── 매거진 sidebar (mv-side-chips) — 1180px 이하 1열 stacking 시 가로 row + 중앙 정렬로 부유 방지 ── */
@media (max-width: 1180px){
  .mag-v2-side {
    display: flex; flex-direction: column;
    align-items: center; gap: 18px;
    padding-top: 6px;
  }
  .mv-side-chips {
    flex-direction: row !important;
    flex-wrap: wrap; justify-content: center;
    gap: 10px !important;
  }
  .mv-quote { max-width: 520px; }
  .mv-newissue { max-width: 520px; }
}


/* === 영역 E === L1544-1564 매거진 모달 @media (mag-modal__grid/sections/art, modal--magazine) */
@media (max-width: 860px) {
  .mag-modal__grid {
    grid-template-columns: 1fr;
  }
  .mag-modal__sections {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 560px) {
  .modal--magazine {
    padding: 18px;
    border-radius: 24px;
  }
  .mag-modal__art {
    min-height: 220px;
  }
}

/* === 영역 C === L1128-1138 1280px 미디어쿼리 매거진 라인 (혼재 영역에서 분리) */
@media (max-width: 1280px){
  .mag-decor--cover,
  .mag-decor--miniset,
  .mv-side-decor--quote,
  .mv-side-decor--price { display: none; }
}
