/* ============================================================
    만나관리 V7 — 운영 대시보드 스타일 (Phase 4)
    Scope: .page-dashboard 내부에만 적용
    ============================================================ */

.page-dashboard *, .page-dashboard *::before, .page-dashboard *::after { box-sizing: border-box; }
.page-dashboard { font-family: var(--font-family); font-size: var(--font-size-base); line-height: 1.5; color: var(--color-text-primary); background: var(--color-bg); word-break: keep-all; min-height: 100vh; }
.page-dashboard a { color: inherit; text-decoration: none; }
.page-dashboard button { font-family: inherit; cursor: pointer; border: none; background: none; }
.page-dashboard input, .page-dashboard select, .page-dashboard textarea { font-family: inherit; font-size: inherit; }
.page-dashboard .layout { display: flex; min-height: 100vh; }
.page-dashboard .sidebar { width: var(--sidebar-w); background: var(--color-sidebar-bg); color: var(--color-sidebar-text); flex-shrink: 0; display: flex; flex-direction: column; position: sticky; top: 0; height: 100vh; box-shadow: var(--shadow-md); z-index: 10; }
.page-dashboard .main { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.page-dashboard .sidebar-head { padding: var(--space-5) var(--space-4) var(--space-3); display: flex; align-items: center; gap: var(--space-3); }
.page-dashboard .seal { width: 36px; height: 36px; background: var(--color-primary); color: #FFF; font-weight: 700; font-size: 15px; display: grid; place-items: center; border-radius: var(--radius-sm); box-shadow: 0 2px 4px rgba(0,0,0,0.15); }
.page-dashboard .brand-name { font-size: var(--font-size-lg); font-weight: 700; letter-spacing: -0.3px; }
.page-dashboard .brand-sub { font-size: 10px; letter-spacing: 1px; color: var(--color-sidebar-text-muted); margin-top: 2px; }
.page-dashboard .admin-tag { margin: 0 var(--space-4) var(--space-3); display: inline-flex; align-items: center; gap: var(--space-2); padding: 4px var(--space-3); background: rgba(201, 123, 90, 0.18); color: #E5A98A; font-size: var(--font-size-xs); font-weight: 500; border-radius: var(--radius-full); width: fit-content; }
.page-dashboard .admin-tag .ver { color: var(--color-sidebar-text-muted); margin-left: auto; padding-left: var(--space-2); border-left: 1px solid rgba(255,255,255,0.15); }
.page-dashboard .menu-search { margin: 0 var(--space-4) var(--space-4); display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-3); background: rgba(255,255,255,0.06); border-radius: var(--radius-md); border: 1px solid rgba(255,255,255,0.10); }
.page-dashboard .menu-search input { flex: 1; background: transparent; border: none; color: inherit; outline: none; font-size: var(--font-size-sm); }
.page-dashboard .menu-search input::placeholder { color: var(--color-sidebar-text-muted); }
.page-dashboard .menu-search .kbd { font-size: 10px; color: var(--color-sidebar-text-muted); border: 1px solid rgba(255,255,255,0.15); padding: 1px 5px; border-radius: 3px; }
.page-dashboard .nav { flex: 1; overflow-y: auto; padding: 0 var(--space-3) var(--space-4); }
.page-dashboard .nav-section-label { font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--color-sidebar-section-label); padding: var(--space-4) var(--space-3) var(--space-2); font-weight: 600; }
.page-dashboard .nav-group { margin-bottom: 2px; }
.page-dashboard .nav-group-head { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-3); border-radius: var(--radius-md); font-size: var(--font-size-sm); font-weight: 500; cursor: pointer; transition: background 0.15s; }
.page-dashboard .nav-group-head:hover { background: var(--color-sidebar-active-bg); }
.page-dashboard .nav-group-head .dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.page-dashboard .dot-orange { background: #C97B5A; } .page-dashboard .dot-blue { background: #6FA8C9; } .page-dashboard .dot-gray { background: #B0AEA8; } .page-dashboard .dot-green { background: #9CAE85; } .page-dashboard .dot-gold { background: #D4A95A; } .page-dashboard .dot-brown { background: #8B6F4F; } .page-dashboard .dot-gear { background: rgba(255,255,255,0.6); }
.page-dashboard .nav-group-head .label { flex: 1; }
.page-dashboard .nav-group-head .chev { font-size: 10px; color: var(--color-sidebar-text-muted); }
.page-dashboard .nav-group-head .badge { background: var(--color-primary); color: #FFF; font-size: 10px; font-weight: 600; padding: 1px 6px; border-radius: var(--radius-full); }
.page-dashboard .nav-sub { display: none; padding: var(--space-1) 0 var(--space-2); }
.page-dashboard .nav-group.open .nav-sub { display: block; }
.page-dashboard .nav-sub-item { display: flex; align-items: center; justify-content: space-between; padding: var(--space-2) var(--space-3) var(--space-2) calc(var(--space-3) + 20px); font-size: var(--font-size-sm); color: var(--color-sidebar-text-muted); border-radius: var(--radius-md); margin: 1px 0; cursor: pointer; transition: background 0.15s, color 0.15s; }
.page-dashboard .nav-sub-item:hover { background: var(--color-sidebar-active-bg); color: var(--color-sidebar-text); }
.page-dashboard .nav-sub-item.active { background: var(--color-sidebar-active-bg); color: var(--color-sidebar-text); font-weight: 600; border-left: 2px solid var(--color-primary); padding-left: calc(var(--space-3) + 18px); }
.page-dashboard .nav-sub-item .badge { background: var(--color-primary); color: #FFF; font-size: 10px; font-weight: 600; padding: 1px 6px; border-radius: var(--radius-full); }
.page-dashboard .nav-flat { padding: var(--space-2) 0; }
.page-dashboard .nav-flat-item { display: flex; align-items: center; justify-content: space-between; padding: var(--space-2) var(--space-3); font-size: var(--font-size-sm); color: var(--color-sidebar-text-muted); border-radius: var(--radius-md); cursor: pointer; margin: 1px 0; transition: background 0.15s, color 0.15s; }
.page-dashboard .nav-flat-item:hover { background: var(--color-sidebar-active-bg); color: var(--color-sidebar-text); }
.page-dashboard .nav-flat-item.active { background: var(--color-sidebar-active-bg); color: var(--color-sidebar-text); font-weight: 600; border-left: 2px solid var(--color-primary); padding-left: calc(var(--space-3) - 2px); }
.page-dashboard .nav-flat-item .pill { background: rgba(212, 169, 90, 0.25); color: #E8C58A; font-size: 10px; font-weight: 600; padding: 1px 6px; border-radius: var(--radius-full); }
.page-dashboard .sidebar-foot { padding: var(--space-4); margin-top: auto; background: rgba(0,0,0,0.15); border-top: 1px solid rgba(255,255,255,0.06); }
.page-dashboard .clock-time { font-size: var(--font-size-xl); font-weight: 700; letter-spacing: -0.3px; }
.page-dashboard .clock-date { font-size: var(--font-size-xs); color: var(--color-sidebar-text-muted); margin-top: 2px; }
.page-dashboard .grain-row { display: flex; gap: 4px; margin: var(--space-3) 0 var(--space-2); opacity: 0.5; }
.page-dashboard .mood-quote { font-size: var(--font-size-xs); color: var(--color-sidebar-text-muted); font-style: italic; line-height: 1.5; }
.page-dashboard .topbar { height: var(--topbar-h); background: var(--color-card-bg); border-bottom: 1px solid var(--color-border); display: flex; align-items: center; justify-content: space-between; padding: 0 var(--space-6); position: sticky; top: 0; z-index: 5; }
.page-dashboard .topbar-title { font-size: var(--font-size-2xl); font-weight: 700; letter-spacing: -0.5px; }
.page-dashboard .topbar-sub { font-size: var(--font-size-sm); color: var(--color-text-muted); margin-top: 2px; }
.page-dashboard .topbar-right { display: flex; align-items: center; gap: var(--space-4); }
.page-dashboard .global-search { display: flex; align-items: center; gap: var(--space-2); background: var(--color-bg); padding: var(--space-2) var(--space-3); border-radius: var(--radius-md); border: 1px solid var(--color-border); min-width: 320px; }
.page-dashboard .global-search input { flex: 1; background: transparent; border: none; outline: none; font-size: var(--font-size-sm); }
.page-dashboard .icon-btn { width: 38px; height: 38px; display: grid; place-items: center; border-radius: var(--radius-md); background: var(--color-bg); position: relative; transition: background 0.15s; }
.page-dashboard .icon-btn:hover { background: rgba(201,123,90,0.10); }
.page-dashboard .icon-btn .red-dot { position: absolute; top: 8px; right: 8px; width: 7px; height: 7px; background: var(--color-primary); border-radius: 50%; border: 1.5px solid #FFF; }
.page-dashboard .user-pill { display: flex; align-items: center; gap: var(--space-3); padding: 4px var(--space-3) 4px 4px; border-radius: var(--radius-full); border: 1px solid var(--color-border); }
.page-dashboard .avatar { width: 32px; height: 32px; background: var(--color-primary); color: #FFF; display: grid; place-items: center; border-radius: 50%; font-weight: 700; font-size: var(--font-size-sm); }
.page-dashboard .user-name { font-size: var(--font-size-sm); font-weight: 600; }
.page-dashboard .user-role { font-size: 11px; color: var(--color-text-muted); }
.page-dashboard .content { flex: 1; padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-5); }
.page-dashboard .row { display: grid; gap: var(--space-5); }
.page-dashboard .row-kpi { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.page-dashboard .row-7-3 { grid-template-columns: 7fr 3fr; }
.page-dashboard .row-1-1 { grid-template-columns: 1fr 1fr; }
.page-dashboard .kpi-card { background: var(--color-card-bg); border-radius: var(--radius-lg); padding: var(--space-5); box-shadow: var(--shadow-md); border: 1px solid var(--color-card-border); position: relative; overflow: hidden; transition: transform 0.15s, box-shadow 0.15s; }
.page-dashboard .kpi-card:hover { transform: translateY(-1px); box-shadow: var(--shadow-lg); }
.page-dashboard .kpi-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--accent, var(--color-primary)); }
.page-dashboard .kpi-card.acc-orange { --accent: #C97B5A; } .page-dashboard .kpi-card.acc-sage { --accent: #9CAE85; } .page-dashboard .kpi-card.acc-terracotta { --accent: #C97B5A; } .page-dashboard .kpi-card.acc-gold { --accent: #D4A95A; } .page-dashboard .kpi-card.acc-wheat { --accent: #B8966B; }
.page-dashboard .kpi-icon-wrap { display: flex; align-items: center; gap: var(--space-2); font-size: var(--font-size-sm); color: var(--color-text-secondary); margin-bottom: var(--space-3); }
.page-dashboard .kpi-icon { width: 16px; height: 16px; color: var(--accent, var(--color-primary)); }
.page-dashboard .kpi-num { font-size: var(--font-size-kpi); font-weight: 700; line-height: 1.1; letter-spacing: -1px; }
.page-dashboard .kpi-num .unit { font-size: var(--font-size-base); font-weight: 500; color: var(--color-text-secondary); margin-left: 4px; }
.page-dashboard .kpi-foot { display: flex; align-items: center; justify-content: space-between; margin-top: var(--space-3); font-size: var(--font-size-sm); color: var(--color-text-muted); }
.page-dashboard .panel { background: var(--color-card-bg); border-radius: var(--radius-lg); padding: var(--space-5); box-shadow: var(--shadow-md); border: 1px solid var(--color-card-border); }
.page-dashboard .panel-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-4); }
.page-dashboard .panel-title { font-size: var(--font-size-lg); font-weight: 700; letter-spacing: -0.3px; }
.page-dashboard .panel-title small { font-size: var(--font-size-sm); font-weight: 500; color: var(--color-text-muted); margin-left: var(--space-2); }
.page-dashboard .panel-link { font-size: var(--font-size-sm); color: var(--color-primary); font-weight: 500; }
.page-dashboard .toggle-pill { display: inline-flex; gap: 2px; background: var(--color-bg); padding: 3px; border-radius: var(--radius-full); font-size: var(--font-size-xs); font-weight: 600; }
.page-dashboard .toggle-pill button { padding: 4px var(--space-3); border-radius: var(--radius-full); color: var(--color-text-muted); }
.page-dashboard .toggle-pill button.on { background: var(--color-primary); color: #FFF; }
.page-dashboard .chart-svg { width: 100%; height: 280px; display: block; }
.page-dashboard .chart-legend { display: flex; gap: var(--space-4); margin-top: var(--space-3); font-size: var(--font-size-xs); color: var(--color-text-secondary); }
.page-dashboard .legend-item { display: inline-flex; align-items: center; gap: var(--space-2); }
.page-dashboard .legend-swatch { width: 10px; height: 10px; border-radius: 2px; }
.page-dashboard .legend-line { width: 16px; height: 2px; border-radius: 2px; }
.page-dashboard .alert-list { display: flex; flex-direction: column; gap: var(--space-3); }
.page-dashboard .alert-item { display: flex; gap: var(--space-3); padding: var(--space-3); background: var(--color-bg); border-radius: var(--radius-md); border-left: 3px solid var(--alert-color, var(--color-primary)); }
.page-dashboard .alert-item.danger { --alert-color: var(--color-primary); } .page-dashboard .alert-item.warning { --alert-color: var(--color-warning); } .page-dashboard .alert-item.info { --alert-color: var(--color-info); }
.page-dashboard .alert-icon { width: 32px; height: 32px; background: var(--alert-color); color: #FFF; border-radius: var(--radius-md); display: grid; place-items: center; flex-shrink: 0; font-size: 14px; }
.page-dashboard .alert-body .title { font-size: var(--font-size-sm); font-weight: 600; line-height: 1.4; }
.page-dashboard .alert-body .meta { font-size: var(--font-size-xs); color: var(--color-text-muted); margin-top: 2px; }
.page-dashboard .top5-list { display: flex; flex-direction: column; gap: var(--space-3); }
.page-dashboard .top5-row { display: grid; grid-template-columns: 32px 1fr 1fr auto; gap: var(--space-3); align-items: center; }
.page-dashboard .rank-circle { width: 28px; height: 28px; border-radius: 50%; background: var(--color-bg); border: 1.5px solid var(--rank-color, var(--color-primary)); color: var(--rank-color, var(--color-primary)); display: grid; place-items: center; font-weight: 700; font-size: var(--font-size-sm); }
.page-dashboard .top5-row.r1 { --rank-color: #C97B5A; } .page-dashboard .top5-row.r2 { --rank-color: #9CAE85; } .page-dashboard .top5-row.r3 { --rank-color: #D4A95A; } .page-dashboard .top5-row.r4 { --rank-color: #B8966B; } .page-dashboard .top5-row.r5 { --rank-color: #888888; }
.page-dashboard .top5-name { font-size: var(--font-size-sm); font-weight: 500; }
.page-dashboard .top5-bar { height: 8px; background: var(--color-bg); border-radius: var(--radius-full); overflow: hidden; position: relative; }
.page-dashboard .top5-bar > span { display: block; height: 100%; background: var(--rank-color, var(--color-primary)); border-radius: var(--radius-full); }
.page-dashboard .top5-amount { font-size: var(--font-size-sm); font-weight: 700; text-align: right; min-width: 80px; }
.page-dashboard .shipments-table { width: 100%; border-collapse: collapse; font-size: var(--font-size-sm); }
.page-dashboard .shipments-table thead th { text-align: left; padding: var(--space-2) var(--space-3); font-size: var(--font-size-xs); font-weight: 500; color: var(--color-text-muted); border-bottom: 1px solid var(--color-border); }
.page-dashboard .shipments-table tbody tr { transition: background 0.1s; }
.page-dashboard .shipments-table tbody tr:hover { background: var(--color-bg); }
.page-dashboard .shipments-table td { padding: var(--space-3); vertical-align: middle; border-bottom: 1px solid rgba(0,0,0,0.04); }
.page-dashboard .shipments-table .num { text-align: right; font-weight: 600; }
.page-dashboard .badge { display: inline-flex; align-items: center; gap: 4px; font-size: var(--font-size-xs); font-weight: 600; padding: 3px 10px; border-radius: var(--radius-full); }
.page-dashboard .badge.done { background: var(--color-status-done-bg); color: var(--color-status-done-text); }
.page-dashboard .badge.progress { background: var(--color-status-progress-bg); color: var(--color-status-progress-text); }
.page-dashboard .badge.pending { background: var(--color-status-pending-bg); color: var(--color-status-pending-text); }
.page-dashboard .badge.hold { background: var(--color-status-hold-bg); color: var(--color-status-hold-text); }
.page-dashboard .fab { position: fixed; right: var(--space-6); bottom: var(--space-6); width: 64px; height: 64px; background: var(--color-primary); color: #FFF; border-radius: 50%; font-size: 30px; font-weight: 300; line-height: 1; box-shadow: var(--shadow-lg); z-index: 50; transition: transform 0.15s, background 0.15s; }
.page-dashboard .fab:hover { transform: translateY(-2px); background: var(--color-primary-hover); }
.page-dashboard .sheet-backdrop { position: fixed; inset: 0; background: var(--color-overlay); z-index: 100; display: none; }
.page-dashboard .sheet-backdrop.open { display: block; }
.page-dashboard .sheet { position: fixed; left: 0; right: 0; bottom: 0; background: var(--color-card-bg); border-top-left-radius: var(--radius-lg); border-top-right-radius: var(--radius-lg); z-index: 101; transform: translateY(100%); transition: transform 0.25s ease-out; max-width: 640px; margin: 0 auto; box-shadow: 0 -8px 32px rgba(0,0,0,0.15); display: flex; flex-direction: column; max-height: 80vh; }
.page-dashboard .sheet.open { transform: translateY(0); }
.page-dashboard .sheet-head { padding: var(--space-4) var(--space-5); display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--color-border); }
.page-dashboard .sheet-title { font-size: var(--font-size-lg); font-weight: 700; }
.page-dashboard .sheet-close { width: 32px; height: 32px; border-radius: 50%; font-size: 18px; color: var(--color-text-muted); }
.page-dashboard .sheet-close:hover { background: var(--color-bg); }
.page-dashboard .sheet-tabs { display: flex; gap: var(--space-2); padding: var(--space-3) var(--space-5); border-bottom: 1px solid var(--color-border); }
.page-dashboard .sheet-tab { padding: var(--space-2) var(--space-4); border-radius: var(--radius-full); font-size: var(--font-size-sm); font-weight: 600; color: var(--color-text-muted); transition: background 0.15s, color 0.15s; }
.page-dashboard .sheet-tab.on { background: var(--color-primary); color: #FFF; }
.page-dashboard .sheet-body { flex: 1; padding: var(--space-5); overflow-y: auto; }
.page-dashboard .sheet-pane { display: none; flex-direction: column; gap: var(--space-4); }
.page-dashboard .sheet-pane.on { display: flex; }
.page-dashboard .field-label { font-size: var(--font-size-sm); font-weight: 600; margin-bottom: var(--space-2); display: block; }
.page-dashboard .chip-row { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.page-dashboard .chip { padding: 6px var(--space-3); border-radius: var(--radius-full); background: var(--color-bg); font-size: var(--font-size-sm); border: 1px solid var(--color-border); cursor: pointer; transition: background 0.15s, color 0.15s; }
.page-dashboard .chip:hover { background: rgba(201,123,90,0.10); }
.page-dashboard .chip.on { background: var(--color-primary); color: #FFF; border-color: var(--color-primary); }
.page-dashboard .qty-row { display: flex; gap: var(--space-2); align-items: center; }
.page-dashboard .qty-row button { width: 36px; height: 36px; border-radius: var(--radius-md); background: var(--color-bg); border: 1px solid var(--color-border); font-size: 18px; font-weight: 600; }
.page-dashboard .qty-row input { flex: 1; max-width: 120px; padding: var(--space-2) var(--space-3); border: 1px solid var(--color-border); border-radius: var(--radius-md); text-align: center; font-weight: 600; font-size: var(--font-size-base); }
.page-dashboard .preset-row { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.page-dashboard .sheet-foot { padding: var(--space-4) var(--space-5); display: flex; gap: var(--space-3); border-top: 1px solid var(--color-border); }
.page-dashboard .btn { flex: 1; padding: var(--space-3) var(--space-5); border-radius: var(--radius-md); font-size: var(--font-size-base); font-weight: 600; transition: background 0.15s, transform 0.1s; }
.page-dashboard .btn-primary { background: var(--color-primary); color: #FFF; }
.page-dashboard .btn-primary:hover { background: var(--color-primary-hover); }
.page-dashboard .btn-ghost { background: transparent; color: var(--color-text-secondary); border: 1px solid var(--color-border); }
.page-dashboard .btn-ghost:hover { background: var(--color-bg); }
@media (max-width: 1279px) {
  .page-dashboard .row-kpi { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .page-dashboard .sidebar { width: 64px; }
  .page-dashboard .brand-name, .page-dashboard .brand-sub, .page-dashboard .admin-tag, .page-dashboard .menu-search, .page-dashboard .nav-section-label, .page-dashboard .nav-group-head .label, .page-dashboard .nav-group-head .chev, .page-dashboard .nav-group-head .badge, .page-dashboard .nav-sub, .page-dashboard .nav-flat-item .label, .page-dashboard .nav-flat-item .pill, .page-dashboard .sidebar-foot .clock-date, .page-dashboard .sidebar-foot .mood-quote, .page-dashboard .sidebar-foot .grain-row { display: none; }
  .page-dashboard .nav-flat-item, .page-dashboard .nav-group-head { justify-content: center; padding: var(--space-3); }
  .page-dashboard .clock-time { font-size: var(--font-size-base); text-align: center; }
}
@media (max-width: 767px) {
  .page-dashboard .sidebar { display: none; }
  .page-dashboard .row-kpi, .page-dashboard .row-7-3, .page-dashboard .row-1-1 { grid-template-columns: 1fr; }
  .page-dashboard .global-search { display: none; }
  .page-dashboard .topbar { padding: 0 var(--space-4); }
  .page-dashboard .content { padding: var(--space-4); gap: var(--space-4); }
  .page-dashboard .kpi-num { font-size: 32px; }
}

/* [Phase4-1_visual_v2_20260510] 와이드 모니터 대응 — 콘텐츠 max-width */
.page-dashboard {
  max-width: 1600px;
  margin: 0 auto;
}
.page-dashboard .chart-svg {
  max-width: 100%;
  height: 280px;
  display: block;
}
