/* =============================================
   DevReq 관리자 추가 스타일
   ============================================= */

/* ─── 대시보드 카운트 카드 ─── */
.stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 14px;
    margin-bottom: 28px;
}
.stat-card {
    background: var(--white);
    border: 1px solid var(--slate-200);
    border-radius: var(--radius);
    padding: 20px;
    display: flex;
    flex-direction: column;
    transition: all var(--transition);
}
.stat-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}
.stat-card .stat-label {
    font-size: .78rem;
    font-weight: 600;
    color: var(--slate-400);
    text-transform: uppercase;
    letter-spacing: .5px;
    margin-bottom: 8px;
}
.stat-card .stat-value {
    font-size: 1.8rem;
    font-weight: 800;
    color: var(--navy-900);
    line-height: 1;
}
.stat-card .stat-icon {
    width: 36px; height: 36px;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem;
    margin-bottom: 12px;
}
.stat-card .stat-icon.received    { background: rgba(99,102,241,.1);  color: var(--indigo-500); }
.stat-card .stat-icon.in_progress { background: rgba(245,158,11,.1);  color: var(--amber-500); }
.stat-card .stat-icon.review      { background: rgba(139,92,246,.1);  color: var(--violet-500); }
.stat-card .stat-icon.completed   { background: rgba(16,185,129,.1);  color: var(--emerald-500); }
.stat-card .stat-icon.hold        { background: rgba(100,116,139,.1); color: var(--slate-500); }

/* ─── 관리자 테이블 ─── */
.admin-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .88rem;
}
.admin-table thead th {
    text-align: center;
    padding: 10px 14px;
    background: var(--slate-50);
    border-bottom: 2px solid var(--slate-200);
    font-size: .78rem;
    font-weight: 700;
    color: var(--slate-500);
    text-transform: uppercase;
    letter-spacing: .5px;
}
.admin-table tbody td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--slate-100);
    vertical-align: middle;
    text-align: center;
}
.admin-table tbody tr { transition: background var(--transition); }
.admin-table tbody tr:hover { background: var(--slate-50); }

/* ─── 상태 변경 드롭다운 ─── */
.status-select {
    display: inline-flex;
    gap: 6px;
    flex-wrap: wrap;
}
.status-select .status-option {
    padding: 6px 12px;
    border-radius: 99px;
    font-size: .78rem;
    font-weight: 700;
    border: 2px solid transparent;
    cursor: pointer;
    transition: all var(--transition);
    background: var(--slate-100);
    color: var(--slate-500);
}
.status-select .status-option:hover { border-color: var(--slate-300); }
.status-select .status-option.active { border-color: currentColor; }
.status-select .status-option.s-received    { color: var(--indigo-500); }
.status-select .status-option.s-in_progress { color: var(--amber-500); }
.status-select .status-option.s-review      { color: var(--violet-500); }
.status-select .status-option.s-completed   { color: var(--emerald-500); }
.status-select .status-option.s-hold        { color: var(--slate-500); }
.status-select .status-option.s-rejected    { color: var(--red-500); }
.status-select .status-option.active.s-received    { background: rgba(99,102,241,.1); }
.status-select .status-option.active.s-in_progress { background: rgba(245,158,11,.1); }
.status-select .status-option.active.s-review      { background: rgba(139,92,246,.1); }
.status-select .status-option.active.s-completed   { background: rgba(16,185,129,.1); }
.status-select .status-option.active.s-hold        { background: rgba(100,116,139,.1); }
.status-select .status-option.active.s-rejected    { background: rgba(239,68,68,.1); }

/* ─── 관리자 로그인 ─── */
.admin-login-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--navy-900);
}
.admin-login-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: 40px;
    max-width: 380px;
    width: 90%;
    box-shadow: var(--shadow-lg);
}
.admin-login-card h1 {
    font-size: 1.3rem;
    font-weight: 800;
    margin-bottom: 4px;
}
.admin-login-card .admin-login-sub {
    color: var(--slate-400);
    font-size: .85rem;
    margin-bottom: 28px;
}

@media (max-width: 768px) {
    .stat-grid { grid-template-columns: repeat(2, 1fr); }
    .admin-table { font-size: .78rem; }
    .admin-table thead th,
    .admin-table tbody td { padding: 8px 10px; }

    /* 상태 선택 버튼 */
    .status-select { gap: 4px; }
    .status-select .status-option { padding: 5px 8px; font-size: .72rem; }

    /* 관리 패널 폼 */
    .card-body form[style*="flex:1"] { min-width: 100% !important; }

    /* 벌크바 */
    #bulkBar { flex-wrap: wrap; font-size: .82rem; }

    /* 통계 차트 2열→1열 */
    div[style*="grid-template-columns:1fr 1fr"] { grid-template-columns: 1fr !important; }
}
