/* ============================================
   배차 본문 스타일
   ============================================ */

/* 전역 스타일 */
* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}
.mt-6 {
	margin-top: 6px;
}

/* 반응형 표시/숨김 */
.desktop-only {
	display: block !important;
}

.mobile-only {
	display: none !important;
}

/* flexbox 전용 반응형 클래스 */
.desktop-only-flex {
	display: flex !important;
}

.mobile-only-flex {
	display: none !important;
}

@media (max-width: 768px) {
	.desktop-only {
		display: none !important;
	}
	
	.mobile-only {
		display: block !important;
	}
	
	.desktop-only-flex {
		display: none !important;
	}
	
	.mobile-only-flex {
		display: flex !important;
	}
}

.main_visual_wp.dispatch-wp {
    display: flex;
    flex-direction: column;
    gap: 30px;
	height: auto;
	margin: 0 auto;
}
.max-w-1200 {
	max-width: 1200px;
}

/* 히어로 이미지 섹션 (상단 배경 이미지) */
.dispatch-hero-section {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 0;
}

.dispatch-hero-gradient-overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 40%;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.30) 40%, rgba(255, 255, 255, 1) 75%);
	pointer-events: none;
	z-index: 3;
	box-sizing: border-box;
	border: none;
	outline: none;
	margin: 0;
	padding: 0;
}

.dispatch-hero-image-wrapper {
	z-index: 1;
	position: relative;
	display: flex;
	align-items: center;
	width: 100%;
	max-height: 250px;
	overflow: hidden;
}


.dispatch-hero-image {
	z-index: 1;
	position: relative;
	width: 100%;
	height: auto;
	object-fit: cover;
}

/* 배차 상세, 폼 페이지 배경색 설정 */
#wrap:has(.dispatch-wp.max-w-1200),
#wrap:has(.dispatch-wp.max-w-1200) .cd-main-content,
#wrap:has(.dispatch-wp.max-w-1200) .main_visual_wp.dispatch-wp,
#wrap:has(.dispatch-wp.max-w-1200) + #dispatch-footer {
	background: var(--color-grayscale-bg-detail);
}
#wrap:has(.dispatch-wp.max-w-1200) .dispatch-hero-gradient-overlay {
	background: linear-gradient(180deg, rgba(250, 250, 250, 0) 0%, rgba(250, 250, 250, 0.3) 40%, #FAFAFA 75%);
}

#wrap:has(.dispatch-wp.max-w-1200).dispatch-layout,
#wrap:has(.dispatch-wp.max-w-1200) .main_visual_wp.dispatch-wp {
	gap: 60px;
}

/* 페이지 타이틀 섹션 (흰색 배경) */
.dispatch-header {
	position: relative;
}

.dispatch-header-content {
	z-index: 1;
	position: relative;
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 16px;
}
.dispatch-header h1 {
	font-size: 43.6px;
	line-height: 43.56px;
	letter-spacing: 0%;
	color: var(--color-grayscale-100-primary-text);
}

.dispatch-page-info {
	position: relative;
	display: flex;
	align-items: center;
	gap: 8px;
}

.dispatch-info-icon {
	display: inline-block;
	width: 24px;
	height: 24px;
    color: var(--color-grayscale-30);
	cursor: pointer;
	transition: color 0.2s;
}

.dispatch-info-icon:hover {
	color: var(--color-grayscale-50);
}

/* 상태 설명 툴팁 */
.dispatch-status-tooltip {
	position: fixed;
	display: none;
	z-index: 10000;
	min-width: 320px;
	pointer-events: none;
}

.dispatch-status-tooltip.active {
	display: block;
	pointer-events: auto;
}

/* 데스크탑에서 툴팁 헤더 타이틀 숨김 */
.dispatch-status-tooltip .tooltip-header h2 {
	display: none;
}

