/* ============================================================
   km-admin.css — 관리자 셸(좌측 그룹 사이드바 + 상단바 + 대시보드) 전용.
   adminStyle.css 뒤에 로드. **안쪽 콘텐츠(폼/테이블/달력/검색 등)는 원본
   adminStyle.css 디자인을 그대로 유지**하고, 여기서는 셸과 대시보드만 담당한다.
   ============================================================ */
:root{
  --ad-primary:#2563eb; --ad-primary-d:#1d4ed8; --ad-primary-soft:#eaf1ff;
  --ad-ink:#1b2433; --ad-soft:#4a5566; --ad-muted:#8a94a4;
  --ad-line:#e4e8ef; --ad-line-2:#cfd6e1;
  --ad-bg:#f4f6fa; --ad-side:236px;
}

/* ── 셸 기본: 구 좌측 배경이미지 제거 + 여백 정리(폰트/콘텐츠 색은 원본 유지) ── */
body{ margin:0 !important; min-width:0 !important; background:var(--ad-bg) !important; }
/* 구 셸(상단 탭) 숨김 — 새 사이드바로 대체 */
#header{ display:none !important; }

/* ── 좌측 사이드바 ── */
#kmSide{ position:fixed; left:0; top:0; bottom:0; width:var(--ad-side); background:#fff;
  border-right:1px solid var(--ad-line); overflow-y:auto; z-index:60;
  font-family:'Pretendard Variable','Pretendard','Noto Sans KR',-apple-system,'맑은 고딕',sans-serif; }
