/* ============================================================
   MYPAGE.CSS — 마이페이지
   ============================================================ */

/* ── Hero ── */
.mypage-hero {
  background: linear-gradient(135deg, var(--color-primary) 0%, #3d4f6b 100%);
  color: #fff;
  padding: var(--space-8) 0;
}
.mypage-hero .breadcrumb {
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: var(--space-4);
}
.mypage-hero .breadcrumb a {
  color: rgba(255, 255, 255, 0.7);
}
.mypage-hero .breadcrumb-sep {
  color: rgba(255, 255, 255, 0.4);
}

/* 회원 요약 */
.mypage-user-summary {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  flex-wrap: wrap;
}
.mypage-avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.15);
  border: 2px solid rgba(255, 255, 255, 0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.9);
  flex-shrink: 0;
}
.mypage-user-name {
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: #fff;
}
.mypage-user-email {
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.7);
  margin-top: 2px;
}
.mypage-stats {
  display: flex;
  gap: var(--space-6);
  margin-left: auto;
  flex-shrink: 0;
}
.mypage-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.mypage-stat-val {
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: #fff;
}
.mypage-stat-label {
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.7);
}

/* ── 메인 레이아웃 ── */
.mypage-main {
  padding: var(--space-10) 0 var(--space-20);
}
.mypage-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--space-8);
  align-items: flex-start;
}

/* ── 사이드 메뉴 ── */
.mypage-sidebar {
  position: sticky;
  top: calc(var(--header-height) + var(--space-6));
}
.mypage-menu {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.mypage-menu-group {
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--color-border);
}
.mypage-menu-group:last-child {
  border-bottom: none;
}
.mypage-menu-group-title {
  padding: var(--space-2) var(--space-5);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  color: var(--color-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.mypage-menu-item {
  display: block;
  width: 100%;
  text-align: left;
  padding: var(--space-3) var(--space-5);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text);
  background: transparent;
  border: none;
  border-left: 3px solid transparent;
  cursor: pointer;
  transition:
    color var(--transition-fast),
    background var(--transition-fast),
    border-color var(--transition-fast);
}
.mypage-menu-item:hover {
  color: var(--color-primary);
  background: var(--color-bg-alt);
}
.mypage-menu-item.is-active {
  color: var(--color-primary);
  background: var(--color-selected-bg);
  border-left-color: var(--color-primary);
  font-weight: var(--font-semibold);
}
.mypage-menu-item--danger {
  color: var(--color-error);
}
.mypage-menu-item--danger:hover {
  color: var(--color-error);
  background: #ffeeee;
}
.mypage-menu-item--danger.is-active {
  color: var(--color-error);
  background: #ffeeee;
  border-left-color: var(--color-error);
}

/* ── 콘텐츠 패널 ── */
.mypage-content {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  min-height: 400px;
  min-width: 0;
  overflow-x: hidden;
}
.mypage-panel {
  padding: var(--space-8);
}
.mypage-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--color-border);
}
.mypage-panel-header h2 {
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--color-text);
}

/* ── 주문 내역 ── */
.order-filter-row {
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}
.order-period-btn {
  padding: 0.35rem 1rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  background: transparent;
  color: var(--color-muted);
  cursor: pointer;
  transition: all var(--transition-fast);
}
.order-period-btn.is-active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}

