/* ─── 홈 화면 (회사 대시보드) ─── */
#homeBody{padding:18px 24px 24px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:12px}

/* ── 인사 ── */
.hm-greeting{display:flex;align-items:center;gap:12px;flex-shrink:0}
.hm-greeting-left{display:flex;align-items:center;gap:12px}
.hm-av{width:42px;height:42px;border-radius:50%;background:rgba(91,107,82,0.12);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.hm-greet-text{font-size:17px;font-weight:700;color:var(--txt)}
.hm-greet-sub{font-size:12px;color:var(--txt2);margin-top:2px}

/* ── 운세 배너 ── */
.hm-fortune{display:flex;align-items:center;gap:10px;padding:7px 16px;border-left:3px solid var(--green);background:rgba(91,107,82,0.05);border-radius:0 8px 8px 0;flex-shrink:0}
.hm-fortune-label{font-size:10px;font-weight:700;color:var(--green);white-space:nowrap;flex-shrink:0}
.hm-fortune-text{font-size:12px;color:var(--txt);line-height:1.4;transition:opacity .3s}
.hm-fortune-fade{opacity:0}
.hm-fortune-setup{cursor:pointer;transition:background .12s}
.hm-fortune-setup:hover{background:rgba(91,107,82,0.1)}

/* ── KPI 스트립 (4카드 한 줄) ── */
.hm-kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;flex-shrink:0}
.hm-kpi-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:4px;transition:box-shadow .15s}
.hm-kpi-card:hover{box-shadow:0 2px 8px rgba(0,0,0,0.05)}
.hm-kpi-card-label{font-size:11px;font-weight:600;color:var(--txt2);letter-spacing:0.02em}
.hm-kpi-card-val{font-size:26px;font-weight:800;color:var(--txt);line-height:1.1;margin-top:2px;font-feature-settings:'tnum'}
.hm-kpi-card-unit{font-size:13px;font-weight:600;color:var(--txt2);margin-left:3px}
.hm-kpi-card-delta{font-size:11px;font-weight:600;color:var(--txt3);margin-top:2px;display:flex;align-items:center;gap:4px;min-height:14px}
.hm-delta-up{color:#2E7D32}
.hm-delta-down{color:#C62828}
.hm-delta-neutral{color:var(--txt3);font-weight:500}
.hm-delta-label{font-weight:500;color:var(--txt3)}
.hm-kpi-card-todo{opacity:0.65;background:repeating-linear-gradient(45deg,var(--bg),var(--bg) 10px,var(--bg2) 10px,var(--bg2) 11px)}
.hm-kpi-todo-val{font-size:24px;color:var(--txt3)!important}
.hm-masked{color:var(--txt3);font-size:22px}

/* ── 메인 그리드 (좌 2:우 1) ── */
.hm-main-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(260px,1fr);gap:14px;flex:1;min-height:0}
.hm-main-left{display:flex;flex-direction:column;gap:12px;min-width:0}

/* ── 카드 공통 ── */
.hm-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:14px 18px;display:flex;flex-direction:column;min-width:0}
.hm-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-shrink:0;gap:8px}
.hm-card-title{font-size:13px;font-weight:700;color:var(--txt);display:flex;align-items:center;gap:6px}
.hm-card-sub{font-size:10px;color:var(--txt3);font-weight:500}
.hm-card-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;background:var(--bg2);border-radius:9px;font-size:10px;font-weight:700;color:var(--txt2)}
.hm-card-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:3px 10px;font-size:11px;font-weight:600;color:var(--txt2);cursor:pointer;font-family:inherit;transition:all .12s}
.hm-card-btn:hover{background:var(--bg2);color:var(--txt)}
.hm-empty{text-align:center;padding:16px 0;font-size:12px;color:var(--txt3)}

