/* =========================================
   해오름 관리자 패널 - admin.css
   프론트 CSS 와 완전 분리
   ========================================= */
:root {
    --sidebar-bg: #1e2a3b;
    --sidebar-text: #94a3b8;
    --sidebar-active: #3b82f6;
    --primary: #2563eb;
    --primary-h: #1d4ed8;
    --success: #16a34a;
    --danger: #dc2626;
    --warning: #d97706;
    --g50: #f8fafc;
    --g100: #f1f5f9;
    --g200: #e2e8f0;
    --g300: #cbd5e1;
    --g400: #94a3b8;
    --g500: #64748b;
    --g600: #475569;
    --g700: #334155;
    --g800: #1e293b;
    --shadow: 0 1px 4px rgba(0,0,0,.08), 0 2px 8px rgba(0,0,0,.05);
    --radius: 8px;
    --sidebar-w: 220px;
    --topbar-h: 58px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,'Pretendard','Apple SD Gothic Neo',sans-serif;font-size:14px;color:var(--g800);background:var(--g100)}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Sidebar ── */
.admin-wrap{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;overflow:hidden}
.sidebar-brand{padding:18px 16px;display:flex;align-items:center;gap:9px;color:#fff;font-size:15px;font-weight:700;border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0}
.brand-icon{font-size:22px;line-height:1}
.sidebar-nav{flex:1;padding:6px 0;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;color:var(--sidebar-text);text-decoration:none;font-size:13.5px;transition:background .13s,color .13s;white-space:nowrap}
.nav-item:hover{background:rgba(255,255,255,.08);color:#fff;text-decoration:none}
.nav-item.active{background:var(--sidebar-active);color:#fff}
.nav-icon{width:16px;text-align:center;flex-shrink:0;font-style:normal}
.nav-divider{border-top:1px solid rgba(255,255,255,.07);margin:6px 0}
.nav-logout{color:#f87171}
.nav-logout:hover{background:rgba(248,113,113,.12);color:#f87171}
.sidebar-footer{padding:12px 20px;color:var(--g500);font-size:11px;border-top:1px solid rgba(255,255,255,.07);flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── Main layout ── */
.main-wrap{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-height:100vh}
.top-bar{background:#fff;height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;padding:0 24px;border-bottom:1px solid var(--g200);position:sticky;top:0;z-index:50;flex-shrink:0}
.page-title{font-size:17px;font-weight:600;color:var(--g800)}
.top-user{font-size:12px;color:var(--g500)}
.content{padding:22px 24px;flex:1}

/* ── Cards ── */
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:20px}
.card-header{padding:14px 20px;border-bottom:1px solid var(--g200);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-title{font-size:14px;font-weight:600;color:var(--g800)}
.card-body{padding:20px}

/* ── Stats ── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.stat-card{background:#fff;border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}
.stat-label{font-size:11px;color:var(--g500);margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.stat-value{font-size:30px;font-weight:700;color:var(--g800);line-height:1}
.stat-card.highlight{background:var(--primary)}
.stat-card.highlight .stat-label,.stat-card.highlight .stat-value{color:#fff}

/* ── Tables ── */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{background:var(--g50);padding:9px 12px;text-align:left;font-size:11px;font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--g200);white-space:nowrap}
td{padding:11px 12px;border-bottom:1px solid var(--g100);font-size:13.5px;color:var(--g700);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--g50)}

/* ── Badges ── */
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.badge-new{background:#dbeafe;color:#1d4ed8}
.badge-contacted{background:#fef3c7;color:#92400e}
.badge-confirmed{background:#dcfce7;color:#166534}
.badge-done{background:var(--g200);color:var(--g500)}
.badge-cancelled{background:#fee2e2;color:#991b1b}
.badge-active{background:#dcfce7;color:#166534}
.badge-inactive{background:#fee2e2;color:#991b1b}
.badge-pinned{background:#fef3c7;color:#92400e}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:7px 15px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;border:none;text-decoration:none;transition:background .13s,box-shadow .13s;white-space:nowrap;line-height:1.4}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-h);color:#fff}
.btn-secondary{background:#fff;color:var(--g700);border:1px solid var(--g300)}
.btn-secondary:hover{background:var(--g50);color:var(--g700)}
.btn-success{background:var(--success);color:#fff}
.btn-success:hover{background:#15803d;color:#fff}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:#b91c1c;color:#fff}
.btn-warning{background:var(--warning);color:#fff}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-xs{padding:3px 7px;font-size:11px}
.w-full{width:100%;display:flex}

/* ── Forms ── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:14px}
.form-group.full{grid-column:1/-1}
label{display:block;font-size:12px;font-weight:600;color:var(--g600);margin-bottom:5px}
input[type=text],input[type=number],input[type=date],input[type=email],input[type=password],textarea,select{width:100%;padding:8px 11px;border:1px solid var(--g300);border-radius:6px;font-size:13.5px;color:var(--g800);outline:none;background:#fff;transition:border-color .13s;font-family:inherit}
input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
textarea{resize:vertical;min-height:90px;line-height:1.6}
.form-hint{font-size:11px;color:var(--g400);margin-top:4px;line-height:1.4}
.form-actions{margin-top:20px;display:flex;gap:8px;flex-wrap:wrap}
.form-check{display:flex;align-items:center;gap:7px;font-size:13.5px;cursor:pointer}
.form-check input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--primary)}

/* ── Alerts ── */
.alert{padding:11px 15px;border-radius:var(--radius);margin-bottom:16px;font-size:13.5px;border-width:1px;border-style:solid}
.alert-error{background:#fee2e2;color:#991b1b;border-color:#fca5a5}
.alert-success{background:#dcfce7;color:#166534;border-color:#86efac}
.alert-info{background:#dbeafe;color:#1e40af;border-color:#93c5fd}

/* ── Filter bar ── */
.filter-bar{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.filter-bar select,.filter-bar input{width:auto}

/* ── Image previews ── */
.thumb-preview{width:80px;height:60px;object-fit:cover;border-radius:4px;border:1px solid var(--g200);display:block}
.img-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.img-item{position:relative;display:inline-block}
.img-item img{width:80px;height:60px;object-fit:cover;border-radius:4px;border:1px solid var(--g200);display:block}

/* ── Inquiry detail ── */
.inq-info{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.inq-field{background:var(--g50);border-radius:6px;padding:11px 13px}
.inq-field .lbl{font-size:11px;color:var(--g500);margin-bottom:3px;font-weight:600;text-transform:uppercase}
.inq-field .val{font-size:14px;color:var(--g800)}
.inq-msg{background:var(--g50);border-radius:6px;padding:14px;font-size:13.5px;color:var(--g700);line-height:1.7;white-space:pre-wrap;word-break:break-word}

/* ── Gallery grid ── */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.gallery-item{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.gallery-item img{width:100%;height:120px;object-fit:cover;display:block}
.gallery-item-footer{padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:6px}
.gallery-item-title{font-size:12px;color:var(--g600);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}

/* ── Breadcrumb ── */
.breadcrumb{display:flex;gap:6px;align-items:center;margin-bottom:16px;font-size:13px;color:var(--g500)}
.breadcrumb a{color:var(--primary)}
.breadcrumb-sep{color:var(--g300)}

/* ── Utilities ── */
.text-right{text-align:right}
.text-center{text-align:center}
.text-muted{color:var(--g400)}
.d-flex{display:flex}
.align-center{align-items:center}
.gap-1{gap:8px}
.gap-2{gap:14px}
.mt-1{margin-top:8px}
.mt-2{margin-top:16px}
.mb-1{margin-bottom:8px}
.nowrap{white-space:nowrap}
.flex-1{flex:1}

/* ── Settings table ── */
.settings-key{font-family:monospace;font-size:12px;background:var(--g100);padding:4px 7px;border-radius:4px;color:var(--g600)}

/* ── Login page ── */
.login-page{background:var(--g100)}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-box{background:#fff;border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.12);padding:40px;width:100%;max-width:400px}
.login-header{text-align:center;margin-bottom:28px}
.login-logo{font-size:42px;line-height:1;margin-bottom:12px}
.login-header h1{font-size:21px;font-weight:700;color:var(--g800);margin-bottom:4px}
.login-header p{font-size:13px;color:var(--g500)}
.login-box .btn{margin-top:4px}

/* 이미지 삭제 체크박스 */
.img-item { position: relative; display: inline-block; }
.img-item .img-del { display: block; font-size: 12px; color: #c0392b; margin-top: 4px; cursor: pointer; }

/* top-bar 우측 액션 */
.top-actions { display: flex; align-items: center; gap: 14px; }
.btn-sm { padding: 7px 14px; font-size: 13px; }

/* ── 예약현황 관리 캘린더 (itm/calendar.php) ───────── */
.adm-cal-toolbar { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 18px; }
.adm-cal-toolbar .form-group select { min-width: 200px; }
.adm-cal-monthnav { display: flex; align-items: center; gap: 14px; }
.adm-cal-monthnav strong { font-size: 16px; color: var(--g800); min-width: 120px; text-align: center; }

.adm-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
}
.adm-cal-cellform { margin: 0; display: block; }
.adm-cal-cell.dow {
  text-align: center;
  font-weight: 700;
  color: var(--g500);
  padding: 4px 0;
}
.adm-cal-cell.empty { border: none; background: transparent; min-height: 0; }
button.adm-cal-cell {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  min-height: 64px;
  padding: 8px;
  border: 1px solid var(--g200);
  border-radius: 8px;
  background: #fff;
  cursor: pointer;
  font: inherit;
  transition: filter .15s, box-shadow .15s;
}
button.adm-cal-cell:hover { box-shadow: 0 2px 8px rgba(0,0,0,.12); filter: brightness(.98); }
.adm-cal-date { font-size: 14px; font-weight: 600; color: var(--g800); }
.adm-cal-state { font-size: 11px; font-weight: 600; }
button.adm-cal-cell.open { background: #f1f8f0; border-color: #cfe6cb; }
button.adm-cal-cell.open .adm-cal-state { color: #3f8c43; }
button.adm-cal-cell.booked { background: #faecec; border-color: #e3b6b6; }
button.adm-cal-cell.booked .adm-cal-state { color: #c0392b; }
button.adm-cal-cell.hold { background: #fdf6e3; border-color: #ecd9a3; }
button.adm-cal-cell.hold .adm-cal-state { color: #b8860b; }
button.adm-cal-cell.past { opacity: .55; }

.adm-cal-legend {
  display: inline-block;
  padding: 2px 10px;
  margin-right: 6px;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 600;
}
.adm-cal-legend.open { background: #f1f8f0; color: #3f8c43; }
.adm-cal-legend.booked { background: #faecec; color: #c0392b; }
.adm-cal-legend.hold { background: #fdf6e3; color: #b8860b; }

@media (max-width: 600px) {
  .adm-cal-grid { gap: 4px; }
  button.adm-cal-cell { min-height: 50px; padding: 5px; border-radius: 6px; }
  .adm-cal-date { font-size: 12px; }
  .adm-cal-state { font-size: 10px; }
  .adm-cal-toolbar { gap: 12px; }
}

/* ── 예약현황 관리 v2: 날짜 칸 안에 전체 객실 (bookings.php) ── */
.adm-bk-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
}
.adm-bk-cell {
  border: 1px solid var(--g200, #e2e0dc);
  border-radius: 8px;
  padding: 6px 5px;
  background: #fff;
}
.adm-bk-cell.dow {
  border: none;
  background: transparent;
  text-align: center;
  font-weight: 700;
  color: var(--g600, #777);
  padding: 4px 0;
}
.adm-bk-cell.empty { border: none; background: transparent; }
.adm-bk-cell.past { background: #f5f4f1; }
.adm-bk-cell.past .adm-bk-date { color: #b6b2aa; }
.adm-bk-date { display: block; font-size: 13px; font-weight: 700; color: var(--g800, #333); margin-bottom: 4px; }
.adm-bk-form { margin: 0 0 3px; display: block; }
.adm-bk-rm {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
  padding: 1px 0;
  font-size: 11.5px;
  line-height: 1.5;
  white-space: nowrap;
  color: var(--g700, #555);
}
.adm-bk-rm .adm-bk-name {
  display: flex;
  align-items: baseline;
  gap: 4px;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}
.adm-bk-rm.done { opacity: .65; }
.adm-bk-rm.done .adm-bk-name { color: #a09a91; }
.adm-bk-rm .nm-short { display: none; }
.adm-bk-memo {
  font-style: normal;
  font-size: 10px;
  color: #a5705f;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
/* 상태 필 뱃지 = 토글 버튼 */
.bk-badge {
  display: inline-block;
  flex-shrink: 0;
  padding: 2px 10px;
  border: none;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: .03em;
  color: #fff;
}
.bk-badge.open { background: #3d4a3a; }   /* 솔잎그린(사이트 --pine) */
.bk-badge.done { background: #96685a; }   /* 차분한 적갈 */
button.bk-badge { cursor: pointer; transition: filter .15s, box-shadow .15s; }
button.bk-badge:hover { filter: brightness(1.18); box-shadow: 0 1px 5px rgba(0,0,0,.25); }

@media (max-width: 1000px) and (min-width: 769px) {
  .adm-bk-grid { gap: 4px; }
  .adm-bk-rm { font-size: 10.5px; }
  .adm-bk-rm .nm-full { display: none; }
  .adm-bk-rm .nm-short { display: inline; }
  .adm-bk-memo { display: none; }
  .bk-badge { padding: 1px 7px; font-size: 10px; }
}
@media (max-width: 768px) {
  .adm-bk-grid { display: block; }
  /* 오늘 이후 날짜만 세로 리스트로 — 과거 정정은 데스크톱에서 */
  .adm-bk-cell.dow, .adm-bk-cell.empty, .adm-bk-cell.past { display: none; }
  .adm-bk-cell { margin-bottom: 12px; padding: 10px 14px; }
  .adm-bk-date { font-size: 15px; margin-bottom: 6px; }
  .adm-bk-form { margin: 0; }
  .adm-bk-rm { font-size: 14px; padding: 5px 0; border-top: 1px dashed var(--g200, #e2e0dc); }
  .adm-bk-form:first-of-type .adm-bk-rm { border-top: none; }
  /* 터치 영역 확보 */
  button.bk-badge { min-height: 32px; min-width: 64px; padding: 5px 16px; font-size: 13px; }
}

/* ── 어드민 공통 레이아웃 모바일 대응 (사이드바 → 상단 가로스크롤 메뉴) ── */
@media (max-width: 768px) {
  .admin-wrap { display: block; }
  .sidebar {
    position: static;
    width: 100%;
    height: auto;
    overflow: visible;
  }
  .sidebar-brand { padding: 12px 16px; font-size: 14px; }
  .sidebar-nav {
    display: flex;
    padding: 0 8px 10px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .nav-item { flex-shrink: 0; padding: 9px 13px; font-size: 13px; border-radius: 6px; }
  .nav-divider { display: none; }
  .sidebar-footer { display: none; }
  .main-wrap { margin-left: 0; }
  .top-bar { padding: 0 14px; height: auto; min-height: 48px; }
  .page-title { font-size: 15px; }
  .content { padding: 14px 12px; }
  .card-body { padding: 14px; }
  .form-grid { grid-template-columns: 1fr; }
  .adm-cal-monthnav strong { min-width: 100px; font-size: 15px; }
}

/* ── 스토리 편집 ── */
.story-thumb-preview{max-width:360px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--g200);background:#fff}
.story-thumb-preview img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.story-edit-msg{display:block;margin-top:8px;font-size:12.5px;color:var(--g500);word-break:break-all}
.story-asset-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.story-asset{display:flex;align-items:center;gap:8px;border:1px solid var(--g200);background:#fff;border-radius:var(--radius);padding:6px 10px 6px 6px;cursor:pointer;font-size:12px;color:var(--g600);max-width:100%}
.story-asset img{width:44px;height:34px;object-fit:cover;border-radius:4px;flex-shrink:0}
.story-asset span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:260px}
.story-asset.is-selected{border-color:var(--primary);box-shadow:0 0 0 2px rgba(37,99,235,.15)}
.story-asset-empty{font-size:12.5px;color:var(--g400);padding:4px 0}