.order-table-wrap {
  overflow-x: auto;
}
.order-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}
.order-table th {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  color: var(--color-muted);
  background: var(--color-bg-alt);
  border-bottom: 1px solid var(--color-border);
  white-space: nowrap;
}
.order-table td {
  padding: var(--space-4);
  border-bottom: 1px solid var(--color-border);
  color: var(--color-text);
  vertical-align: middle;
}
.order-table tr:last-child td {
  border-bottom: none;
}
.order-id {
  font-size: var(--text-xs);
  color: var(--color-muted);
  white-space: nowrap;
}
.order-product {
  max-width: 200px;
}
.order-amount {
  font-weight: var(--font-semibold);
  white-space: nowrap;
}
.order-status-badge {
  display: inline-block;
  padding: 0.2rem 0.65rem;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  white-space: nowrap;
}
.order-status-badge[data-status="주문접수"]  { background: rgba(127,140,154,.12); color: #7F8C9A; }
.order-status-badge[data-status="파일검수중"] { background: rgba(245,166,35,.12);  color: #F5A623; }
.order-status-badge[data-status="제작중"]    { background: rgba(173,216,230,.2);   color: #5aadcb; }
.order-status-badge[data-status="배송중"]    { background: rgba(76,175,130,.12);   color: #4CAF82; }
.order-status-badge[data-status="배송완료"]  { background: rgba(45,55,72,.1);      color: #2D3748; }
.order-status-badge[data-status="취소"]      { background: rgba(224,92,92,.12);    color: #E05C5C; }
.order-actions-group { display: flex; gap: 0.3rem; align-items: center; }
.order-table td:nth-child(6) {
  white-space: nowrap;
}

/* ── Empty State ── */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-16) 0;
  color: var(--color-muted);
  text-align: center;
}
.empty-state svg {
  opacity: 0.4;
}
.empty-state p {
  font-size: var(--text-sm);
}

/* ── 혜택 (마일리지/쿠폰) ── */
.benefit-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}
.benefit-card {
  padding: var(--space-6);
  background: var(--color-bg);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
}
.benefit-card-label {
  font-size: var(--text-sm);
  color: var(--color-muted);
  margin-bottom: var(--space-2);
}
.benefit-card-value {
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  color: var(--color-primary);
  margin-bottom: var(--space-1);
}
.benefit-card-desc {
  font-size: var(--text-xs);
  color: var(--color-muted);
}

.mypage-section-subtitle {
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  margin-bottom: var(--space-3);
}
.coupon-register-row {
  display: flex;
  gap: var(--space-3);
}
.coupon-register-input {
  flex: 1;
  padding: 0.65rem 1rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  outline: none;
}
.coupon-register-input:focus {
  border-color: var(--color-primary);
}

/* ── 선입금 ── */
.prepaid-balance-card {
  display: flex;
  align-items: center;
  gap: var(--space-8);
  padding: var(--space-8);
  background: var(--color-bg);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
}
.prepaid-balance-label {
  font-size: var(--text-sm);
  color: var(--color-muted);
}
.prepaid-balance-value {
  font-size: var(--text-4xl);
  font-weight: var(--font-bold);
  color: var(--color-primary);
}

/* ── 회원 정보 수정 ── */
.profile-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  max-width: 480px;
}
.profile-section-divider {
  margin: var(--space-2) 0 0;
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--color-text);
}
.profile-postcode-row {
  display: flex;
  gap: var(--space-2);
}
.profile-postcode-row input {
  flex: 1;
}
.profile-postcode-row .btn-postcode {
  flex-shrink: 0;
  padding: 0.65rem 1rem;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  color: var(--color-text);
  cursor: pointer;
  white-space: nowrap;
  transition: border-color var(--transition-fast), background var(--transition-fast);
}
.profile-postcode-row .btn-postcode:hover {
  border-color: var(--color-primary);
  background: var(--color-white);
}

/* ── 회원 탈퇴 ── */
.withdraw-wrap {
  max-width: 480px;
}
.withdraw-warning {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}
.withdraw-warning h3 {
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  color: var(--color-error);
}
.withdraw-notice-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
}
.withdraw-notice-list li {
  font-size: var(--text-sm);
  color: var(--color-muted);
  padding-left: var(--space-4);
  position: relative;
}
.withdraw-notice-list li::before {
  content: "·";
  position: absolute;
  left: 0;
  color: var(--color-error);
}

/* ── 증빙 서류 등록 ── */
.doc-tabs {
  display: flex;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-6);
  gap: var(--space-2);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.doc-tabs::-webkit-scrollbar {
  display: none;
}
.doc-tab {
  padding: 0 var(--space-5);
  height: 44px;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-muted);
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  transition:
    color var(--transition-fast),
    border-color var(--transition-fast);
}
.doc-tab:hover {
  color: var(--color-text);
}
.doc-tab.is-active {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
  font-weight: var(--font-semibold);
}
.doc-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  max-width: 480px;
}

/* ── Review Write Form (12.1) ─────────────────────────────── */
.review-form-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  max-width: 640px;
}

.review-form-wrap .form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.review-form-wrap .form-label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
}

.review-form-wrap .form-select {
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  color: var(--color-text);
  background: #fff;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 12 12' fill='none' stroke='%23888' stroke-width='2' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 12px;
  cursor: pointer;
}

.review-form-wrap .form-select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(var(--color-primary-rgb, 0, 122, 255), 0.12);
}

/* Star Rating */
.review-rating-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.review-stars-select {
  display: flex;
  gap: 4px;
}