.dispatch-status-tooltip .tooltip-arrow {
	position: absolute;
	top: -8px;
	left: 34.5px;
	transform: translateX(-50%);
	width: 0;
	height: 0;
	border-left: 9.88px solid transparent;
	border-right: 9.88px solid transparent;
	border-bottom: 9.88px solid var(--color-grayscale-0);
	filter: drop-shadow(0 -2px 2px rgba(0, 0, 0, 0.1));
	pointer-events: none;
	z-index: 1;
}

.dispatch-status-tooltip .tooltip-content {
	position: relative;
	padding: 10px 12px;
	background: var(--color-grayscale-0);
	box-shadow: var(--shadow-normal);
	pointer-events: auto;
}

.dispatch-status-tooltip .status-item {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	margin-bottom: 0;
}

.dispatch-status-tooltip .status-item:last-child {
	margin-bottom: 0;
}

.dispatch-quote-tooltip .status-item {
	gap: 0;
}
.dispatch-status-tooltip .status-bullet {
	flex-shrink: 0;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	padding: 0 7px;
	font-size: 14px;
	font-weight: 500;
	color: var(--color-grayscale-55-secondary-text);
}

.dispatch-status-tooltip .status-number {
	display: none;
}

.dispatch-status-tooltip .status-left {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	flex-shrink: 0;
}

.dispatch-status-tooltip .status-description {
	flex: 1;
	font-size: 14px;
	font-weight: 500;
	color: var(--color-grayscale-55-secondary-text);
}

.dispatch-status-tooltip .status-arrow {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 5px 0;
	width: 100%;
}

.dispatch-status-tooltip .status-arrow svg {
	width: 6px;
	height: 4px;
	color: var(--color-grayscale-30);
}

.dispatch-header p {
	font-size: 18px;
	color: #666;
	margin: 0;
}

/* 배차 컨트롤 영역 (필터 버튼 + 생성 버튼) */
.dispatch-controls-container {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 20px;
	border-bottom: 1px solid var(--color-grayscale-10);
}

/* 필터 버튼 그룹 */
.dispatch-filter-buttons {
	flex-wrap: wrap;
	display: flex;
	gap: 8px;
	margin-left: auto;
}

.dispatch-filter-tabs-wrapper {
	position: relative;
	display: flex;
	align-items: center;
	gap: 40px;
}

a.dispatch-filter-btn {
	position: relative;
	display: inline-block;
	padding: 17px 0 36px;
	border-radius: 0;
	border: none;
	background: transparent;
	font-size: 18px;
	font-weight: 700;
	white-space: nowrap;
	text-decoration: none;
	color: var(--color-grayscale-50);
	cursor: pointer;
	transition: color 0.3s ease;
}

a.dispatch-filter-btn::after {
	content: '';
	position: absolute;
	bottom: -2.5px;
	left: 0;
	right: 0;
	height: 5px;
	background: var(--color-blue-50-primary, #667eea);
	z-index: 1;
	opacity: 0;
	transition: opacity 0.3s ease;
}

a.dispatch-filter-btn:hover::after,
a.dispatch-filter-btn.active::after {
	opacity: 1;
}

a.dispatch-filter-btn.active {
	color: var(--color-blue-50-primary);
	background: transparent;
	border: none;
}

/* 배차 신청서 작성 버튼 */
a.dispatch-create-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 16px;
	border: none;
	background: var(--color-blue-50-primary);
	font-size: 16px;
	font-weight: 500;
	text-decoration: none;
	white-space: nowrap;
	color: var(--color-grayscale-0);
	cursor: pointer;
	transition: all 0.3s;
}

a.dispatch-create-btn:hover {
	background: var(--color-blue-50-hover);
}

a.dispatch-create-btn .plus-icon {
	width: 24px;
	height: 24px;
	color: var(--color-grayscale-0);
}

/* 모바일용 버튼 - 데스크톱에서 숨김 */
.dispatch-create-button-mobile {
	display: none;
}

/* 배차 목록 테이블 컨테이너 */
.dispatch-list-container:not(:has(.pagination-container)) {
	padding: 0 0 30px;
}
.dispatch-list-body {
	overflow-x: auto;
	overflow-y: visible;
	-webkit-overflow-scrolling: touch;
}

