/* ==========================================================================
File: public/styles/app.css
Purpose:
  MC The Children 고유의 시각 감성(블랙/골드 톤, 카드 타이포, 턴테이블 버튼)을 정의한다.
Primary Responsibility:
  구조 정책을 침범하지 않고 카드 콘텐츠 스타일과 컨트롤 UI 톤을 담당한다.
Design Intent:
  - 레이아웃 이식 후에도 기존 프로젝트의 정서(무드, 컬러, 타이포 밀도)를 유지한다.
  - 카드 텍스트 가독성과 뒷면 서사 몰입감을 동시에 확보한다.
  - 컨트롤 버튼은 기존 PUSH 행동의 아이콘 역할을 계속한다.
Non-Goals:
  - 카드 그리드 열 수 결정, 플립 상태 토글 로직은 담당하지 않는다.
Dependencies:
  - core.css 색상/간격/타입 토큰
  - components-cards.css 구조 클래스
Constraints & Assumptions:
  - `.front`, `.back`, `.control-center`, `.turntable-btn` 클래스가 존재해야 한다.
Extension Points:
  - 카드별 accent 오버라이드, 다크/라이트 테마 확장, 버튼 변형 스타일 추가.
========================================================================== */

.front{
  display: grid;
  grid-template-rows: auto auto auto 1fr auto;
  row-gap: var(--gap-1);
  background: var(--color-front-bg);
  color: var(--color-front-fg);
}

.back{
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  align-content: stretch;
  row-gap: var(--gap-1);
  background: var(--color-back-bg);
  color: var(--color-back-fg);
  border: 2px solid var(--color-accent);
}

.bean-label{
  margin: 0;
  font-size: var(--small);
  color: var(--color-front-meta);
  font-weight: 700;
}

.song-title{
  margin: 0;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--color-accent);
  font-size: var(--h2);
}

.point{
  margin: 0;
  font-weight: 700;
  line-height: 1.4;
}

.desc{
  margin: 0;
  color: var(--color-front-muted);
  line-height: 1.6;
  overflow: visible;
  padding-right: 2px;
}

/* Preserve author-entered line breaks in all card copy without requiring <br>. */
.card-display-area .side :where(h2, h3, p, span, strong){
  white-space: pre-line !important;
}

/* Back side safety rule: preserve line breaks at container level as well. */
.card-display-area .back .scroll-v{
  display: grid;
  align-content: start;
  gap: clamp(6px, 0.8vw, 10px);
  white-space: pre-wrap !important;
  overflow: hidden !important;
}

.card-display-area .back .scroll-v :where(h2, h3, p, span, strong){
  white-space: inherit !important;
}

.back h3{
  margin: 0;
  color: var(--color-accent);
  font-size: var(--h3);
}

.lyrics{
  margin: 0;
  text-align: center;
  color: var(--color-accent);
  font-style: italic;
}

.narrative,
.note{
  margin: 0;
  line-height: 1.6;
  opacity: 0.95;
}

.flip-btn{
  justify-self: start;
  margin-top: var(--gap-1);
  padding: 0.65rem 0.9rem;
  border-radius: 999px;
  border: 1px solid rgba(127, 127, 127, 0.35);
  background: transparent;
  color: currentColor;
  font: inherit;
  cursor: pointer;
}

.back .flip-btn{
  margin-top: var(--gap-2);
  align-self: end;
  justify-self: start;
  border-color: rgba(212, 163, 115, 0.7);
  color: var(--color-accent);
}

.control-center{
  position: fixed;
  right: 40px;
  bottom: 40px;
  z-index: 1000;
}

.turntable-btn{
  width: 110px;
  height: 110px;
  border-radius: 50%;
  border: 4px solid var(--color-accent);
  background: #222;
  color: var(--color-accent);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform 0.2s ease, filter 0.2s ease;
}

.turntable-btn:hover{
  transform: translateY(-2px);
  filter: brightness(1.06);
}

.disc{
  width: 75px;
  height: 75px;
  border-radius: 50%;
  background: repeating-radial-gradient(circle, #000, #000 2px, #333 4px);
  animation: spin 4s linear infinite;
}

.btn-txt{
  margin-top: 5px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
}

@keyframes spin{
  to{
    transform: rotate(360deg);
  }
}

@media (max-width: 768px){
  .top-header h1{
    margin-bottom: var(--gap-2);
    letter-spacing: 0.05em;
  }

  .control-center{
    right: 50%;
    bottom: 30px;
    transform: translateX(50%);
  }
}

@media (prefers-reduced-motion: reduce){
  .disc{
    animation: none;
  }

  .turntable-btn{
    transition: none;
  }
}