.review-star-btn {
  background: none;
  border: none;
  padding: 2px;
  cursor: pointer;
  font-size: 28px;
  color: #d1d5db;
  transition:
    color 0.1s,
    transform 0.1s;
  line-height: 1;
}

.review-star-btn.is-filled,
.review-star-btn:hover {
  color: #f59e0b;
}

.review-star-btn:active {
  transform: scale(1.2);
}

.review-rating-label {
  font-size: var(--text-sm);
  color: var(--color-text-light);
  min-width: 60px;
}

/* Textarea */
.review-textarea {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  color: var(--color-text);
  resize: vertical;
  min-height: 120px;
  font-family: inherit;
  line-height: 1.6;
  box-sizing: border-box;
}

.review-textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(var(--color-primary-rgb, 0, 122, 255), 0.12);
}

/* Upload Zone — product-detail 스타일과 동일 */
.review-upload-zone {
  border: 2px dashed var(--color-border-dark, #cbd5e1);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  text-align: center;
  cursor: default;
  transition:
    border-color var(--transition-fast),
    background var(--transition-fast);
  background: var(--color-bg, #f8fafc);
}

.review-upload-zone:hover,
.review-upload-zone.is-drag-over {
  border-color: var(--color-secondary);
  background: var(--color-selected-bg);
}

.review-upload-idle {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  text-align: center;
  padding: var(--space-4) 0;
}

.review-upload-idle .upload-zone-text {
  font-size: var(--text-sm);
  color: var(--color-muted);
  line-height: 1.6;
}

.review-upload-idle .upload-zone-hint {
  font-size: var(--text-xs);
  color: var(--color-border-dark, #94a3b8);
}

.review-upload-zone .upload-browse-btn {
  background: none;
  border: none;
  color: var(--color-secondary);
  font-weight: var(--font-semibold);
  cursor: pointer;
  font-size: inherit;
  text-decoration: underline;
  padding: 0;
}

.review-upload-zone .upload-browse-btn:hover {
  color: #6bafc8;
}

/* Image Previews */
.review-image-previews {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-3);
}

.review-preview-item {
  position: relative;
  width: 80px;
  height: 80px;
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 1px solid var(--color-border);
  flex-shrink: 0;
}

.review-preview-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.review-preview-remove {
  position: absolute;
  top: 3px;
  right: 3px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.55);
  color: #fff;
  border: none;
  font-size: 12px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
}

.review-preview-remove:hover {
  background: rgba(0, 0, 0, 0.8);
}

/* ── 반응형 ── */
@media (max-width: 1023px) {
  .mypage-layout {
    grid-template-columns: 1fr;
  }
  .mypage-sidebar {
    position: static;
  }
  .mypage-menu {
    display: flex;
    flex-wrap: wrap;
    border-radius: var(--radius-md);
  }
  .mypage-menu-group {
    border-bottom: none;
    border-right: 1px solid var(--color-border);
    padding: var(--space-2) 0;
    flex: 1;
    min-width: 150px;
  }
  .mypage-menu-group:last-child {
    border-right: none;
  }
}

@media (max-width: 767px) {
  /* 히어로 */
  .mypage-hero {
    padding: var(--space-5) 0;
  }
  .mypage-user-summary {
    gap: var(--space-3);
  }
  .mypage-avatar {
    width: 48px;
    height: 48px;
  }
  .mypage-avatar svg {
    width: 26px;
    height: 26px;
  }
  .mypage-user-name {
    font-size: var(--text-lg);
  }
  .mypage-stats {
    display: none;
  }

  /* 사이드 메뉴: 가로 스크롤 탭 형태 */
  .mypage-sidebar {
    width: 100%;
    overflow: hidden;
  }
  .mypage-menu {
    display: flex;
    flex-wrap: nowrap;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    border-radius: var(--radius-md);
    border: none;
    border-bottom: 1px solid var(--color-border);
  }
  .mypage-menu::-webkit-scrollbar {
    display: none;
  }
  .mypage-menu-group {
    border: none;
    padding: 0;
    flex-shrink: 0;
    flex: none;
    min-width: auto;
    display: flex;
    align-items: center;
  }
  .mypage-menu-group-title {
    display: none;
  }
  .mypage-menu-item {
    white-space: nowrap;
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-sm);
    border-left: none;
    border-bottom: 2px solid transparent;
  }
  .mypage-menu-item.is-active {
    border-left: none;
    border-bottom-color: var(--color-primary);
    background: transparent;
  }
  .mypage-menu-item--danger {
    color: var(--color-error);
  }

  /* 콘텐츠 패널 */
  .mypage-content {
    border-radius: var(--radius-md);
    min-height: 300px;
  }
  .mypage-panel {
    padding: var(--space-5);
  }
  .mypage-panel-header {
    margin-bottom: var(--space-4);
    padding-bottom: var(--space-3);
  }
  .mypage-panel-header h2 {
    font-size: var(--text-lg);
  }

  /* 주문 필터 */
  .order-filter-row {
    flex-wrap: wrap;
    gap: var(--space-2);
  }
  .order-period-btn {
    font-size: var(--text-xs);
    padding: 0.25rem 0.75rem;
  }

  /* 주문 테이블 → 카드 */
  #panel-orders .order-table-wrap {
    overflow: visible;
  }
  #panel-orders .order-table,
  #panel-orders .order-table tbody,
  #panel-orders .order-table tr {
    display: block;
    width: 100%;
  }
  #panel-orders .order-table thead {
    display: none;
  }
  #panel-orders .order-table tr {
    border: 1px solid var(--color-border);
    margin-bottom: var(--space-3);
    padding: var(--space-4);
    background: #fff;
  }
  #panel-orders .order-table td {
    display: block;
    padding: var(--space-1) 0;
    border: none;
    font-size: var(--text-sm);
  }
  #panel-orders .order-table .order-meta {
    font-size: var(--text-xs);
    color: var(--color-muted);
    margin-bottom: var(--space-2);
    padding-bottom: var(--space-2);
    border-bottom: 1px solid var(--color-border);
  }
  #panel-orders .order-table .order-product {
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    max-width: none;
    overflow: visible;
    white-space: normal;
  }
  #panel-orders .order-table .order-options {
    color: var(--color-muted);
    font-size: var(--text-xs);
  }
  #panel-orders .order-table .order-amount {
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
  }
  #panel-orders .order-table .order-actions {
    display: flex !important;
    gap: var(--space-2);
    margin-top: var(--space-3);
    padding-top: var(--space-3);
    border-top: 1px solid var(--color-border);
  }
  #panel-orders .order-table .order-actions .btn {
    flex: 1;
  }

  /* 마일리지 내역 → 카드 */
  #panel-mileage .order-table-wrap {
    overflow: visible;
  }
  #panel-mileage .order-table,
  #panel-mileage .order-table tbody,
  #panel-mileage .order-table tr {
    display: block;
    width: 100%;
  }
  #panel-mileage .order-table thead {
    display: none;
  }
  #panel-mileage .order-table tr {
    border: 1px solid var(--color-border);
    margin-bottom: var(--space-3);
    padding: var(--space-4);
    background: #fff;
  }
  #panel-mileage .order-table td {
    display: block;
    padding: var(--space-1) 0;
    border: none;
  }
  #panel-mileage .order-table td:nth-child(1) {
    font-size: var(--text-xs) !important;
    color: var(--color-muted);
    padding-bottom: var(--space-2);
    margin-bottom: var(--space-1);
    border-bottom: 1px solid var(--color-border);
  }
  #panel-mileage .order-table td:nth-child(2) {
    font-size: var(--text-sm) !important;
  }
  #panel-mileage .order-table td:nth-child(3) {
    font-size: var(--text-base) !important;
  }
  #panel-mileage .order-table td:nth-child(4) {
    font-size: var(--text-base) !important;
  }

  /* 쿠폰 아이템 overflow 방지 */
  .coupon-list-wrap > div {
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  /* 추가금 결제 완료 내역 → 카드 */
  #panel-extra-payment .order-table-wrap {
    overflow: visible;
  }
  #panel-extra-payment .order-table,
  #panel-extra-payment .order-table tbody,
  #panel-extra-payment .order-table tr {
    display: block;
    width: 100%;
  }
  #panel-extra-payment .order-table thead {
    display: none;
  }
  #panel-extra-payment .order-table tr {
    border: 1px solid var(--color-border);
    margin-bottom: var(--space-3);
    padding: var(--space-4);
    background: #fff;
  }
  #panel-extra-payment .order-table td {
    display: block;
    padding: var(--space-1) 0;
    border: none;
    font-size: var(--text-sm);
  }
  #panel-extra-payment .order-table .order-id {
    font-size: var(--text-xs) !important;
    color: var(--color-muted);
    padding-bottom: var(--space-2);
    margin-bottom: var(--space-1);
    border-bottom: 1px solid var(--color-border);
  }
  #panel-extra-payment .order-table .order-amount {
    font-size: var(--text-base) !important;
  }
  #panel-extra-payment .order-table td:nth-child(4) {
    font-size: var(--text-xs) !important;
    color: var(--color-muted);
  }

  /* 추가금 결제 대기 카드 내 flex row wrap */
  .extra-payment-items > div {
    box-sizing: border-box;
  }
  .extra-payment-items > div > div:last-child {
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  /* 선입금 내역 → 카드 */
  #panel-prepaid .order-table-wrap {
    overflow: visible;
  }
  #panel-prepaid .order-table,
  #panel-prepaid .order-table tbody,
  #panel-prepaid .order-table tr {
    display: block;
    width: 100%;
  }
  #panel-prepaid .order-table thead {
    display: none;
  }
  #panel-prepaid .order-table tr {
    border: 1px solid var(--color-border);
    margin-bottom: var(--space-3);
    padding: var(--space-4);
    background: #fff;
  }
  #panel-prepaid .order-table td {
    display: block;
    padding: var(--space-1) 0;
    border: none;
  }
  #panel-prepaid .order-table td:nth-child(1) {
    font-size: var(--text-xs) !important;
    color: var(--color-muted);
    padding-bottom: var(--space-2);
    margin-bottom: var(--space-1);
    border-bottom: 1px solid var(--color-border);
  }
  #panel-prepaid .order-table td:nth-child(2) {
    font-size: var(--text-sm);
  }
  #panel-prepaid .order-table td:nth-child(3) {
    font-size: var(--text-base) !important;
  }
  #panel-prepaid .order-table td:nth-child(4) {
    font-size: var(--text-base) !important;
  }

  /* 1:1 상담 테이블 → 카드 */
  #panel-inquiry {
    overflow-x: hidden;
  }
  #panel-inquiry .order-table-wrap {
    overflow: hidden;
    width: 100%;
  }
  #panel-inquiry .order-table,
  #panel-inquiry .order-table tbody {
    display: block;
    width: 100%;
  }
  #panel-inquiry .order-table thead {
    display: none;
  }
  #panel-inquiry .order-table tr {
    display: block;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }
  #panel-inquiry .order-table tr[id^="inq-detail"] {
    display: block;
    overflow: hidden;
  }
  #panel-inquiry .order-table tr:not([id^="inq-detail"]) {
    display: block;
    border: 1px solid var(--color-border);
    margin-bottom: var(--space-3);
    padding: var(--space-4);
    background: #fff;
  }
  #panel-inquiry .order-table tr:not([id^="inq-detail"]) td {
    display: block;
    padding: var(--space-1) 0;
    border: none;
    font-size: var(--text-sm);
  }
  #panel-inquiry .order-table .inq-id {
    font-size: var(--text-xs);
    color: var(--color-muted);
    margin-bottom: var(--space-2);
    padding-bottom: var(--space-2);
    border-bottom: 1px solid var(--color-border);
  }
  #panel-inquiry .order-table .inq-title {
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    max-width: none;
    overflow: visible;
    white-space: normal;
  }
  #panel-inquiry .order-table .inq-type,
  #panel-inquiry .order-table .inq-date {
    color: var(--color-muted);
    font-size: var(--text-xs) !important;
  }
  #panel-inquiry .order-table .inq-action {
    margin-top: var(--space-3);
    padding-top: var(--space-3);
    border-top: 1px solid var(--color-border);
  }
  #panel-inquiry .order-table tr[id^="inq-detail"] td {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    overflow-wrap: break-word;
    word-break: break-word;
    padding: var(--space-4) !important;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-top: 0;
    margin-bottom: var(--space-3);
    background: var(--color-bg);
  }
  #panel-inquiry .order-table tr[id^="inq-detail"] td p,
  #panel-inquiry .order-table tr[id^="inq-detail"] td div {
    max-width: 100%;
    overflow-wrap: break-word;
    word-break: break-word;
  }

  /* 1:1 상담 상세보기 모바일 카드 */
  .inq-detail-mobile-card {
    display: block;
    width: 100%;
    box-sizing: border-box;
    padding: var(--space-4);
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-3);
    overflow-wrap: break-word;
    word-break: break-word;
  }
  .inq-detail-mobile-card > div {
    display: block;
    width: 100%;
  }
  .inq-detail-mobile-card p {
    margin: 0;
    font-size: var(--text-sm);
    line-height: 1.6;
    word-break: break-word;
  }

  /* 혜택 */
  .benefit-cards {
    grid-template-columns: 1fr;
  }
  .benefit-card {
    padding: var(--space-4);
  }
  .benefit-card-value {
    font-size: var(--text-2xl);
  }

  /* 선입금 */
  .prepaid-balance-card {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-4);
    padding: var(--space-5);
  }
  .prepaid-balance-value {
    font-size: var(--text-3xl);
  }

  /* 쿠폰 등록 */
  .coupon-register-row {
    flex-direction: column;
  }

  /* 폼 전체폭 */
  .profile-form {
    max-width: 100%;
  }
  .review-form-wrap {
    max-width: 100%;
  }
  .withdraw-wrap {
    max-width: 100%;
  }
}

