/**
 * 全局页面与弹窗美化（Windows 11 Fluent 风格）
 * 交接班页使用 .handover-page，通过 :has() 排除，不覆盖 shift_handover.css
 */

/* -------------------------------------------------------------------------- */
/* 非交接班：页面标题区、卡片、表格、导航                                     */
/* -------------------------------------------------------------------------- */

main.main-content:not(:has(.handover-page)) .border-bottom {
  border-color: rgba(0, 0, 0, 0.08) !important;
  padding-bottom: 0.65rem !important;
  margin-bottom: 1rem !important;
}

main.main-content:not(:has(.handover-page)) h1.h2,
main.main-content:not(:has(.handover-page)) .h2.mb-0,
main.main-content:not(:has(.handover-page)) .h3.mb-0 {
  font-weight: 600;
  letter-spacing: -0.02em;
  color: #1c1c1c;
}

main.main-content:not(:has(.handover-page)) .breadcrumb {
  --bs-breadcrumb-divider: "›";
  font-size: 0.875rem;
  padding: 0.35rem 0.65rem;
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: 8px;
  margin-bottom: 0.75rem;
}

main.main-content:not(:has(.handover-page)) .breadcrumb-item a {
  color: #0067c0;
  text-decoration: none;
}

main.main-content:not(:has(.handover-page)) .breadcrumb-item a:hover {
  text-decoration: underline;
}

main.main-content:not(:has(.handover-page)) .card {
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.07);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05), 0 0 0 1px rgba(255, 255, 255, 0.5) inset;
  overflow: hidden;
  transition: box-shadow 0.2s ease;
}

/* 入住退房页 .compact-page：内联样式需优先，避免覆盖彩色表头与白字「新增」链接 */
main.main-content:not(:has(.handover-page)) .compact-page .card {
  overflow: visible;
  border: none;
  box-shadow: none;
  background: transparent;
  border-radius: 0;
}

/* 仅对可点击/强调卡片增强悬停，避免统计区大量卡片一起闪动 */
main.main-content:not(:has(.handover-page)) a.card:hover,
main.main-content:not(:has(.handover-page)) .hotel-icon-card:hover {
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08), 0 0 0 1px rgba(255, 255, 255, 0.55) inset;
}

main.main-content:not(:has(.handover-page)) .card-header {
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  font-weight: 600;
  letter-spacing: -0.01em;
}

main.main-content:not(:has(.handover-page)) .card-header:not([class*="bg-"]):not(.header-ci):not(.header-co):not(.header-sales):not(.header-expenses) {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 250, 252, 0.95) 100%);
}

main.main-content:not(:has(.handover-page)) .nav-tabs .nav-link,
main.main-content:not(:has(.handover-page)) .nav-tabs.card-header-tabs .nav-link {
  border-radius: 8px 8px 0 0;
  margin-right: 2px;
}

main.main-content:not(:has(.handover-page)) .nav-tabs.card-header-tabs {
  gap: 0.15rem;
}

main.main-content:not(:has(.handover-page)) .alert {
  border-radius: 10px;
  border: 1px solid transparent;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

main.main-content:not(:has(.handover-page)) .alert-info {
  background: linear-gradient(135deg, rgba(239, 246, 255, 0.95) 0%, rgba(224, 242, 254, 0.65) 100%);
  border-color: rgba(59, 130, 246, 0.22);
  color: #1e3a5f;
}

main.main-content:not(:has(.handover-page)) .alert-success {
  border-color: rgba(34, 197, 94, 0.28);
}

main.main-content:not(:has(.handover-page)) .alert-warning {
  border-color: rgba(245, 158, 11, 0.35);
}

main.main-content:not(:has(.handover-page)) .alert-danger {
  border-color: rgba(244, 63, 94, 0.28);
}

/* 表格：不覆盖 table-dark / 商品页等强制定义 */
main.main-content:not(:has(.handover-page)) .table:not(.table-dark) thead th {
  font-weight: 600;
  font-size: 0.875rem;
  text-transform: none;
  letter-spacing: 0.01em;
}

main.main-content:not(:has(.handover-page)) .table-responsive {
  border-radius: 0 0 10px 10px;
}

main.main-content:not(:has(.handover-page)) .table-hover > tbody > tr {
  transition: background-color 0.12s ease;
}

/* 酒店列表等卡片网格 */
main.main-content:not(:has(.handover-page)) .hotel-icon-card {
  border-radius: 14px;
  overflow: hidden;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

main.main-content:not(:has(.handover-page)) .hotel-icon-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12) !important;
}

/* -------------------------------------------------------------------------- */
/* 登录 / 注册（非交接班，轻量统一外壳）                                       */
/* -------------------------------------------------------------------------- */

.login-stage .login-shell {
  box-shadow: 0 28px 56px rgba(15, 23, 42, 0.12), 0 0 0 1px rgba(255, 255, 255, 0.75) inset;
}