.kmSideBrand{ padding:16px 18px; border-bottom:1px solid var(--ad-line); }
.kmSideBrand a{ display:flex; align-items:center; gap:11px; text-decoration:none; }
.kmSideBrand .bi{ width:38px; height:38px; border-radius:10px; background:linear-gradient(135deg,#2563eb,#4f8bff);
  display:flex; align-items:center; justify-content:center; color:#fff; }
.kmSideBrand .bi .kmIco{ width:22px; height:22px; }
.kmSideBrand .bt{ font-size:17px; font-weight:800; color:var(--ad-ink); line-height:1.15; }
.kmSideBrand .bt b{ display:block; font-size:11px; font-weight:600; color:var(--ad-muted); letter-spacing:.3px; }
.kmSideNav{ padding:12px 12px 40px; }
.kmSideNav .kmIco{ width:17px; height:17px; flex:none; }
.kmSideHome{ display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:9px;
  color:var(--ad-ink); font-weight:700; font-size:14px; text-decoration:none; }
.kmSideHome:hover{ background:#f1f4f9; }
.kmSideHome.on{ background:var(--ad-primary); color:#fff; }
/* 아코디언 그룹 */
.kmSideGroup{ margin-top:3px; }
.kmSideGroup .gh{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:8px;
  background:none; border:0; padding:10px 12px; border-radius:9px; cursor:pointer;
  font-size:13.5px; font-weight:700; color:var(--ad-ink); font-family:inherit; }
.kmSideGroup .gh:hover{ background:#f1f4f9; }
.kmSideGroup .gh .chv{ width:7px; height:7px; border-right:2px solid var(--ad-muted); border-bottom:2px solid var(--ad-muted);
  transform:rotate(-45deg); transition:transform .18s; flex:none; margin-right:3px; }
.kmSideGroup.open > .gh{ color:var(--ad-primary); }
.kmSideGroup.open > .gh .chv{ transform:rotate(45deg); border-color:var(--ad-primary); }
.kmSideGroup .gsub{ display:none; padding:2px 0 6px; }
.kmSideGroup.open > .gsub{ display:block; }
.kmSideGroup .gsub a{ display:flex; align-items:center; gap:9px; padding:8px 12px 8px 24px; border-radius:9px;
  color:var(--ad-soft); font-size:13px; font-weight:500; text-decoration:none; }
.kmSideGroup .gsub a:hover{ background:#f1f4f9; color:var(--ad-ink); }
.kmSideGroup .gsub a.on{ background:var(--ad-primary-soft); color:var(--ad-primary); font-weight:700; }

/* ── 메인 영역(상단바 + 콘텐츠) ── */
#kmMain{ margin-left:var(--ad-side); min-height:100vh; display:flex; flex-direction:column; }
.kmTopbar{ position:sticky; top:0; z-index:50; height:58px; background:#fff;
  border-bottom:1px solid var(--ad-line); display:flex; align-items:center; padding:0 24px; gap:14px;
  font-family:'Pretendard Variable','Pretendard','Noto Sans KR',sans-serif; }
.kmTopbar .sp{ flex:1; }
.kmSideToggle{ display:none; width:38px; height:38px; border:1px solid var(--ad-line); background:#fff;
  border-radius:8px; font-size:18px; color:var(--ad-soft); }
.kmTopUser{ display:flex; align-items:center; gap:12px; }
.kmTopUser .nm{ font-size:14px; color:var(--ad-ink); } .kmTopUser .nm b{ color:var(--ad-primary); }
.kmTopUser .lv{ font-size:12px; color:var(--ad-soft); background:#eef2f8; padding:4px 11px; border-radius:999px; }
.kmTopLogout{ height:32px; padding:0 15px; border:1px solid var(--ad-line-2); background:#fff;
  border-radius:8px; color:var(--ad-soft); font-weight:600; cursor:pointer; }
.kmTopLogout:hover{ border-color:var(--ad-primary); color:var(--ad-primary); }
.kmSideBackdrop{ display:none; }

/* 콘텐츠 영역: 셸 안에 배치만 하고 내부 디자인은 원본 유지 */
#contents{ flex:1; overflow:visible !important; }

/* ── 대시보드(새 홈) ── */
.kmDashStats{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:18px; }
.kmStatCard{ background:#fff; border:1px solid var(--ad-line); border-radius:14px; padding:20px;
  display:flex; align-items:center; gap:16px; box-shadow:0 1px 3px rgba(20,30,60,.04); }
.kmStatCard .ic{ width:52px; height:52px; border-radius:13px; display:flex; align-items:center; justify-content:center; flex:none; }
.kmStatCard .ic .kmIco{ width:26px; height:26px; }
.kmStatCard .tx .l{ margin:0 0 4px; font-size:13px; color:var(--ad-muted); }
.kmStatCard .tx .v{ margin:0; font-size:26px; font-weight:800; color:var(--ad-ink); letter-spacing:-.5px; }
.kmDashRow{ display:flex; gap:16px; margin-bottom:16px; align-items:stretch; }
.kmCard{ background:#fff; border:1px solid var(--ad-line); border-radius:14px; padding:18px 20px; box-shadow:0 1px 3px rgba(20,30,60,.04); }
.kmCardH{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.kmCardH h2{ font-size:15px; font-weight:800; color:var(--ad-ink); margin:0; }
.kmCardH span{ font-size:12px; color:var(--ad-muted); }
.kmCardH a{ font-size:12px; color:var(--ad-primary); text-decoration:none; font-weight:600; }
.kmDonutC{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; pointer-events:none; }
.kmDonutC b{ font-size:22px; font-weight:800; color:var(--ad-ink); } .kmDonutC span{ font-size:11px; color:var(--ad-muted); }
.kmLegend{ list-style:none; margin:14px 0 0; padding:0; }
.kmLegend li{ display:flex; align-items:center; gap:8px; padding:6px 0; font-size:13px; }
.kmLegend li i{ width:10px; height:10px; border-radius:3px; flex:none; }
.kmLegend li span{ color:var(--ad-soft); } .kmLegend li b{ margin-left:auto; color:var(--ad-ink); font-weight:700; }
.kmDashTbl{ width:100%; border-collapse:collapse; }
.kmDashTbl th{ text-align:left; font-size:12px; color:var(--ad-muted); font-weight:700; padding:8px 10px; border-bottom:2px solid var(--ad-line); }
.kmDashTbl td{ padding:11px 10px; border-bottom:1px solid var(--ad-line); font-size:13px; color:var(--ad-ink); }
.kmDashTbl td.subj{ font-weight:600; }
.kmDashTbl tbody tr:hover td{ background:#f8fafd; }
.kmBadge{ display:inline-block; padding:3px 11px; border-radius:999px; font-size:12px; font-weight:700; }
.kmNoticeList{ list-style:none; margin:0; padding:0; }
.kmNoticeList li{ display:flex; align-items:center; gap:10px; padding:9px 0; border-bottom:1px dashed var(--ad-line); font-size:13px; }
.kmNoticeList li:last-child{ border-bottom:0; }
.kmNoticeList .t{ flex:1; color:var(--ad-ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.kmNoticeList .d{ color:var(--ad-muted); font-size:12px; flex:none; }
.kmQuick{ display:grid; grid-template-columns:repeat(2,1fr); gap:10px; }
.kmQuick a{ display:flex; flex-direction:column; align-items:center; gap:7px; padding:16px 8px; border:1px solid var(--ad-line);
  border-radius:11px; text-decoration:none; color:var(--ad-soft); font-size:12.5px; font-weight:600; transition:.12s; }
.kmQuick a:hover{ border-color:var(--ad-primary); color:var(--ad-primary); background:#f5f8ff; }
.kmQuick a .kmIco{ width:22px; height:22px; }
/* 운영 준비 상태(온보딩) */
.kmSetupGrid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:8px; }
.kmSetupItem{ display:flex; align-items:center; gap:8px; padding:10px 12px; border:1px solid var(--ad-line);
  border-radius:9px; text-decoration:none; font-size:13px; font-weight:600; }
.kmSetupItem .ck{ width:20px; height:20px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:800; flex:none; color:#fff; }
.kmSetupItem.ok{ color:var(--ad-soft); background:#fff; } .kmSetupItem.ok .ck{ background:#22a565; }
.kmSetupItem.no{ color:#b54708; background:#fffaf2; border-color:#f4d9a8; } .kmSetupItem.no .ck{ background:#e08a00; }
.kmSetupItem.no:hover{ border-color:var(--ad-primary); }
/* 대시보드는 Pretendard로 */
.kmDashStats, .kmDashRow, #contents > h1{ font-family:'Pretendard Variable','Pretendard','Noto Sans KR',sans-serif; }
@media (max-width:1200px){ .kmDashStats{ grid-template-columns:repeat(2,1fr); } .kmDashRow{ flex-wrap:wrap; } .kmDashRow > *{ flex:1 1 100% !important; } }

/* ── 반응형: 사이드바 오프캔버스 ── */
@media (max-width:1024px){
  #kmSide{ transform:translateX(-100%); transition:transform .22s ease; }
  body.kmSideOpen #kmSide{ transform:translateX(0); }
  #kmMain{ margin-left:0; }
  .kmSideToggle{ display:inline-flex; align-items:center; justify-content:center; }
  body.kmSideOpen .kmSideBackdrop{ display:block; position:fixed; inset:0; background:rgba(15,23,42,.4); z-index:55; }
}