@media (max-width: 479px) {
  .review-star-btn {
    font-size: 24px;
  }
  .review-upload-zone {
    padding: var(--space-5) var(--space-3);
  }
  .mypage-hero {
    padding: var(--space-4) 0;
  }
  .mypage-avatar {
    width: 40px;
    height: 40px;
  }
  .mypage-avatar svg {
    width: 22px;
    height: 22px;
  }
  .mypage-user-name {
    font-size: var(--text-base);
  }
  .mypage-user-email {
    font-size: var(--text-xs);
  }
  .mypage-main {
    padding: var(--space-5) 0 var(--space-12);
  }
  .mypage-layout {
    gap: var(--space-4);
  }
  .mypage-panel {
    padding: var(--space-4);
  }
  .mypage-panel-header h2 {
    font-size: var(--text-base);
  }
  .mypage-section-subtitle {
    font-size: var(--text-sm);
  }
  .order-period-btn {
    font-size: 11px;
    padding: 0.2rem 0.6rem;
  }
  .order-table th,
  .order-table td {
    padding: var(--space-2);
    font-size: 11px;
    white-space: nowrap;
  }
  .benefit-card-value {
    font-size: var(--text-xl);
  }
  .prepaid-balance-value {
    font-size: var(--text-2xl);
  }
}