/* 배차 목록 테이블 스타일 (데스크톱) */
.dispatch-table {
	width: 100%;
	border-collapse: collapse;
	overflow: hidden;
	table-layout: fixed;
	min-width: 1680px; /* 최소 너비 설정으로 스크롤 유도 */
}

/* 빈 테이블일 때는 최소 너비 제거 */
.dispatch-table:has(tbody td.dispatch-table-empty) {
	min-width: auto;
}

/* 빈 테이블 메시지 스타일 */
.dispatch-table tbody td.dispatch-table-empty {
	text-align: center;
	padding: 120px 24px;
	color: var(--color-grayscale-40);
}

/* dispatch-table 내부의 모든 요소에 Pretendard 폰트 강제 적용 */
.dispatch-table,
.dispatch-table *,
.dispatch-table *::before,
.dispatch-table *::after {
	font-family: var(--font-pretendard), 'notokr-regular', sans-serif;
}

.dispatch-table thead {
	border-bottom: 1px solid var(--color-grayscale-20);
	background: var(--color-grayscale-100-primary-text);
	box-shadow: var(--shadow-table-header);
	color: white;
}

.dispatch-table thead th {
	padding: 9px 16px 8px;
	font-size: 14px;
	font-weight: 500;
	line-height: 22px;
	letter-spacing: 0;
	text-align: center;
	color: white;

}

