/* ==============================================================
   admin_common.css - 하나점포 관리자 공통 CSS
   ============================================================== */

/* ----------------------------------------------
   [1] CSS 변수 (공통 테마 컬러)
   ---------------------------------------------- */
:root {
	--color-primary: #1e293b;
	--color-primary-light: #334155;
	--color-accent: #dc2626;
	--color-accent-hover: #b91c1c;
	--color-orange: #ea580c;
	--color-blue: #2563eb;
	--color-green: #16a34a;
	--color-purple: #7c3aed;
	--bg-body: #f1f5f9;
	--bg-card: #ffffff;
	--bg-header: #1e293b;
	--bg-footer: #1e293b;
	--text-primary: #1e293b;
	--text-secondary: #64748b;
	--text-light: #94a3b8;
	--text-white: #f8fafc;
	--border-color: #e2e8f0;
	--shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
	--shadow-md: 0 4px 6px rgba(0,0,0,0.07);
	--shadow-lg: 0 10px 15px rgba(0,0,0,0.1);
	--max-width: 1200px;
	--radius: 8px;
	--radius-sm: 4px;
}

/* ----------------------------------------------
   [2] 리셋 & 기본 스타일
   ---------------------------------------------- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { font-size:14px; -webkit-text-size-adjust:100%; }
body {
	font-family: 'Malgun Gothic','Apple SD Gothic Neo','Noto Sans KR',sans-serif;
	background: var(--bg-body);
	color: var(--text-primary);
	line-height: 1.6;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}
a { color:inherit; text-decoration:none; }
a:hover { text-decoration:none; }
img { max-width:100%; height:auto; border:0; }

/* ----------------------------------------------
   [3] 공통 레이아웃 컨테이너
   ---------------------------------------------- */
.container { width:100%; max-width:var(--max-width); margin:0 auto; padding:0 20px; }
.main-content { flex:1; padding:24px 0; }

/* ----------------------------------------------
   [4] 헤더 (상단 공통 영역)
   ---------------------------------------------- */
