/**
 * ┌─────────────────────────────────────────────────────────────────────┐
 * │  FILE INDEX — 여수뉴스포털                                          │
 * │  파일명: deal-form.css / 위치: /deal/assets/css/deal-form.css       │
 * │  생성일: 2026-05-16 / 수정일: 2026-06-06 / 버전: v1.3              │
 * │  역할: 거래포털 write/edit 보조 CSS — placard pw-* 위에 scoped 적용 │
 * │  SSOT: publicity/assets/css/placard.css                             │
 * │  변경: v1.3 모바일 공간 최적화 (2열 유지·칩 auto-size·인라인 보존) │
 * └─────────────────────────────────────────────────────────────────────┘
 *
 * ● 스코프: [class*="-write-wrap"] specificity(0,2,0) > placard(0,1,0)
 *           모바일 브레이크포인트에서도 deal-form 규칙 우선 적용
 * ● 타이포그래피: 14px 하한선 / 입력요소 16px (iOS zoom 방지)
 * ● Mobile-First: 기본값 = 모바일, min-width 로만 확장
 */

/* ═══════════════════════════════════════════════════════════════
   §1. 폼 행(pw-row) — 모바일 2열 유지
   ---------------------------------------------------------------
   placard @max-width:768px → pw-row:1fr (스택) → 라벨 1행 낭비
   [class*="-write-wrap"](0,2,0) > placard(0,1,0) → 88px 1fr 강제
   전: 라벨40px + 필드44px = 행당 84px
   후: max(40,44) = 행당 44px → 약 절반
   ─────────────────────────────────────────────────────────────── */