/* ── 쿠폰 다운받기 ── */
.coupon-download-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}
.coupon-download-card {
  border: 1.5px dashed var(--color-primary);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  background: #fff;
  transition: box-shadow var(--transition-fast);
}
.coupon-download-card:hover {
  box-shadow: var(--shadow-md);
}
.coupon-download-badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  background: var(--color-primary-light);
  color: var(--color-primary);
  align-self: flex-start;
}
.coupon-badge--summer {
  background: #fff3cd;
  color: #856404;
}
.coupon-badge--vip {
  background: #f0e6ff;
  color: #6f42c1;
}
.coupon-download-title {
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  color: var(--color-text);
}
.coupon-download-desc {
  font-size: var(--text-xs);
  color: var(--color-muted);
}
.coupon-download-expire {
  font-size: var(--text-xs);
  color: var(--color-muted);
  margin-top: auto;
}
.coupon-download-btn {
  margin-top: var(--space-2);
  width: 100%;
  justify-content: center;
}

/* ── Order Detail Page ── */
.order-detail-page {
  padding: var(--space-8) 0 var(--space-20);
}

.order-detail-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-8);
}
.order-detail-page-header h1 {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--color-text);
}

.order-detail-section {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6) var(--space-8);
  margin-bottom: var(--space-6);
}