/* -------------------------------------------------------------------------- */
/* 弹窗：排除交接班页（body 含 .handover-page 时不应用）                       */
/* -------------------------------------------------------------------------- */

body:not(:has(.handover-page)) .modal.fade .modal-dialog {
  transition: transform 0.22s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.2s ease;
  transform: translate(0, 8px) scale(0.985);
}

body:not(:has(.handover-page)) .modal.show .modal-dialog {
  transform: none;
}

body:not(:has(.handover-page)) .modal-content {
  border-radius: 12px !important;
  border: 1px solid rgba(0, 0, 0, 0.09) !important;
  box-shadow: 0 24px 56px rgba(0, 0, 0, 0.16), 0 0 0 1px rgba(255, 255, 255, 0.55) inset !important;
  background: rgba(252, 252, 252, 0.98) !important;
  backdrop-filter: blur(22px) saturate(1.2);
  -webkit-backdrop-filter: blur(22px) saturate(1.2);
  overflow: hidden;
}

body:not(:has(.handover-page)) .modal-header {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(245, 246, 248, 0.96) 100%) !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.07) !important;
  padding: 0.85rem 1.15rem !important;
}

body:not(:has(.handover-page)) .modal-title {
  font-weight: 600;
  letter-spacing: -0.02em;
  color: #1c1c1c;
}

body:not(:has(.handover-page)) .modal-body {
  color: #323130;
}

body:not(:has(.handover-page)) .modal-footer {
  background: rgba(249, 249, 250, 0.95) !important;
  border-top: 1px solid rgba(0, 0, 0, 0.07) !important;
  padding: 0.7rem 1.1rem !important;
  gap: 0.45rem;
  flex-wrap: wrap;
}

body:not(:has(.handover-page)) .modal-footer .btn {
  border-radius: 8px;
  min-width: 4.5rem;
  font-weight: 500;
}

body:not(:has(.handover-page)) .modal .table {
  font-size: 0.9rem;
}

body:not(:has(.handover-page)) .modal .list-group-item {
  border-color: rgba(0, 0, 0, 0.07);
  border-radius: 8px !important;
  margin-bottom: 4px;
}

body:not(:has(.handover-page)) .modal .form-control,
body:not(:has(.handover-page)) .modal .form-select {
  border-radius: 8px;
}

/* 小号确认框 */
body:not(:has(.handover-page)) .modal-sm .modal-content {
  border-radius: 11px !important;
}

body:not(:has(.handover-page)) .modal-fullscreen .modal-content {
  border-radius: 0 !important;
}

/* SweetAlert2 */
body:not(:has(.handover-page)) .swal2-popup {
  border-radius: 12px !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(255, 255, 255, 0.6) inset !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

body:not(:has(.handover-page)) .swal2-styled.swal2-confirm {
  border-radius: 8px !important;
  font-weight: 600 !important;
  padding: 0.45rem 1.25rem !important;
}

body:not(:has(.handover-page)) .swal2-styled.swal2-cancel {
  border-radius: 8px !important;
}

/* Toast */
body:not(:has(.handover-page)) .toast {
  border-radius: 10px !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.12) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* Offcanvas */
body:not(:has(.handover-page)) .offcanvas {
  border-radius: 0 14px 14px 0 !important;
  box-shadow: 12px 0 40px rgba(0, 0, 0, 0.12) !important;
}

body:not(:has(.handover-page)) .offcanvas-end {
  border-radius: 14px 0 0 14px !important;
}

/* Popover */
body:not(:has(.handover-page)) .popover {
  border-radius: 10px !important;
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.12) !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
}

/* Dropdown（页面内，非顶栏） */
main.main-content:not(:has(.handover-page)) .dropdown-menu {
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.1);
  padding: 0.35rem;
}

main.main-content:not(:has(.handover-page)) .dropdown-item {
  border-radius: 6px;
  padding: 0.4rem 0.65rem;
}

main.main-content:not(:has(.handover-page)) .dropdown-item:hover {
  background: rgba(0, 103, 192, 0.08);
  color: #0a4a7a;
}

/* -------------------------------------------------------------------------- */
/* 个人资料等窄页 container                                                    */
/* -------------------------------------------------------------------------- */

main.main-content:not(:has(.handover-page)) > .container {
  max-width: 920px;
}

main.main-content:not(:has(.handover-page)) > .container .card {
  border-radius: 14px;
}

/* -------------------------------------------------------------------------- */
/* 减少动效（系统偏好）                                                       */
/* -------------------------------------------------------------------------- */

@media (prefers-reduced-motion: reduce) {
  main.main-content:not(:has(.handover-page)) .card,
  main.main-content:not(:has(.handover-page)) .hotel-icon-card {
    transition: none;
  }

  body:not(:has(.handover-page)) .modal.fade .modal-dialog {
    transition: opacity 0.15s ease;
    transform: none;
  }
}