.dispatch-table tbody td {
	padding: 13px 16px 12px;
	border-bottom: 1px solid var(--color-grayscale-20);
	font-size: 14px;
	line-height: 22px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* 상차지, 하차지 컬럼 스타일 */
.dispatch-table tbody td.address-tooltip-td {
	white-space: normal;
	overflow: visible;
}

/* 주소 텍스트 2줄 제한 및 말줄임표 처리 */
.dispatch-table tbody td.address-tooltip-td .address-text {
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	line-clamp: 2; /* 표준 속성 */
	overflow: hidden;
	text-overflow: ellipsis;
	line-height: 1.5;
	max-height: calc(1.5em * 2); /* 2줄 높이 */
	word-break: break-word;
	cursor: pointer; /* 툴팁이 있을 수 있음을 표시 */
}

.dispatch-table tbody tr:hover {
	background: var(--color-grayscale-0-hover-blue);
}

.dispatch-table .btn {
	padding: 6px 12px;
	border: none;
	border-radius: 5px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.3s;
}

.dispatch-table .btn-primary {
	background: #667eea;
	color: white;
}

.dispatch-table .btn-danger {
	background: #dc3545;
	color: white;
}
.dispatch-table .btn-primary:hover {
	background: #5568d3;
}

.dispatch-table .btn-sm {
	padding: 5px 10px;
	font-size: 12px;
}

/* 테이블 컬럼 너비 고정 */
.dispatch-table thead th[data-column="id"],
.dispatch-table tbody td[data-column="id"] {
	width: 72px;
	min-width: 72px;
	max-width: 72px;
	text-align: center;
}

.dispatch-table thead th[data-column="status"],
.dispatch-table tbody td[data-column="status"] {
	width: 72px;
	min-width: 72px;
	max-width: 72px;
	text-align: center;
	padding-left: 7px;
	padding-right: 7px;
}

.dispatch-table thead th[data-column="proposer"],
.dispatch-table tbody td[data-column="proposer"] {
	width: 80px;
	min-width: 80px;
	max-width: 80px;
	text-align: center;
}

.dispatch-table thead th[data-column="start-dt"],
.dispatch-table tbody td[data-column="start-dt"] {
	width: 140px;
	min-width: 140px;
	max-width: 140px;
}

.dispatch-table thead th[data-column="end-dt"],
.dispatch-table tbody td[data-column="end-dt"] {
	width: 140px;
	min-width: 140px;
	max-width: 140px;
}

/* 일시 컬럼 스타일링 */
.dispatch-table tbody td[data-column="start-dt"],
.dispatch-table tbody td[data-column="end-dt"] {
	white-space: normal;
	overflow: visible;
}

.datetime-cell {
	display: flex;
	flex-direction: column;
}

.datetime-date {
	font-size: 14px;
	line-height: 22px;
	/* color: var(--color-grayscale-100-primary-text); */
}

.datetime-time {
	font-size: 12px;
	line-height: 20px;
	letter-spacing: 0;
	color: var(--color-grayscale-50);
}

.dispatch-table thead th[data-column="production"],
.dispatch-table tbody td[data-column="production"] {
	width: 100px;
	min-width: 100px;
	max-width: 100px;
	text-align: center;
}

.dispatch-table thead th[data-column="product-name"],
.dispatch-table tbody td[data-column="product-name"] {
	width: 100px;
	min-width: 100px;
	max-width: 100px;
	text-align: center;
}

.dispatch-table thead th[data-column="car-weight"],
.dispatch-table tbody td[data-column="car-weight"] {
	width: 186px;
	min-width: 186px;
	max-width: 186px;
	text-align: center;
}

.dispatch-table thead th[data-column="settlement-amount"],
.dispatch-table tbody td[data-column="settlement-amount"] {
	width: 130px;
	min-width: 130px;
	max-width: 130px;
	text-align: center;
}

/* 너비가 지정되지 않은 컬럼들이 남은 공간을 채우도록 설정 */
/* table-layout: fixed에서는 퍼센트나 명시적 너비가 필요함 */
/* 출발지와 도착지가 항상 동일한 너비를 가지며, 화면이 커지면 함께 넓어짐 */
.dispatch-table thead th[data-column="start-address"],
.dispatch-table tbody td[data-column="start-address"] {
	width: 18%; /* 남은 공간의 일부를 할당 (출발지와 도착지 동일 너비) */
	min-width: 240px;
}

.dispatch-table thead th[data-column="end-address"],
.dispatch-table tbody td[data-column="end-address"] {
	width: 18%; /* 남은 공간의 일부를 할당 (출발지와 도착지 동일 너비) */
	min-width: 240px;
}

.dispatch-table thead th[data-column="part-number"],
.dispatch-table tbody td[data-column="part-number"] {
	width: 160px;
	min-width: 160px;
	max-width: 160px;
	text-align: center;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* 견적 대기중 placeholder 스타일 */
.dispatch-table tbody td .placeholder-text,
.dispatch-card .placeholder-text {
	width: 100%;
	text-align: center;
	color: var(--color-grayscale-40);
}

/* 배차 카드 스타일 (모바일) */
.dispatch-cards {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

/* dispatch-card 내부의 모든 요소에 Pretendard 폰트 강제 적용 */
.dispatch-card,
.dispatch-card *,
.dispatch-card *::before,
.dispatch-card *::after {
	font-family: var(--font-pretendard), 'notokr-regular', sans-serif;
}

.dispatch-card {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 12px;
	background: var(--color-grayscale-0);
	border: 1px solid var(--color-grayscale-10);
}

.dispatch-card:has(.empty-text) {
	justify-content: center;
	align-items: center;
	height: 153px;
}

.dispatch-card-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--color-grayscale-10);
}


.dispatch-card-name {
	width: 100%;
	font-size: 14px;
	font-weight: 600;
	text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden;
}
.dispatch-card-header .status-badge {
	flex-shrink: 0;
}


.dispatch-card-body {
	margin-bottom: 0;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

/* 모바일 카드 정보 행 스타일 */
.dispatch-card-info-row {
	display: flex;
	align-items: center;
	gap: 4px;
	min-width: 0; /* flex item이 overflow를 허용하도록 */
}

.dispatch-card-icon {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	margin-right: 4px;
	color: var(--color-grayscale-50);
}


.dispatch-card-info-value {
	flex: 1;
	min-width: 0; /* flex item이 overflow를 허용하도록 */
	font-size: 12px;
	text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden;
}

.dispatch-card-time-value {
	flex: 0 0 auto;
}

.dispatch-card-arrow,
.dispatch-card-separator {
	flex-shrink: 0;
}

/* 차량 톤수와 총 정산 금액 행 스타일 */
.dispatch-card-settlement-row {
	justify-content: space-between;
	align-items: center;
}

.dispatch-card-weight-section {
	display: flex;
	align-items: center;
	gap: 4px;
	flex: 1;
	min-width: 0;
}

.dispatch-card-settlement-amount {
	flex-shrink: 0;
	font-size: 14px;
	font-weight: 700;
	color: var(--color-grayscale-90);
	margin-left: auto;
	white-space: nowrap;
}

/* 상태 뱃지 */
.status-badge {
	display: inline-flex;
	align-items: center;
	padding: 2px 6px;
	border-radius: 4px;
	font-size: 12px;
	font-weight: 500;
	line-height: 150%;
	letter-spacing: 0.3px;
	color: var(--color-grayscale-0);
}

.status-badge.status-1 {
	background: var(--color-semantic-blue);
}

.status-badge.status-2 {
	background: var(--color-semantic-yellow);
}

.status-badge.status-3 {
	background: var(--color-semantic-purple);
}

.status-badge.status-4 {
	background: var(--color-semantic-green);
}

.address-tooltip-popup {
	z-index: 1010;
	position: absolute;
	display: none;
	max-width: 350px;
	padding: 8px 12px;
	border-radius: 6px;
	border: 1px solid var(--color-grayscale-10);
	background: var(--color-grayscale-0);
	box-shadow: var(--shadow-normal);
	font-size: 12px;
	white-space: pre-line;
	word-break: break-all;
}

.pagination-container ul {
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	gap: 33px;
	margin: 0;
	padding: 30px 0 0;
	list-style: none;
}

/* 페이지네이션 그룹 스타일 */
.pagination-container .pagination-arrow-group {
	display: flex;
	flex-direction: row;
	gap: 10px;
	align-items: center;
}

.pagination-container .pagination-number-group {
	display: flex;
	flex-direction: row;
	gap: 6px;
	align-items: center;
}

.pagination-container li {
	min-width: 42px;
	height: 42px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: var(--border-pagination);
	background-color: var(--color-grayscale-0);
	transition: all 0.3s ease;
}

.pagination-container li:hover {
	border-color: var(--color-blue-50-primary);
	background-color: var(--color-blue-50-primary);
	color: var(--color-grayscale-0);
}

.pagination-container li.active {
	background-color: var(--color-grayscale-pagination-active);
	border-color: var(--color-grayscale-pagination-active);
}

.pagination-container li a,
.pagination-container li span {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	padding: 6px 9px;
	font-size: 13.2px;
	font-weight: 500;
	line-height: 100%;
	letter-spacing: 0;
	text-decoration: none;
	color: var(--color-grayscale-pagination);
	transition: all 0.3s ease;
}

.pagination-container li:hover a,
.pagination-container li:hover span {
	color: var(--color-grayscale-0);
}

/* 페이지네이션 아이콘 스타일 */
.pagination-container .pagination-icon {
	width: 30px;
	height: 45px;
	color: var(--color-grayscale-100-primary-text);
	display: inline-block;
	vertical-align: middle;
	transition: all 0.3s ease;
}

/* 화살표 아이콘이 있는 li와 a 태그 스타일 (배경, 보더, 패딩 제거) */

.pagination-container li:has(.pagination-icon) {
	width: fit-content;
	min-width: unset;
	height: fit-content;
	border: none;
	background: none;
}
.pagination-container li a:has(.pagination-icon) {
	padding: 0;
}

.pagination-container li.active a {
	color: #fff;
}
.pagination-container li:hover .pagination-icon {
	color: var(--color-blue-50-primary);
}

/* 비활성 페이지네이션 링크 스타일 */
.pagination-container li.disabled, .pagination-container li.disabled a {
	pointer-events: none;
	cursor: not-allowed;
}

.pagination-container li.disabled .pagination-icon,
.pagination-container li.disabled svg, .pagination-container li.disabled:hover .pagination-icon,
.pagination-container li.disabled:hover svg  {
	color: var(--color-grayscale-30);
}

.pagination-container li.disabled:hover {
	border-color: transparent;
	background-color: transparent;
	cursor: not-allowed;
}

.pagination-container li.disabled:hover a {
	color: var(--color-grayscale-30);
	cursor: not-allowed;
}

.main_visual_wp .dispatch-wp {
	display: flex;
	flex-direction: column;
	gap: 30px;
	/* max-width: 1200px; */
}

@keyframes slideUp {
	from {
		transform: translateY(100%);
	}
	to {
		transform: translateY(0);
	}
}

/* 반응형 디자인 */

/* 태블릿 (768px 이하) */
@media (max-width: 768px) {
	.dispatch-hero-section {
		height: 60px;
	}
	.dispatch-hero-image-wrapper, .dispatch-hero-gradient-overlay {
		display: none;
	}

	.main_visual_wp.dispatch-wp {
		gap: 24px;
	}

	/* 배차 상세, 폼 페이지 배경색 설정 */
	#wrap:has(.dispatch-wp.max-w-1200),
	#wrap:has(.dispatch-wp.max-w-1200) .cd-main-content,
	#wrap:has(.dispatch-wp.max-w-1200) .main_visual_wp.dispatch-wp,
	#wrap:has(.dispatch-wp.max-w-1200) + #dispatch-footer {
		background: var(--color-grayscale-0);
	}
	#wrap:has(.dispatch-wp.max-w-1200) .dispatch-hero-gradient-overlay {
		background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.30) 40%, rgba(255, 255, 255, 1) 75%);
	}
	#wrap:has(.dispatch-wp.max-w-1200).dispatch-layout, #wrap:has(.dispatch-wp.max-w-1200) .main_visual_wp.dispatch-wp {
		/* gap: 24px; */
		gap: 0;
	}
	
	.dispatch-header {
        padding: 24px 24px 0;
    }
	
	.dispatch-header-content {
		gap: 10px;
	}
	
	.dispatch-header h1 {
		font-size: 28px;
		line-height: 150%;
	}

	.dispatch-controls-container {
		padding: 0;
		gap: 15px;
	}

	.dispatch-filter-buttons {
		gap: 6px;
		width: 100%;
		overflow-x: auto;
		overflow-y: hidden;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none; /* Firefox */
		-ms-overflow-style: none; /* IE and Edge */
		padding-bottom: 1.5px; /* ::after 밑줄이 잘리지 않도록 */
		margin-bottom: -1.5px; /* 레이아웃 영향 최소화 */
	}
	
	.dispatch-filter-buttons::-webkit-scrollbar {
		display: none; /* Chrome, Safari, Opera */
	}

	a.dispatch-filter-btn {
		padding: 8px 0 14px;
		font-size: 16px;
	}
	a.dispatch-filter-btn.active::after {
		bottom: -1.5px;
		height: 3px;
	}

	/* 모바일에서 데스크톱 버튼 숨기기 */
	.dispatch-controls-container .dispatch-create-button {
		display: none;
	}

	/* 모바일용 생성 버튼 */
	.dispatch-create-button-mobile {
		z-index: 999;
		position: fixed;
		bottom: 24px;
		right: 16px;
		display: block;
		transition: all 0.3s ease;
	}
	body:has(.topvi) .dispatch-create-button-mobile {
		bottom: 92px;
	}
	
	.dispatch-create-btn-mobile {
		position: relative;
		display: flex;
		align-items: center;
		justify-content: center;
		width: 56px;
		height: 56px;
		padding: 0;
		background: var(--color-blue-50-primary);
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		overflow: hidden;
		text-decoration: none;
		transition: all 0.3s;
	}
	
	.dispatch-create-btn-mobile:hover {
		background: var(--color-blue-50-hover);
		transform: translateY(-2px);
	}
	
	.dispatch-create-btn-mobile .create-icon {
		width: 24px;
		height: 24px;
		color: var(--color-grayscale-0);
	}
	/* top button */
	.btn_top {
		right: 16px;
		bottom: 24px;
		width: 56px;
		height: 56px;
	}
	.btn_top button {
		width: 56px;
		height: 56px;
		background: var(--color-grayscale-100-primary-text);
		font-size: 16px;
		font-weight: 500;
		letter-spacing: 0.3px;
		opacity: 1;
	}

	/* 탭 */
	.dispatch-filter-tabs-wrapper {
		gap: 24px;
		padding: 0 16px;
		flex-wrap: nowrap;
		min-width: max-content;
	}

	/* start: 툴팁 */
	.dispatch-status-tooltip {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		width: 100vw;
		height: 100dvh; /* iOS Safari 주소창 고려 (fallback: 100vh) */
		min-width: unset;
		background: rgba(0, 0, 0, 0.4);
		backdrop-filter: blur(2px);
		display: none;
		align-items: flex-end;
		justify-content: center;
		pointer-events: auto;
		z-index: 10000;
	}
	.dispatch-status-tooltip.active {
		display: flex;
	}
	.dispatch-status-tooltip .tooltip-arrow {
		display: none;
	}
	.dispatch-status-tooltip .tooltip-content {
		display: flex;
		flex-direction: column;
		gap: 16px;
		width: 100%;
		max-width: 100%;
		max-height: 80vh;
		padding: 28px 16px 32px;
		border-radius: 20px 20px 0 0;
		box-shadow: var(--shadow-mobile-modal);
		transform: translateY(100%);
		transition: transform 0.3s ease-out;
		overflow-y: auto;
	}
	
	.dispatch-status-tooltip.active .tooltip-content {
		transform: translateY(0);
	}

	.tooltip-mobile-close {
		position: absolute;
		top: 12px;
		left: 50%;
		transform: translateX(-50%);
		width: 40px;
		height: 4px;
		background: var(--color-grayscale-10);
	}
	
	.dispatch-status-tooltip .tooltip-header {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	.dispatch-status-tooltip .tooltip-header h2 {
		display: block; /* 모바일에서 보이도록 */
		font-size: 18px;
		font-weight: 700;
	}
	.dispatch-status-tooltip .tooltip-status-list {
		display: flex;
		flex-direction: column;
		gap: 10px;
	}
	.dispatch-status-tooltip .status-item {
		gap: 8px;
	}
	.dispatch-quote-tooltip .status-item {
		gap: 4px;
	}
	.dispatch-status-tooltip .status-bullet {
		display: none;
	}
	.dispatch-status-tooltip .status-number {
		flex-shrink: 0;
		display: flex;
		justify-content: center;
		align-items: center;
		width: 22px;
		height: 22px;
		padding: 2px;
		border-radius: 4px;
		background: var(--color-grayscale-25);
		font-size: 12px;
		font-weight: 500;
		color: var(--color-grayscale-0);
	}
	.dispatch-status-tooltip .status-description {
		flex: 1;
	}
	.dispatch-status-tooltip .status-left {
		gap: 10px;
	}
	.dispatch-status-tooltip .status-arrow {
		margin: 6px 0;
	}
	.dispatch-status-tooltip .status-arrow svg {
		width: 12px;
		height: 8px;
	}
	/* end: 툴팁 */

	/* start: 배차 목록 */
	.dispatch-list-body {
		padding: 0 16px;
	}
	/* end: 배차 목록 */

	/* start: 페이지네이션 */
	.pagination-container ul {
		gap: 8px;
		padding: 24px 16px 0;
	}
	.pagination-container .pagination-arrow-group,
	.pagination-container .pagination-number-group {
		gap: 4px;
	}
	.pagination-container .pagination-icon {
		width: 24px;
		height: 36px;
	}
	.pagination-container li {
		min-width: 36px;
		height: 36px;
	}
	.pagination-container li a, .pagination-container li span {
		font-size: 14.85px;
	}
	/* end: 페이지네이션 */
}