.order-detail-section-title {
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  color: var(--color-text);
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border);
}

.order-detail-info-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.order-detail-info-row {
  display: flex;
  gap: var(--space-4);
  font-size: var(--text-sm);
}
.order-detail-info-label {
  flex-shrink: 0;
  width: 140px;
  color: var(--color-muted);
}
.order-detail-info-value {
  color: var(--color-text);
  font-weight: var(--font-medium);
}
.order-detail-payment-row {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.receipt-print-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--text-xs);
}
.order-detail-completion-date {
  color: var(--color-primary);
  font-weight: var(--font-semibold);
}

.order-status-badge {
  display: inline-block;
  padding: 0.2rem 0.6rem;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
}

.order-detail-products {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.order-detail-product-card {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-4);
  background: var(--color-bg-alt);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
}
.order-detail-product-thumb {
  width: 80px;
  height: 80px;
  flex-shrink: 0;
  background: var(--color-border);
  border-radius: var(--radius-md);
}
.order-detail-product-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  justify-content: center;
}
.order-detail-product-name {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--color-text);
}
.order-detail-product-options {
  font-size: var(--text-xs);
  color: var(--color-muted);
  line-height: 1.6;
}
.order-detail-product-price {
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  color: var(--color-primary);
  margin-top: var(--space-1);
}