.site-header { background:var(--bg-header); color:var(--text-white); position:sticky; top:0; z-index:100; box-shadow:var(--shadow-lg); }
.header-top { display:flex; align-items:center; justify-content:space-between; padding:14px 0; border-bottom:1px solid rgba(255,255,255,0.1); }
.header-logo { font-size:1.4rem; font-weight:800; letter-spacing:-0.5px; color:#fff; }
.header-logo span { color:var(--color-accent); }
.header-util { display:flex; gap:6px; align-items:center; }
.header-util a { color:var(--text-light); font-size:0.85rem; padding:4px 10px; border-radius:var(--radius-sm); transition:all 0.2s; }
.header-util a:hover { color:#fff; background:rgba(255,255,255,0.1); }
.header-util .btn-logout { color:var(--color-accent); border:1px solid var(--color-accent); margin-left:4px; cursor:pointer; }
.header-util .btn-logout:hover { background:var(--color-accent); color:#fff; }
.header-util .divider { color:rgba(255,255,255,0.2); font-size:0.8rem; user-select:none; }
.header-nav { display:flex; flex-wrap:wrap; gap:2px; padding:8px 0 0 0; }
.header-nav a { display:inline-block; padding:10px 16px; color:rgba(255,255,255,0.7); font-size:0.9rem; font-weight:500; border-radius:var(--radius-sm) var(--radius-sm) 0 0; transition:all 0.2s; white-space:nowrap; }
.header-nav a:hover { color:#fff; background:rgba(255,255,255,0.1); }
.header-nav a.active { color:#fff; background:var(--color-accent); }
.mobile-menu-btn { display:none; background:none; border:1px solid rgba(255,255,255,0.3); color:#fff; font-size:1.3rem; padding:6px 10px; border-radius:var(--radius-sm); cursor:pointer; line-height:1; }
.mobile-menu-btn:hover { background:rgba(255,255,255,0.1); }

/* ----------------------------------------------
   [5] 푸터 (하단 공통 영역)
   ---------------------------------------------- */
.site-footer { background:var(--bg-footer); color:var(--text-light); text-align:center; padding:24px 0; font-size:0.8rem; margin-top:auto; }

/* ----------------------------------------------
   [6] 검색 바
   ---------------------------------------------- */
.search-bar { background:var(--bg-card); border-radius:var(--radius); padding:16px 20px; margin-bottom:20px; box-shadow:var(--shadow-sm); border:1px solid var(--border-color); }
.search-bar form { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.search-row { display:flex; gap:8px; align-items:center; flex-wrap:wrap; width:100%; margin-bottom:8px; }
.search-row:last-child { margin-bottom:0; }
.search-select { padding:9px 10px; border:1px solid var(--border-color); border-radius:var(--radius-sm); font-size:0.9rem; font-family:inherit; background:#fff; color:var(--text-primary); outline:none; min-width:120px; cursor:pointer; transition:border-color 0.2s; }
.search-select:focus { border-color:var(--color-blue); box-shadow:0 0 0 3px rgba(37,99,235,0.1); }
.search-input { padding:9px 14px; border:1px solid var(--border-color); border-radius:var(--radius-sm); font-size:0.9rem; font-family:inherit; outline:none; transition:border-color 0.2s; min-width:100px; width:120px; }
.search-input-wide { flex:1; min-width:150px; width:auto; }
.search-input:focus { border-color:var(--color-blue); box-shadow:0 0 0 3px rgba(37,99,235,0.1); }

/* ----------------------------------------------
   [7] 공통 버튼 스타일
   ---------------------------------------------- */
.btn { display:inline-block; padding:10px 20px; font-size:0.9rem; font-weight:600; border:none; border-radius:var(--radius-sm); cursor:pointer; transition:all 0.2s; text-align:center; font-family:inherit; line-height:1.4; white-space:nowrap; }
.btn-primary { background:var(--color-accent); color:#fff; }
.btn-primary:hover { background:var(--color-accent-hover); }
.btn-secondary { background:var(--color-primary); color:#fff; }
.btn-secondary:hover { background:var(--color-primary-light); }
.btn-outline { background:#fff; color:var(--text-primary); border:1px solid var(--border-color); }
.btn-outline:hover { background:var(--bg-body); border-color:var(--text-light); }
.btn-sm { padding:6px 12px; font-size:0.8rem; }

/* ----------------------------------------------
   [8] 리스트 헤더 (제목 + 정렬탭)
   ---------------------------------------------- */
.list-header { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; margin-bottom:16px; }
.list-title { font-size:1.3rem; font-weight:800; color:var(--text-primary); display:flex; align-items:center; gap:8px; }
.list-title .count { font-size:0.85rem; font-weight:500; color:var(--text-secondary); }
.sort-tabs { display:flex; gap:4px; flex-wrap:wrap; }
.sort-tabs a { padding:7px 14px; font-size:0.85rem; color:var(--text-secondary); border:1px solid var(--border-color); border-radius:var(--radius-sm); background:var(--bg-card); transition:all 0.2s; }
.sort-tabs a:hover { color:var(--color-accent); border-color:var(--color-accent); }
.sort-tabs a.active { background:var(--color-accent); color:#fff; border-color:var(--color-accent); }

/* ----------------------------------------------
   [9] 매물 카드 리스트
   ---------------------------------------------- */
.listing-list { display:flex; flex-direction:column; gap:12px; }
.listing-card { background:var(--bg-card); border-radius:var(--radius); border:1px solid var(--border-color); box-shadow:var(--shadow-sm); overflow:hidden; transition:box-shadow 0.2s, transform 0.15s; }
.listing-card:hover { box-shadow:var(--shadow-md); transform:translateY(-1px); }
.listing-card-inner { display:flex; padding:16px; gap:16px; }
.listing-thumb { flex-shrink:0; width:160px; height:120px; border-radius:var(--radius-sm); overflow:hidden; background:#e2e8f0; }
.listing-thumb img { width:100%; height:100%; object-fit:cover; }
.listing-info { flex:1; min-width:0; display:flex; flex-direction:column; gap:6px; }
.listing-tags { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.badge { display:inline-block; padding:2px 8px; font-size:0.75rem; font-weight:700; border-radius:3px; line-height:1.5; }
.badge-recommend { background:#fef2f2; color:#dc2626; border:1px solid #fecaca; }
.badge-urgent    { background:#eff6ff; color:#2563eb; border:1px solid #bfdbfe; }
.badge-safe      { background:#f0fdf4; color:#16a34a; border:1px solid #bbf7d0; }
.badge-new       { background:#fefce8; color:#ca8a04; border:1px solid #fef08a; }
.badge-remodel   { background:#f5f3ff; color:#7c3aed; border:1px solid #ddd6fe; }
.badge-default   { background:#f8fafc; color:#64748b; border:1px solid #e2e8f0; }
.listing-location { font-size:0.9rem; font-weight:700; color:var(--color-blue); }
.listing-admin-memo { font-size:0.8rem; color:var(--color-accent); font-weight:500; }
.listing-title { font-size:1rem; font-weight:700; color:var(--text-primary); line-height:1.4; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.listing-summary { font-size:0.85rem; color:var(--text-secondary); line-height:1.5; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.listing-prices { display:flex; gap:16px; flex-wrap:wrap; margin-top:4px; }
.price-item { font-size:0.85rem; font-weight:600; }
.price-label { font-weight:500; color:var(--text-secondary); margin-right:4px; }
.price-total { color:var(--color-orange); }
.price-month { color:var(--color-purple); }
.price-profit { color:var(--color-accent); }
.listing-meta { display:flex; gap:8px; flex-wrap:wrap; font-size:0.8rem; color:var(--text-secondary); padding-top:6px; border-top:1px solid var(--border-color); margin-top:4px; }
.listing-meta span { display:inline-flex; align-items:center; }
.listing-meta .sep { color:var(--border-color); }
.listing-consultant { flex-shrink:0; width:80px; text-align:center; display:flex; flex-direction:column; align-items:center; gap:6px; padding-left:16px; border-left:1px solid var(--border-color); }
.consultant-photo { width:56px; height:70px; border-radius:var(--radius-sm); overflow:hidden; background:#e2e8f0; }
.consultant-photo img { width:100%; height:100%; object-fit:cover; }
.consultant-name { font-size:0.75rem; color:var(--text-secondary); line-height:1.3; word-break:keep-all; }

/* ----------------------------------------------
   [10] 페이징
   ---------------------------------------------- */
.pagination { display:flex; justify-content:center; align-items:center; gap:4px; margin-top:24px; padding:16px 0; flex-wrap:wrap; }
.pagination a, .pagination span { display:inline-flex; align-items:center; justify-content:center; min-width:36px; height:36px; padding:0 8px; font-size:0.85rem; border-radius:var(--radius-sm); border:1px solid var(--border-color); background:var(--bg-card); color:var(--text-secondary); transition:all 0.2s; }
.pagination a:hover { color:var(--color-accent); border-color:var(--color-accent); background:#fef2f2; }
.pagination .page-current { background:var(--color-accent); color:#fff; border-color:var(--color-accent); font-weight:700; }
.pagination .page-arrow { font-weight:700; font-size:1rem; }
.no-data { text-align:center; padding:60px 20px; color:var(--text-light); font-size:1rem; background:var(--bg-card); border-radius:var(--radius); border:1px solid var(--border-color); }

/* ----------------------------------------------
   [11] 반응형 - 태블릿 (1024px 이하)
   ---------------------------------------------- */
@media screen and (max-width:1024px) {
	.listing-consultant { width:70px; padding-left:12px; }
	.consultant-photo { width:48px; height:60px; }
}

/* ----------------------------------------------
   [12] 반응형 - 모바일 (768px 이하)
   ---------------------------------------------- */
@media screen and (max-width:768px) {
	html { font-size:13px; }
	.container { padding:0 12px; }
	.mobile-menu-btn { display:block; }
	.header-nav { display:none; flex-direction:column; gap:0; padding:0 0 8px 0; border-top:1px solid rgba(255,255,255,0.1); margin-top:8px; }
	.header-nav.open { display:flex; }
	.header-nav a { border-radius:0; padding:12px 16px; border-bottom:1px solid rgba(255,255,255,0.05); font-size:0.95rem; }
	.header-util { display:none; }
	.header-util.mobile-show { display:flex; flex-wrap:wrap; padding:8px 0; border-top:1px solid rgba(255,255,255,0.1); margin-top:6px; }
	.search-row { flex-direction:column; }
	.search-select, .search-input, .search-input-wide { width:100%; min-width:auto; }
	.search-bar form { flex-direction:column; }
	.list-header { flex-direction:column; align-items:flex-start; }
	.sort-tabs { width:100%; }
	.sort-tabs a { flex:1; text-align:center; padding:8px 6px; font-size:0.8rem; }
	.listing-card-inner { flex-direction:column; padding:12px; gap:12px; }
	.listing-thumb { width:100%; height:180px; }
	.listing-consultant { flex-direction:row; width:100%; border-left:none; border-top:1px solid var(--border-color); padding-left:0; padding-top:10px; justify-content:flex-start; gap:10px; }
	.consultant-photo { width:40px; height:50px; }
	.listing-prices { gap:10px; }
	.pagination a, .pagination span { min-width:32px; height:32px; font-size:0.8rem; }
}

/* ----------------------------------------------
   [13] 반응형 - 소형 모바일 (480px 이하)
   ---------------------------------------------- */
@media screen and (max-width:480px) {
	.listing-thumb { height:150px; }
	.listing-prices { flex-direction:column; gap:4px; }
	.listing-meta { flex-direction:column; gap:4px; }
	.listing-meta .sep { display:none; }
}