/* ── 매출 차트 카드 ── */
.hm-chart-card{flex-shrink:0}
.hm-chart-wrap{width:100%;height:170px;display:flex;align-items:center;justify-content:center}
.hm-chart-svg{width:100%;height:100%;max-height:170px}
.hm-chart-bar{fill:var(--green);transition:fill .15s}
.hm-chart-bar:hover{fill:#4A5843}

/* ── 재고 부족 카드 ── */
.hm-lowstock-card{flex-shrink:0}
.hm-lowstock-list{display:flex;flex-direction:column;gap:4px}
.hm-lowstock-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--bg2);border-radius:7px;cursor:pointer;transition:background .12s;font-size:12px}
.hm-lowstock-item:hover{background:rgba(226,75,74,0.08)}
.hm-ls-name{flex:1;font-weight:600;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.hm-ls-code{font-size:10px;color:var(--txt3);font-family:'SF Mono',ui-monospace,monospace;flex-shrink:0}
.hm-ls-stock{font-weight:700;font-size:12px;padding:2px 10px;border-radius:10px;flex-shrink:0;font-feature-settings:'tnum'}
.hm-ls-out{background:#FCEBEB;color:#791F1F}
.hm-ls-low{background:#FAEEDA;color:#633806}
.hm-lowstock-more{text-align:center;padding:8px 0;font-size:11px;color:var(--txt3);cursor:pointer;border-radius:6px;margin-top:2px;transition:background .12s}
.hm-lowstock-more:hover{background:var(--bg2);color:var(--txt2)}

/* ── 진행중 발주 · 발행대기 명세서 (2열) ── */
.hm-pending-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;flex:1;min-height:0}
.hm-pending-card{overflow:hidden}
.hm-pending-list{display:flex;flex-direction:column;gap:6px;overflow-y:auto;min-height:0}
.hm-pending-item{padding:8px 10px;background:var(--bg2);border-radius:7px;cursor:pointer;transition:background .12s;display:flex;flex-direction:column;gap:3px}
.hm-pending-item:hover{background:rgba(91,107,82,0.08)}
.hm-pi-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.hm-pi-title{font-size:12px;font-weight:700;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}
.hm-pi-amount{font-size:12px;font-weight:700;color:var(--green);flex-shrink:0;font-feature-settings:'tnum'}
.hm-pi-bot{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:10px;color:var(--txt3)}
.hm-pi-bot span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── 공지사항 카드 (우측 전체) ── */
.hm-notice{overflow:hidden}
.hm-notice-list{flex:1;overflow-y:auto;min-height:0;display:flex;flex-direction:column}
.hm-notice-item{display:flex;align-items:flex-start;gap:8px;padding:9px 0;border-bottom:1px solid var(--border);cursor:default}
.hm-notice-item:last-child{border-bottom:none}
.hm-badge-pin{font-size:9px;font-weight:700;background:#FCEBEB;color:#791F1F;padding:2px 6px;border-radius:3px;white-space:nowrap;flex-shrink:0;margin-top:2px}
.hm-badge-new{font-size:9px;font-weight:700;background:#E6F1FB;color:#0C447C;padding:2px 6px;border-radius:3px;white-space:nowrap;flex-shrink:0;margin-top:2px}
.hm-notice-body{flex:1;min-width:0}
.hm-notice-title{font-size:12px;font-weight:600;color:var(--txt);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hm-notice-date{font-size:10px;color:var(--txt3);margin-top:1px}

/* ── 반응형 ── */
@media(max-width:1200px){
  .hm-kpi-strip{grid-template-columns:repeat(2,1fr)}
  .hm-main-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  #homeBody{padding:12px;gap:10px}
  .hm-kpi-strip{grid-template-columns:1fr 1fr}
  .hm-kpi-card-val{font-size:22px}
  .hm-pending-row{grid-template-columns:1fr}
}

/* ═════════════ 일반 사용자 홈 (레거시 3카드: 공지·캘린더·나의KPI) ═════════════ */

/* 3섹션 그리드 — 남은 공간 전부 채움 */
.hm-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:14px;flex:1;min-height:0;overflow:hidden}
.hm-grid .hm-notice{grid-column:1/2;grid-row:1/3;display:flex;flex-direction:column;overflow:hidden}
.hm-grid .hm-cal{grid-column:2/3;grid-row:1/2;overflow:hidden}
.hm-grid .hm-kpi{grid-column:2/3;grid-row:2/3;overflow:hidden}

/* 캘린더 — 컴팩트 */
.hm-cal-month{font-size:13px;font-weight:700;color:var(--txt);text-align:center;margin-bottom:8px}
.hm-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;gap:2px}
.hm-cal-head{font-size:10px;color:var(--txt3);padding:3px 0;font-weight:600}
.hm-cal-sun{color:#A32D2D!important}
.hm-cal-sat{color:#185FA5!important}
.hm-cal-day{font-size:12px;padding:5px 0;border-radius:6px;color:var(--txt2);position:relative}
.hm-cal-today{background:rgba(91,107,82,0.15);color:var(--green)!important;font-weight:700}
.hm-cal-event::after{content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--green)}
.hm-cal-schedule{margin-top:8px;border-top:1px solid var(--border);padding-top:6px;display:flex;flex-direction:column;gap:4px}
.hm-cal-sch-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--txt2);line-height:1.3}
.hm-cal-sch-dot{width:5px;height:5px;border-radius:50%;background:var(--green);flex-shrink:0;opacity:0.7}
.hm-cal-sch-today{opacity:1;background:var(--green);box-shadow:0 0 0 2px rgba(91,107,82,0.2)}
.hm-cal-sch-date{font-weight:600;color:var(--txt);min-width:46px;font-size:10px}
.hm-cal-sch-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hm-cal-sch-empty{font-size:11px;color:var(--txt3);text-align:center;padding:3px 0}

/* 나의 KPI — 컴팩트 */
.hm-kpi-cards{display:flex;gap:8px;margin-bottom:10px}
.hm-kpi-box{flex:1;background:var(--bg2);border-radius:8px;padding:8px 8px;text-align:center}
.hm-kpi-label{font-size:10px;color:var(--txt3);margin-bottom:3px}
.hm-kpi-val{font-size:22px;font-weight:700}
.hm-kpi-green{color:#3B6D11}
.hm-kpi-amber{color:#854F0B}
.hm-kpi-red{color:#A32D2D}
.hm-kpi-bar-wrap{margin-bottom:6px}
.hm-kpi-bar-label{display:flex;justify-content:space-between;font-size:11px;color:var(--txt2);margin-bottom:3px}
.hm-kpi-bar{height:6px;background:var(--bg2);border-radius:3px;overflow:hidden}
.hm-kpi-bar-fill{height:100%;border-radius:3px;background:var(--green);transition:width .3s}

@media(max-width:768px){
  .hm-grid{grid-template-columns:1fr;grid-template-rows:auto;overflow-y:auto}
  .hm-grid .hm-notice,.hm-grid .hm-cal,.hm-grid .hm-kpi{grid-column:1;grid-row:auto}
}