.order-detail-file-guide {
  font-size: var(--text-sm);
  color: var(--color-muted);
  margin-bottom: var(--space-5);
}
.order-detail-file-group {
  margin-bottom: var(--space-5);
}
.order-detail-file-label {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--color-text);
  margin-bottom: var(--space-2);
  display: flex;
  align-items: center;
  gap: var(--space-1);
}
.order-detail-file-required {
  color: var(--color-error, #e05c5c);
  font-weight: var(--font-bold);
}
.order-detail-file-optional {
  font-size: var(--text-xs);
  font-weight: var(--font-normal);
  color: var(--color-muted);
}
.order-detail-file-zone {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4);
  background: var(--color-bg-alt);
  border: 1.5px dashed var(--color-border-dark);
  border-radius: var(--radius-lg);
}
.order-detail-file-zone input[type="file"] {
  display: none;
}
.order-detail-file-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  background: var(--color-white);
  border: 1.5px solid var(--color-border-dark);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text);
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition:
    border-color var(--transition-fast),
    background var(--transition-fast);
}
.order-detail-file-btn:hover {
  border-color: var(--color-primary);
  background: var(--color-primary-light);
}
.order-detail-file-hint {
  font-size: var(--text-xs);
  color: var(--color-muted);
}
.order-detail-file-zone--split {
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-3);
}
.order-detail-file-zone--request {
  justify-content: space-between;
}
.order-detail-file-zone--request .btn {
  flex-shrink: 0;
}
.order-detail-upload-approved {
  margin-top: var(--space-5);
}
.order-detail-upload-approved[hidden] {
  display: none;
}
.order-detail-upload-status {
  margin-bottom: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-primary);
  border-radius: var(--radius-md);
  background: var(--color-primary-light);
  color: var(--color-primary);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
}
.order-detail-upload-wizard {
  padding: var(--space-5) 0;
}
.upload-files-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  align-items: flex-start;
}
.upload-file-card {
  min-width: 0;
  width: 100%;
  max-width: 480px;
}
.order-detail-upload-wizard .upload-zone {
  padding: var(--space-5) var(--space-6);
  background: var(--color-bg-alt);
  min-height: unset;
  gap: var(--space-2);
  cursor: pointer;
}
.order-detail-upload-wizard .upload-zone-text {
  font-size: var(--text-sm);
  color: var(--color-muted);
  margin: 0;
  text-align: center;
}
.order-detail-upload-wizard .upload-browse-btn {
  background: none;
  border: none;
  padding: 0;
  color: var(--color-primary);
  font-weight: var(--font-semibold);
  font-size: var(--text-sm);
  cursor: pointer;
  text-decoration: underline;
}
.order-detail-upload-wizard .upload-zone-hint {
  font-size: var(--text-xs);
  color: var(--color-muted);
  margin: 0;
  text-align: center;
}
.order-detail-file-split-item {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}
.order-detail-file-split-label {
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  color: var(--color-muted);
  width: 32px;
  flex-shrink: 0;
}
.order-detail-file-submit {
  margin-top: var(--space-6);
  display: flex;
  justify-content: flex-end;
}

@media (max-width: 767px) {
  .upload-files-grid {
    align-items: stretch;
  }
  .upload-file-card {
    max-width: 100%;
  }
  .order-detail-file-zone--request {
    align-items: stretch;
    flex-direction: column;
  }
  .doc-form {
    max-width: 100%;
  }
  .doc-tab {
    padding: 0 var(--space-3);
  }
}

