/* PWA + 모바일/태블릿 최적화 (iPad mini 우선) */

/* ============================================================
   1. 전역: 터치 친화 + iOS standalone 조정
   ============================================================ */
:root {
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left: env(safe-area-inset-left, 0px);
  --safe-right: env(safe-area-inset-right, 0px);
}

html {
  -webkit-text-size-adjust: 100%;
  /* iOS bounce 방지는 PWA standalone에서만 적용 (아래 미디어 쿼리) */
}

body {
  -webkit-tap-highlight-color: transparent;
  /* 더블탭 줌 비활성 (모든 인터랙티브 요소) */
  touch-action: manipulation;
}

/* 모든 클릭 가능한 요소 - 터치 타겟 최소 44x44 (Apple HIG) */
a, button, .btn, .nav-link, .navbar-menu a, .album-link, .video-card a,
input[type="button"], input[type="submit"], select {
  min-height: 44px;
  touch-action: manipulation;
}

/* 아이콘만 있는 버튼은 최소 44x44 정사각형 */
.icon-btn, button.icon-only {
  min-width: 44px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* 폼 입력 - iOS 줌 방지 (16px 이상이면 입력 시 줌 안 됨) */
input[type="text"], input[type="search"], input[type="email"],
input[type="url"], input[type="password"], textarea, select {
  font-size: 16px;
}

/* ============================================================
   2. 태블릿 (iPad mini 등 600-1024px) - 앨범 그리드 최적화
   ============================================================ */
@media (max-width: 1024px) {
  .container {
    padding-left: max(1rem, var(--safe-left));
    padding-right: max(1rem, var(--safe-right));
  }

  .album-grid {
    /* iPad mini 세로(744px)에 3~4열, 가로(1133px)에 5~6열 */
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 16px;
    padding: 16px 0;
  }

  .album-card:hover {
    /* 터치 디바이스에선 hover 트랜스폼 줄임 (실제 hover 없음) */
    transform: none;
  }

  .navbar {
    padding: 0.75rem 0;
    padding-top: max(0.75rem, var(--safe-top));
  }

  .navbar .container {
    flex-wrap: wrap;
    gap: 0.5rem;
  }

  .navbar-menu {
    gap: 0.5rem;
    flex-wrap: wrap;
  }

  /* 페이지 헤더 */
  .page-header {
    flex-wrap: wrap;
    gap: 0.5rem;
  }
}

/* ============================================================
   3. 폰 (≤600px) - 앨범 2열, 컴팩트 네비
   ============================================================ */
@media (max-width: 600px) {
  .album-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }

  .navbar-brand {
    font-size: 1.2rem;
  }

  .navbar-menu a {
    padding: 0.5rem 0.75rem;
    font-size: 0.95rem;
  }

  .container {
    padding: 0.75rem;
  }
}

/* ============================================================
   4. 영상 플레이어 - 풀스크린 최적화
   ============================================================ */
.video-player-wrap, .player-container, iframe[src*="youtube"] {
  max-width: 100%;
}

@media (max-width: 1024px) {
  /* 플레이어 페이지에서 컨텐츠 영역을 화면 가득 */
  .player-page .container,
  .album-player-page .container {
    padding: 0;
    max-width: 100%;
  }

  /* YouTube 임베드 - 16:9 유지하면서 가로 가득 */
  iframe[src*="youtube"], iframe[src*="youtu.be"] {
    width: 100%;
    aspect-ratio: 16/9;
    height: auto;
  }
}

/* ============================================================
   5. iOS PWA standalone 모드 (홈화면에서 실행)
   ============================================================ */
@media (display-mode: standalone) {
  body {
    /* iOS 위/아래 안전 영역 자동 패딩 */
    padding-top: var(--safe-top);
    padding-bottom: var(--safe-bottom);
    overscroll-behavior-y: none; /* 당겨서 새로고침 차단 */
  }

  /* sticky 네비는 safe-area-top 안에 안 가리도록 */
  .navbar {
    top: 0;
    padding-top: max(0.75rem, var(--safe-top));
  }

  /* 풀스크린 느낌: 외부 링크 표시 줄임 */
  .external-only {
    display: none;
  }
}

/* ============================================================
   6. 다크 모드 (이미 base.html에서 data-theme 처리하므로 보강만)
   ============================================================ */
@media (prefers-color-scheme: dark) {
  :root {
    color-scheme: dark light;
  }
}

/* ============================================================
   7. 접근성 - reduce-motion
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}