[class*="-write-wrap"] .pw-row {
  grid-template-columns: 88px 1fr;
}
[class*="-write-wrap"] .pw-label {
  padding: 10px 6px 10px 12px;
  font-size: 14px;
  align-items: flex-start;
  word-break: keep-all;
  line-height: 1.4;
}
[class*="-write-wrap"] .pw-field {
  padding: 8px 10px 8px 0;
  gap: 5px;
}
/* 모바일 입력요소: iOS zoom 방지(16px) + 터치 타깃(44px) */
[class*="-write-wrap"] .pw-input,
[class*="-write-wrap"] .pw-select {
  font-size: 16px;
  min-height: 44px;
}
[class*="-write-wrap"] .pw-textarea {
  font-size: 16px;
  min-height: 80px;
}
/* 769px+: 표준 레이아웃 */
@media (min-width: 769px) {
  [class*="-write-wrap"] .pw-row {
    grid-template-columns: 160px 1fr;
  }
  [class*="-write-wrap"] .pw-label {
    padding: 14px 16px 14px 20px;
    align-items: flex-start;
    line-height: 1.5;
  }
  [class*="-write-wrap"] .pw-field {
    padding: 12px 20px 12px 0;
    gap: 6px;
  }
  [class*="-write-wrap"] .pw-input,
  [class*="-write-wrap"] .pw-select {
    font-size: 14px;
    min-height: auto;
  }
  [class*="-write-wrap"] .pw-textarea {
    font-size: 14px;
    min-height: 90px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   §2. 인라인 필드(pw-field-inline) — row 유지
   ---------------------------------------------------------------
   placard @max-width:768px → column 스택
   면적·층수·방수 dimension 필드: 5항목 × 44px = 220px 낭비
   → [class*="-write-wrap"] 스코프에서 flex-wrap:row 유지
   ─────────────────────────────────────────────────────────────── */
[class*="-write-wrap"] .pw-field-inline {
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
}
[class*="-write-wrap"] .pw-field-inline .pw-input,
[class*="-write-wrap"] .pw-field-inline .pw-select {
  width: auto;
  min-width: 56px;
  max-width: 90px;
  flex: 0 0 auto;
  font-size: 16px;
}
[class*="-write-wrap"] .pw-field-inline .pw-input-sm {
  width: 64px;
  max-width: 64px;
}
[class*="-write-wrap"] .pw-field-inline .pw-input-md {
  width: 90px;
  max-width: 90px;
}
[class*="-write-wrap"] .pw-dim-unit {
  white-space: nowrap;
  font-size: 14px;
  flex-shrink: 0;
}
@media (min-width: 769px) {
  [class*="-write-wrap"] .pw-field-inline {
    flex-wrap: nowrap;
    gap: 8px;
  }
  [class*="-write-wrap"] .pw-field-inline .pw-input,
  [class*="-write-wrap"] .pw-field-inline .pw-select {
    font-size: 14px;
    min-width: 0;
  }
  [class*="-write-wrap"] .pw-field-inline .pw-input-sm {
    width: 90px;
    max-width: 110px;
  }
  [class*="-write-wrap"] .pw-field-inline .pw-input-md {
    width: 110px;
    max-width: 150px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   §3. 칩 그리드(pw-activity-grid) — Mobile-First auto-size
   ---------------------------------------------------------------
   placard SSOT minmax(155px) → 2-4자 칩 공백 68% 낭비
   ① 기본(모바일): flex auto-size → 칩 = 텍스트 폭만 사용
      매매=52px, 단기임대=80px → 거래유형5개 1-2행
   ② 769px+: grid auto-fill minmax(88px) → 균일폭 compact
   ─────────────────────────────────────────────────────────────── */
[class*="-write-wrap"] .pw-activity-grid {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}
[class*="-write-wrap"] .pw-activity-item {
  flex: 0 0 auto;
  width: auto;
  padding: 7px 12px;
}
@media (min-width: 769px) {
  [class*="-write-wrap"] .pw-activity-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(88px, 1fr));
    gap: 7px;
    align-items: unset;
  }
  [class*="-write-wrap"] .pw-activity-item {
    flex: unset;
    width: auto;
    padding: 8px 12px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   §4. 섹션 카드 — 모바일 compact
   ─────────────────────────────────────────────────────────────── */
[class*="-write-wrap"] .pw-section {
  margin-bottom: 10px;
}
[class*="-write-wrap"] .pw-section-title {
  padding: 10px 12px;
  font-size: 14px;
}
@media (min-width: 769px) {
  [class*="-write-wrap"] .pw-section { margin-bottom: 16px; }
  [class*="-write-wrap"] .pw-section-title { padding: 12px 20px; }
}

/* ═══════════════════════════════════════════════════════════════
   §5. 제출 행 — Mobile-First
   기본: column-reverse 전체폭 / 481px+: flex-row 우측
   ─────────────────────────────────────────────────────────────── */
[class*="-write-wrap"] .pw-submit-row {
  flex-direction: column-reverse;
  gap: 8px;
  padding: 12px 0 4px;
}
[class*="-write-wrap"] .pw-btn-submit,
[class*="-write-wrap"] .pw-btn-cancel {
  width: 100%;
  justify-content: center;
  min-height: 48px;
  font-size: 16px;
}
@media (min-width: 481px) {
  [class*="-write-wrap"] .pw-submit-row {
    flex-direction: row;
    justify-content: flex-end;
    padding: 20px 0 8px;
  }
  [class*="-write-wrap"] .pw-btn-submit,
  [class*="-write-wrap"] .pw-btn-cancel {
    width: auto;
    min-height: 44px;
    font-size: 15px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   §6. Write/Edit outer 래퍼 — pl-wrap 동형
   ─────────────────────────────────────────────────────────────── */
.pub-content-wrap > .pub-main-col > .pl-wrap,
.pl-wrap[class*="-write-wrap"],
.pl-wrap.realestate-write-wrap,
.pl-wrap.cars-write-wrap,
.pl-wrap.online-write-wrap,
.pl-wrap.market-write-wrap,
.pl-wrap.onl-write-wrap,
.pl-wrap.mkt-write-wrap,
.pl-wrap.car-write-wrap,
[class*="-write-wrap"] {
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
.pub-content-wrap > .pub-main-col > .pl-wrap .pw-container,
.pl-wrap[class*="-write-wrap"] .pw-container,
.pl-wrap.realestate-write-wrap .pw-container,
.pl-wrap.cars-write-wrap .pw-container,
.pl-wrap.online-write-wrap .pw-container,
.pl-wrap.market-write-wrap .pw-container,
.pl-wrap.onl-write-wrap .pw-container,
.pl-wrap.mkt-write-wrap .pw-container,
.pl-wrap.car-write-wrap .pw-container,
[class*="-write-wrap"] .pw-container {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  padding: 0;
  box-sizing: border-box;
}
.pub-wrap .pub-main-col > .pl-wrap,
.pub-wrap .pub-main-col > [class*="-write-wrap"] {
  padding-left: 0;
  padding-right: 0;
  margin-left: 0;
  margin-right: 0;
}

/* ═══════════════════════════════════════════════════════════════
   §7. Shell 사이드바 — Mobile-First
   기본: hidden / 901px+: grid 1fr+260px
   ─────────────────────────────────────────────────────────────── */
.pub-list-page .pub-content-wrap > .pub-sidebar {
  display: none;
}
@media (min-width: 901px) {
  .pub-list-page .pub-content-wrap {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 260px;
    gap: 24px;
    align-items: start;
  }
  .pub-list-page .pub-content-wrap > .pub-main-col {
    grid-column: 1;
    grid-row: 1;
    min-width: 0;
    max-width: 100%;
    overflow-x: clip;
  }
  .pub-list-page .pub-content-wrap > .pub-sidebar {
    display: flex !important;
    flex-direction: column;
    grid-column: 2;
    grid-row: 1;
    width: 260px;
    max-width: 260px;
    min-width: 0;
    align-self: start;
  }
}

/* ═══════════════════════════════════════════════════════════════
   §8. 이미지 미리보기·업로드 — Mobile-First
   ─────────────────────────────────────────────────────────────── */
.de-re-preview-img {
  width: auto;
  max-width: 100%;
  max-height: 140px;
  border-radius: 8px;
  border: 1px solid #e2e8f0;
  display: block;
}
@media (min-width: 481px) {
  .de-re-preview-img { max-width: 240px; max-height: 200px; }
}
.de-re-preview-wrap { margin-top: 8px; }
.de-re-preview-wrap[hidden] { display: none !important; }
.de-re-new-block[hidden],
.de-re-price-row[hidden] { display: none !important; }

.de-img-preview-grid { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.de-img-preview-item {
  width: 68px; height: 68px; border-radius: 8px; overflow: hidden; border: 1.5px solid #e2e8f0;
}
.de-img-preview-item img { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (min-width: 481px) {
  .de-img-preview-item { width: 80px; height: 80px; }
}

.de-thumb-preview {
  display: none;
  width: auto; max-width: 100%; max-height: 140px;
  margin-top: 8px; border-radius: 8px; border: 1px solid #e2e8f0;
}
@media (min-width: 481px) {
  .de-thumb-preview { max-width: 240px; max-height: 200px; }
}

.de-img-thumb-wrap { position: relative; display: inline-block; margin: 3px; }
.de-img-thumb-wrap img {
  width: 68px; height: 52px; object-fit: cover; border-radius: 6px; border: 1px solid #e2e8f0;
}
@media (min-width: 481px) {
  .de-img-thumb-wrap img { width: 80px; height: 60px; }
}

.de-img-del-chk {
  position: absolute; top: 2px; right: 2px;
  background: rgba(220,53,69,.85); color: #fff;
  width: 22px; height: 22px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; cursor: pointer;
  touch-action: manipulation; -webkit-tap-highlight-color: transparent;
}

[class*="-write-wrap"] .pw-banner-upload {
  min-height: 80px; padding: 18px 12px;
}
@media (min-width: 481px) {
  [class*="-write-wrap"] .pw-banner-upload { min-height: 100px; padding: 28px 20px; }
}