/* ── 재업로드 신청 완료 모달 ── */
.reupload-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
}
.reupload-modal-backdrop[hidden] {
  display: none;
}
.reupload-modal-box {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  padding: var(--space-10) var(--space-8);
  max-width: 360px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.18);
  text-align: center;
}
.reupload-modal-icon {
  width: 52px;
  height: 52px;
  background: var(--color-primary-light);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
}
.reupload-modal-icon svg {
  width: 28px;
  height: 28px;
}
.reupload-modal-title {
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  color: var(--color-text);
}
.reupload-modal-desc {
  font-size: var(--text-sm);
  color: var(--color-muted);
  line-height: 1.7;
  margin: 0;
}
/* ── 상품별 재업로드 상태 UI ── */
.product-reupload-section {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-3);
  flex-wrap: wrap;
}
.reupload-state {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.reupload-state[hidden] {
  display: none;
}
.reupload-status-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: var(--radius-full, 999px);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
}
.reupload-status-badge--pending {
  background: var(--color-warning-light, #fff8e1);
  color: var(--color-warning, #f59e0b);
  border: 1px solid var(--color-warning, #f59e0b);
}
.reupload-status-badge--approved {
  background: var(--color-success-light, #e8f5e9);
  color: var(--color-success, #22c55e);
  border: 1px solid var(--color-success, #22c55e);
}
.reupload-done-label {
  font-size: var(--text-xs);
  color: var(--color-success, #22c55e);
  font-weight: var(--font-medium);
}
.product-confirm-section {
  margin-top: var(--space-2);
}

/* ── 재업로드 파일 업로드 팝업 ── */
.reupload-upload-box {
  max-width: 480px !important;
  max-height: 88vh;
  align-items: stretch !important;
  text-align: left !important;
  overflow: hidden;
}
.reupload-upload-box .reupload-files-grid {
  overflow-y: auto;
  flex-shrink: 1;
  min-height: 0;
}
.reupload-upload-box .reupload-modal-header,
.reupload-upload-box .reupload-modal-actions {
  flex-shrink: 0;
}
.reupload-files-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-3) !important;
  width: 100%;
}
.reupload-files-grid .upload-file-card {
  max-width: unset;
  width: 100%;
}
.reupload-upload-box .upload-zone--compact {
  padding: var(--space-2) var(--space-3);
  min-height: 56px;
  gap: var(--space-1);
}
.reupload-upload-box .upload-zone--compact .upload-zone-text {
  font-size: var(--text-xs);
  color: var(--color-muted);
  margin: 0;
  text-align: center;
}
.reupload-upload-box .upload-zone--compact .upload-browse-btn {
  font-size: var(--text-xs);
  color: var(--color-primary);
  font-weight: var(--font-semibold);
  text-decoration: underline;
  cursor: pointer;
}
.reupload-upload-box .upload-zone--compact .upload-zone-hint {
  font-size: var(--text-xs);
  color: var(--color-muted);
  margin: 0;
  text-align: center;
}
.reupload-upload-box .upload-zone--compact.has-file {
  border-color: var(--color-primary);
  background: var(--color-primary-light);
}
.reupload-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}
.reupload-modal-x-btn {
  background: none;
  border: none;
  font-size: 1.25rem;
  cursor: pointer;
  color: var(--color-muted);
  padding: 4px;
}
.reupload-modal-x-btn:hover {
  color: var(--color-text);
}
.reupload-modal-actions {
  display: flex;
  gap: var(--space-3);
  justify-content: flex-end;
  margin-top: var(--space-4);
  width: 100%;
}

/* ── 송장번호 링크 ── */
.tracking-number-link {
  color: var(--color-primary);
  text-decoration: underline;
  cursor: pointer;
}
.tracking-number-link:hover {
  opacity: 0.8;
}

.reupload-modal-close {
  margin-top: var(--space-2);
  min-width: 120px;
}

/* ── 재작업 문의 패널 모바일 overflow 방지 ── */
@media (max-width: 1023px) {
  #panel-rework {
    overflow-x: hidden;
    max-width: 100%;
  }
  #panel-rework .rework-layout {
    grid-template-columns: minmax(0, 1fr);
    max-width: 100%;
    overflow-x: hidden;
  }
  #panel-rework .rework-layout > * {
    min-width: 0;
    max-width: 100%;
    overflow-x: hidden;
  }
  #panel-rework .inquiry-info {
    margin-top: var(--space-4);
  }
  #panel-rework textarea,
  #panel-rework input:not([type="radio"]):not([type="file"]) {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }
}

@media print {
  .site-header,
  .site-footer,
  .mypage-sidebar,
  .receipt-print-btn,
  .product-reupload-section,
  .purchase-confirm-btn {
    display: none !important;
  }
  .mypage-content {
    margin: 0;
  }
}
