@font-face {
  font-family: 'remixicon';
  src: url('/remixicon.woff2') format('woff2');
  font-display: swap;
}
:root {
  --hm-bg: #f4f6f3;
  --hm-panel: #ffffff;
  --hm-panel-soft: #f9faf6;
  --hm-ink: #17201a;
  --hm-muted: #667064;
  --hm-line: #dfe5db;
  --hm-green: #27745d;
  --hm-gold: #b97818;
  --hm-red: #b54a3c;
  --hm-blue: #276d99;
  --hm-shadow: 0 14px 40px rgba(43, 59, 43, 0.1);
  color: var(--hm-ink);
  background: var(--hm-bg);
  font-family: 'PingFang SC', 'Microsoft YaHei', ui-sans-serif, system-ui, sans-serif;
  font-synthesis: none;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
* {
  box-sizing: border-box;
}
body {
  margin: 0;
  min-width: 0;
  background: linear-gradient(135deg, rgba(39, 116, 93, 0.08), transparent 32%), linear-gradient(45deg, rgba(185, 120, 24, 0.08), transparent 38%), var(--hm-bg);
}
button,
input,
textarea {
  font: inherit;
}
#app {
  min-height: 100vh;
}
[class^='ri-'],
[class*=' ri-'] {
  font-family: 'remixicon' !important;
  font-style: normal;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.ri-map-pin-2-line::before {
  content: '\ef0a';
}
.ri-map-pin-2-fill::before {
  content: '\ef09';
}
.ri-map-pin-line::before {
  content: '\ef14';
}
.ri-map-pin-fill::before {
  content: '\ef13';
}
.ri-restaurant-fill::before {
  content: '\f083';
}
.ri-restaurant-line::before {
  content: '\f084';
}
.ri-file-list-3-line::before {
  content: '\ecef';
}
.ri-file-list-3-fill::before {
  content: '\ecee';
}
.ri-article-line::before {
  content: '\ea7e';
}
.ri-article-fill::before {
  content: '\ea7d';
}
.ri-map-pin-user-line::before {
  content: '\ef1a';
}
.ri-map-pin-user-fill::before {
  content: '\ef19';
}
.ri-image-circle-line::before {
  content: '\f412';
}
.ri-image-circle-fill::before {
  content: '\f411';
}
.ri-image-circle-ai-line::before {
  content: '\f57c';
}
.ri-image-circle-ai-fill::before {
  content: '\f57b';
}
.ri-user-3-line::before {
  content: '\f256';
}
.ri-user-3-fill::before {
  content: '\f255';
}
.ri-user-community-line::before {
  content: '\f59e';
}
.ri-user-community-fill::before {
  content: '\f59d';
}
.ri-account-circle-line::before {
  content: '\ea09';
}
.ri-account-circle-fill::before {
  content: '\ea08';
}
.ri-vip-line::before {
  content: '\f292';
}
.ri-vip-fill::before {
  content: '\f291';
}
.ri-shopping-basket-2-line::before {
  content: '\f11a';
}
.ri-shopping-basket-2-fill::before {
  content: '\f119';
}
.ri-shopping-basket-line::before {
  content: '\f11c';
}
.ri-shopping-basket-fill::before {
  content: '\f11b';
}
.ri-shopping-cart-2-line::before {
  content: '\f11e';
}
.ri-shopping-cart-2-fill::before {
  content: '\f11d';
}
.ri-shopping-bag-2-line::before {
  content: '\f114';
}
.ri-shopping-bag-2-fill::before {
  content: '\f113';
}
.ri-gift-line::before {
  content: '\edbb';
}
.ri-gift-fill::before {
  content: '\edba';
}
.ri-gift-2-line::before {
  content: '\edb9';
}
.ri-gift-2-fill::before {
  content: '\edb8';
}
.ri-bowl-line::before {
  content: '\f429';
}
.ri-bowl-fill::before {
  content: '\f428';
}
.ri-cup-line::before {
  content: '\ec06';
}
.ri-cup-fill::before {
  content: '\ec05';
}
.ri-brain-line::before {
  content: '\f2f7';
}
.ri-brain-fill::before {
  content: '\f2f6';
}
.ri-brain-2-line::before {
  content: '\f525';
}
.ri-brain-2-fill::before {
  content: '\f524';
}
.ri-dna-line::before {
  content: '\f52f';
}
.ri-dna-fill::before {
  content: '\f52e';
}
.ri-wechat-line::before {
  content: '\f2b6';
}
.ri-wechat-fill::before {
  content: '\f2b5';
}
.ri-wechat-2-line::before {
  content: '\f2b4';
}
.ri-wechat-2-fill::before {
  content: '\f2b3';
}
.ri-signpost-line::before {
  content: '\f48d';
}
.ri-signpost-fill::before {
  content: '\f48c';
}
.ri-apps-line::before {
  content: '\ea44';
}
.ri-apps-fill::before {
  content: '\ea43';
}
.ri-list-settings-line::before {
  content: '\eebd';
}
.ri-list-settings-fill::before {
  content: '\eebc';
}
.ri-question-line::before {
  content: '\f045';
}
.ri-question-fill::before {
  content: '\f044';
}
.ri-alert-line::before {
  content: '\ea21';
}
.ri-alert-fill::before {
  content: '\ea20';
}
.ri-spam-line::before {
  content: '\f16d';
}
.ri-spam-fill::before {
  content: '\f16c';
}
.ri-checkbox-circle-line::before {
  content: '\eb81';
}
.ri-checkbox-circle-fill::before {
  content: '\eb80';
}
.ri-radio-button-line::before {
  content: '\f050';
}
.ri-radio-button-fill::before {
  content: '\f04f';
}
.ri-time-line::before {
  content: '\f20f';
}
.ri-time-fill::before {
  content: '\f20e';
}
.ri-timer-2-line::before {
  content: '\f211';
}
.ri-timer-2-fill::before {
  content: '\f210';
}
.ri-eye-close-line::before {
  content: '\ecb3';
}
.ri-eye-close-fill::before {
  content: '\ecb2';
}
.ri-eye-fill::before {
  content: '\ecb4';
}
.ri-eye-line::before {
  content: '\ecb5';
}
.ri-lock-line::before {
  content: '\eece';
}
.ri-lock-fill::before {
  content: '\eecd';
}
.ri-leaf-line::before {
  content: '\eea3';
}
.ri-leaf-fill::before {
  content: '\eea2';
}
.ri-seedling-line::before {
  content: '\f0d5';
}
.ri-seedling-fill::before {
  content: '\f0d4';
}
.ri-service-bell-line::before {
  content: '\f5f1';
}
.ri-service-bell-fill::before {
  content: '\f5f0';
}
.ri-police-badge-line::before {
  content: '\f50c';
}
.ri-police-badge-fill::before {
  content: '\f50b';
}
.ri-fridge-line::before {
  content: '\ed98';
}
.ri-fridge-fill::before {
  content: '\ed97';
}
.ri-plant-fill::before {
  content: '\f006';
}
.ri-plant-line::before {
  content: '\f007';
}
.ri-qr-code-line::before {
  content: '\f03d';
}
.ri-qr-code-fill::before {
  content: '\f03c';
}
.ri-qr-scan-2-line::before {
  content: '\f03f';
}
.ri-command-fill::before {
  content: '\ebb7';
}
.ri-command-line::before {
  content: '\ebb8';
}
.ri-draw-line::before {
  content: '\f680';
}
.ri-draw-fill::before {
  content: '\f67f';
}
.ri-message-3-line::before {
  content: '\ef46';
}
.ri-message-3-fill::before {
  content: '\ef45';
}
.ri-megaphone-2-line::before {
  content: '\f689';
}
.ri-megaphone-2-fill::before {
  content: '\f688';
}
.ri-send-ins-line::before {
  content: '\f668';
}
.ri-send-ins-fill::before {
  content: '\f667';
}
.ri-calendar-schedule-line::before {
  content: '\f3f2';
}
.ri-calendar-schedule-fill::before {
  content: '\f3f1';
}
.ri-verified-badge-line::before {
  content: '\f3e8';
}
.ri-verified-badge-fill::before {
  content: '\f3e7';
}
.ri-calendar-check-line::before {
  content: '\eb23';
}
.ri-calendar-check-fill::before {
  content: '\eb22';
}
.ri-home-line::before {
  content: '\ee2b';
}
.ri-home-5-fill::before {
  content: '\ee1e';
}
.ri-ancient-pavilion-line::before {
  content: '\ea34';
}
.ri-ancient-pavilion-fill::before {
  content: '\ea33';
}
.ri-arrow-up-s-line::before {
  content: '\ea78';
}
.ri-arrow-right-s-line::before {
  content: '\ea6e';
}
.ri-arrow-down-s-line::before {
  content: '\ea4e';
}
.ri-arrow-left-s-line::before {
  content: '\ea64';
}
.ri-reply-line::before {
  content: '\f07a';
}
.ri-reply-fill::before {
  content: '\f079';
}
.ri-archive-stack-line::before {
  content: '\f427';
}
.login-screen {
  min-height: 100vh;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 460px;
  padding: 28px;
  gap: 28px;
}
.login-visual {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  min-height: calc(100vh - 56px);
  background: #243c31;
  box-shadow: var(--hm-shadow);
}
.login-visual img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.72;
}
.login-visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(16, 31, 24, 0.82), rgba(16, 31, 24, 0.24));
}
.login-visual__copy {
  position: absolute;
  z-index: 1;
  left: 48px;
  bottom: 54px;
  width: min(640px, 70%);
  color: #fff;
}
.login-visual__copy span,
.eyebrow {
  display: inline-block;
  font-size: 12px;
  letter-spacing: 0;
  text-transform: uppercase;
  color: var(--hm-green);
  font-weight: 700;
}
.login-visual__copy span {
  color: #f1d8a8;
}
.login-visual__copy h1 {
  margin: 14px 0 12px;
  font-size: 46px;
  line-height: 1.1;
  letter-spacing: 0;
}
.login-visual__copy p {
  margin: 0;
  font-size: 17px;
  color: rgba(255, 255, 255, 0.78);
}
.login-panel {
  align-self: center;
  background: var(--hm-panel);
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  padding: 28px;
  box-shadow: var(--hm-shadow);
}
.login-panel__head,
.admin-header,
.header-actions,
.toolbar,
.sms-row,
.row-actions {
  display: flex;
  align-items: center;
}
.login-panel__head {
  justify-content: space-between;
  margin-bottom: 24px;
}
.login-panel h2 {
  margin: 6px 0 0;
  font-size: 24px;
  letter-spacing: 0;
}
.segmented {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 18px;
}
.sms-row {
  gap: 10px;
}
.sms-row .arco-input-wrapper {
  flex: 1;
}
.debug-code {
  margin: 8px 0 0;
  color: var(--hm-gold);
  font-size: 12px;
}
.admin-shell {
  position: relative;
  min-height: 100vh;
  min-width: 0;
  flex-direction: row;
}
.skip-link {
  position: fixed;
  left: 16px;
  top: 12px;
  z-index: 1000;
  transform: translateY(-64px);
  padding: 8px 12px;
  border-radius: 8px;
  background: var(--hm-green);
  color: #fff;
  text-decoration: none;
  box-shadow: var(--hm-shadow);
}
.skip-link:focus {
  transform: translateY(0);
}
.admin-sider {
  height: 100vh;
  position: sticky;
  top: 0;
  background: #fbfcf8;
  border-right: 1px solid var(--hm-line);
}
.admin-sider .arco-layout-sider-children {
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: visible;
}
.admin-shell > .arco-layout {
  min-width: 0;
}
.brand {
  position: relative;
  height: 72px;
  padding: 16px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  border-bottom: 1px solid var(--hm-line);
}
.brand__text {
  min-width: 0;
  flex: 1;
}
.brand__mark {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: var(--hm-green);
  color: #fff;
  font-weight: 800;
  font-size: 20px;
}
.brand strong {
  display: block;
  font-size: 16px;
}
.brand__collapse {
  flex: 0 0 auto;
  color: var(--hm-muted);
}
.brand span,
.user-meta span,
.metric-card__hint,
.task-row span,
.capability-grid span {
  display: block;
  color: var(--hm-muted);
  font-size: 12px;
}
.nav-scroll {
  flex: 1;
  height: calc(100vh - 72px);
  overflow: auto;
  overflow-x: hidden;
  padding: 10px 8px 18px;
}
.nav-scroll::-webkit-scrollbar {
  width: 6px;
}
.nav-scroll::-webkit-scrollbar-track {
  background: transparent;
}
.nav-scroll::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: #d1d9d1;
}
.admin-menu {
  width: 100%;
  border: 0;
  background: transparent;
}
.admin-sider .arco-menu {
  border: 0;
  background: transparent;
}
.admin-sider .arco-menu-inner {
  padding: 0 4px 12px;
  overflow-x: hidden;
}
.admin-sider .arco-menu-inline-header {
  height: 40px;
  margin: 2px 0;
  padding: 0 12px !important;
  border-radius: 6px;
  line-height: 40px;
  color: #2f3d34;
  background: transparent;
  font-weight: 700;
}
.admin-sider .arco-menu-inline-header:hover,
.admin-sider .arco-menu-inline-header.arco-menu-selected {
  color: var(--hm-green);
  background: rgba(39, 116, 93, 0.08);
}
.admin-sider .arco-menu-inline-header .arco-menu-icon-suffix {
  right: 10px;
  color: #8a96a3;
}
.admin-sider .arco-menu-item {
  height: 34px;
  margin: 1px 0;
  padding: 0 12px 0 42px !important;
  border-radius: 6px;
  line-height: 34px;
  color: #536170;
  background: transparent;
}
.admin-sider .arco-menu-item:hover {
  color: #1d2a22;
  background: rgba(39, 116, 93, 0.06);
}
.admin-sider .arco-menu-item.arco-menu-selected {
  color: var(--hm-green);
  background: rgba(39, 116, 93, 0.1);
  font-weight: 700;
}
.admin-sider .arco-menu-item.arco-menu-selected::before {
  content: '';
  position: absolute;
  left: 0;
  top: 7px;
  width: 3px;
  height: 20px;
  border-radius: 0 999px 999px 0;
  background: var(--hm-green);
}
.admin-sider .arco-menu-icon {
  width: 18px;
  margin-right: 10px !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #8a96a3;
}
.admin-sider .arco-menu-inline-header:hover .arco-menu-icon,
.admin-sider .arco-menu-inline-header.arco-menu-selected .arco-menu-icon {
  color: currentColor;
}
.admin-sider .arco-menu-title {
  min-width: 0;
}
.admin-sider.is-collapsed .brand {
  justify-content: center;
  padding: 16px 10px;
}
.admin-sider.is-collapsed .brand__text {
  display: none;
}
.admin-sider.is-collapsed .brand__collapse {
  position: absolute;
  right: -13px;
  top: 22px;
  width: 26px;
  height: 26px;
  background: var(--hm-panel);
  border: 1px solid var(--hm-line);
  box-shadow: 0 6px 14px rgba(35, 50, 36, 0.12);
  z-index: 2;
}
.admin-sider.is-collapsed .nav-scroll {
  padding: 10px 6px 18px;
}
.admin-sider.is-collapsed .admin-menu {
  width: 56px;
}
.admin-sider.is-collapsed .arco-menu-inner {
  padding: 0 4px 12px;
}
.admin-sider.is-collapsed .arco-menu-inline-header,
.admin-sider.is-collapsed .arco-menu-item {
  width: 44px;
  height: 40px;
  margin: 2px 0;
  padding: 0 !important;
  justify-content: center;
  line-height: 40px;
}
.admin-sider.is-collapsed .arco-menu-icon {
  margin-right: 0 !important;
}
.admin-sider.is-collapsed .arco-menu-item.arco-menu-selected::before {
  top: 8px;
  height: 24px;
}
.admin-header {
  height: 72px;
  padding: 0 24px;
  justify-content: space-between;
  background: rgba(244, 246, 243, 0.9);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--hm-line);
}
.header-search {
  height: 38px;
  min-width: 340px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--hm-muted);
  background: var(--hm-panel);
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  padding: 0 12px;
}
.header-actions {
  gap: 12px;
}
.user-meta {
  min-width: 96px;
}
.user-meta strong {
  display: block;
  font-size: 13px;
}
.admin-content {
  padding: 24px;
  min-width: 0;
  overflow-x: auto;
}
.page-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 18px;
}
.page-head h1 {
  margin: 6px 0 6px;
  font-size: 28px;
  line-height: 1.18;
  letter-spacing: 0;
}
.page-head p {
  margin: 0;
  color: var(--hm-muted);
  font-size: 14px;
}
.page-head__extra {
  flex-shrink: 0;
}
.toolbar {
  gap: 10px;
}
.toolbar .arco-input-wrapper,
.toolbar .arco-select {
  width: 240px;
}
.metric-strip {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.metric-strip--4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.metric-card {
  min-height: 118px;
}
.metric-card__label {
  color: var(--hm-muted);
  font-size: 13px;
}
.metric-card__value {
  margin: 10px 0 8px;
  font-size: 26px;
  font-weight: 800;
}
.metric-card__value[data-tone='green'] {
  color: var(--hm-green);
}
.metric-card__value[data-tone='gold'] {
  color: var(--hm-gold);
}
.metric-card__value[data-tone='red'] {
  color: var(--hm-red);
}
.workbench-grid {
  display: grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: 16px;
}
.hotel-workbench-grid,
.price-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(360px, 0.85fr);
  gap: 16px;
  margin-bottom: 16px;
}
.hotel-section-card,
.filter-card {
  margin-bottom: 16px;
}
.hotel-task-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.hotel-task {
  min-height: 104px;
  display: grid;
  align-content: center;
  gap: 6px;
  text-align: left;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: var(--hm-panel-soft);
  padding: 14px;
  cursor: pointer;
}
.hotel-task:hover {
  border-color: rgba(39, 116, 93, 0.42);
  box-shadow: 0 8px 22px rgba(43, 59, 43, 0.08);
}
.hotel-task span,
.hotel-task em,
.muted-line,
.plain-note {
  color: var(--hm-muted);
  font-size: 12px;
  font-style: normal;
}
.hotel-task strong {
  font-size: 26px;
}
.hotel-task.is-warn strong {
  color: var(--hm-red);
}
.inventory-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.inventory-summary div {
  min-height: 82px;
  display: grid;
  align-content: center;
  gap: 8px;
  padding: 12px;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: var(--hm-panel-soft);
}
.inventory-summary span,
.detail-grid span,
.detail-kv span,
.drawer-form label span,
.rule-form label span,
.weekday-group > span {
  color: var(--hm-muted);
  font-size: 12px;
}
.inventory-summary strong {
  font-size: 24px;
}
.trend-bars {
  height: 210px;
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 14px;
  align-items: end;
}
.trend-bar {
  min-width: 0;
  display: grid;
  justify-items: center;
  gap: 7px;
}
.trend-bar__track {
  width: 100%;
  height: 136px;
  display: flex;
  align-items: flex-end;
  border-radius: 8px;
  background: #edf3ed;
  overflow: hidden;
}
.trend-bar__track span {
  width: 100%;
  min-height: 4px;
  background: linear-gradient(180deg, #3b8f71, #d49a3a);
}
.trend-bar em {
  color: var(--hm-muted);
  font-size: 12px;
  font-style: normal;
}
.status-tabs {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  padding: 10px;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.72);
}
.order-filters,
.rule-form {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  align-items: end;
}
.rule-form {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.rule-form label,
.drawer-form label {
  display: grid;
  gap: 6px;
}
.weekday-group {
  grid-column: 1 / -1;
  display: grid;
  gap: 8px;
}
.weekday-group div,
.drawer-actions,
.detail-status-line,
.refund-inline-form {
  display: flex;
  align-items: center;
  gap: 8px;
}
.calendar-toolbar .arco-select {
  width: 260px;
}
.month-input {
  width: 110px !important;
}
.calendar-card {
  overflow: hidden;
}
.calendar-week-head,
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
}
.calendar-week-head {
  border: 1px solid var(--hm-line);
  border-bottom: 0;
  border-radius: 8px 8px 0 0;
  overflow: hidden;
}
.calendar-week-head strong {
  padding: 10px 12px;
  background: #eef3ed;
  color: var(--hm-muted);
  font-size: 12px;
  text-align: center;
  border-right: 1px solid var(--hm-line);
}
.calendar-week-head strong:last-child {
  border-right: 0;
}
.calendar-grid {
  border-left: 1px solid var(--hm-line);
  border-top: 1px solid var(--hm-line);
}
.calendar-day {
  min-height: 148px;
  padding: 10px;
  border-right: 1px solid var(--hm-line);
  border-bottom: 1px solid var(--hm-line);
  background: #fff;
  cursor: pointer;
}
.calendar-day:hover {
  background: #fbfcf8;
}
.calendar-day.is-blank {
  cursor: default;
  background: #f4f6f3;
}
.calendar-day.is-closed,
.calendar-day.is-full {
  background: #fff6f4;
}
.calendar-day.is-low {
  background: #fffaf0;
}
.calendar-day.is-locked {
  background: #f5f3ff;
}
.calendar-day__head,
.detail-kv {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.calendar-day__head span {
  color: var(--hm-muted);
  font-size: 12px;
}
.calendar-day__price {
  margin: 10px 0;
  color: var(--hm-green);
  font-weight: 800;
}
.calendar-day__stock {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  margin-bottom: 8px;
  color: var(--hm-muted);
  font-size: 12px;
}
.drawer-form,
.order-detail {
  display: grid;
  gap: 14px;
}
.drawer-actions {
  justify-content: flex-end;
  padding-top: 10px;
  border-top: 1px solid var(--hm-line);
}
.switch-line {
  grid-template-columns: 1fr auto;
  align-items: center;
}
.detail-section {
  display: grid;
  gap: 10px;
  padding-top: 14px;
  border-top: 1px solid var(--hm-line);
}
.detail-section:first-child {
  border-top: 0;
  padding-top: 0;
}
.detail-section h3 {
  margin: 0;
  font-size: 15px;
}
.detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.detail-grid div,
.detail-kv {
  padding: 10px 12px;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: var(--hm-panel-soft);
}
.detail-grid div {
  display: grid;
  gap: 6px;
}
.rule-advice {
  margin: 0;
  padding: 12px;
  border: 1px solid rgba(185, 120, 24, 0.28);
  border-radius: 8px;
  color: #85520f;
  background: #fff8eb;
}
.refund-inline-form {
  align-items: flex-end;
}
.refund-inline-form .arco-input-wrapper {
  flex: 1;
}
.arrow-text {
  margin: 0 6px;
  color: var(--hm-muted);
}
.task-list {
  display: grid;
  gap: 12px;
}
.task-row {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: var(--hm-panel-soft);
}
.task-row i {
  width: 38px;
  height: 38px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: #e8f1eb;
  color: var(--hm-green);
  font-size: 20px;
}
.capability-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.capability-grid div {
  padding: 14px;
  background: var(--hm-panel-soft);
  border: 1px solid var(--hm-line);
  border-radius: 8px;
}
.table-card {
  box-shadow: 0 10px 28px rgba(43, 59, 43, 0.06);
}
.singleton-card {
  max-width: 1080px;
}
.resource-edit-card {
  max-width: 1120px;
}
.resource-edit-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 16px;
  align-items: start;
}
.resource-edit-layout .resource-edit-card {
  max-width: none;
}
.room-preview-card {
  position: sticky;
  top: 92px;
}
.room-preview {
  display: grid;
  gap: 10px;
}
.room-preview__image {
  height: 188px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: var(--hm-panel-soft);
  color: var(--hm-muted);
}
.room-preview__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.room-preview strong {
  font-size: 18px;
}
.room-preview p,
.room-preview em {
  margin: 0;
  color: var(--hm-muted);
  font-size: 13px;
  font-style: normal;
}
.room-preview b {
  color: var(--hm-red);
  font-size: 20px;
}
.resource-context-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: -4px 0 14px;
  padding: 10px 12px;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.72);
}
.resource-context-bar strong {
  font-size: 13px;
}
.setup-required {
  min-height: 320px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 12px;
}
.form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding-top: 16px;
  border-top: 1px solid var(--hm-line);
}
.sticky-actions {
  position: sticky;
  bottom: 0;
  margin: 18px -16px -16px;
  padding: 14px 16px;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(10px);
}
.workflow-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: -4px 0 16px;
}
.workflow-step {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 48px;
  padding: 10px 12px;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.68);
}
.workflow-step span {
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--hm-green);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
}
.workflow-step strong {
  font-size: 13px;
}
.row-actions {
  gap: 4px;
}
.table-link {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 7px;
  color: var(--hm-blue);
  font-size: 12px;
  font-weight: 600;
  text-decoration: none;
}
.table-link:hover {
  color: var(--hm-green);
}
.table-thumb {
  width: 54px;
  height: 42px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid var(--hm-line);
  border-radius: 6px;
  background: var(--hm-panel-soft);
  color: var(--hm-muted);
  font-size: 12px;
}
.table-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.empty-state {
  height: 180px;
  display: grid;
  place-items: center;
  color: var(--hm-muted);
}
.empty-state i {
  font-size: 28px;
}
.json-view {
  margin: 0;
  padding: 16px;
  min-height: 360px;
  overflow: auto;
  background: #101713;
  color: #dce8df;
  border-radius: 8px;
  font-size: 12px;
  line-height: 1.6;
}
.verification-layout {
  display: grid;
  grid-template-columns: 480px minmax(0, 1fr);
  gap: 16px;
}
.verification-result,
.verification-empty {
  min-height: 300px;
  display: grid;
  align-content: center;
  gap: 12px;
}
.verification-empty {
  justify-items: center;
  text-align: center;
  color: var(--hm-muted);
}
.verification-empty i {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #e8f1eb;
  color: var(--hm-green);
  font-size: 28px;
}
.verification-empty strong {
  color: var(--hm-ink);
}
.result-kv {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 14px;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: var(--hm-panel-soft);
}
.result-kv span {
  color: var(--hm-muted);
}
.result-kv strong {
  word-break: break-all;
}
.resource-form {
  padding-bottom: 12px;
}
.form-section {
  padding: 14px 0 8px;
  border-top: 1px solid var(--hm-line);
}
.form-section:first-child {
  border-top: 0;
  padding-top: 0;
}
.form-section__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.form-section__head strong,
.subfield-head strong {
  font-size: 15px;
  color: var(--hm-ink);
}
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 2px 16px;
}
.form-item-wide {
  grid-column: 1 / -1;
}
.media-uploader {
  display: grid;
  gap: 12px;
}
.product-media-field {
  display: grid;
  gap: 24px;
}
.product-media-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: center;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 8px 22px rgba(43, 59, 43, 0.04);
}
.product-media-summary div {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 58px;
  gap: 12px;
  padding: 0 18px;
  color: #344256;
}
.product-media-summary div + div {
  border-left: 1px solid var(--hm-line);
}
.product-media-summary svg {
  flex: 0 0 auto;
  color: var(--hm-green);
}
.product-media-field__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  align-items: start;
}
.media-block {
  display: grid;
  min-width: 0;
}
.media-uploader__trigger {
  width: 138px;
  height: 112px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 6px;
  color: var(--hm-muted);
}
.media-uploader__trigger i {
  color: var(--hm-green);
}
.media-uploader__trigger strong {
  color: var(--hm-ink);
}
.media-uploader__trigger span,
.subfield-head span {
  color: var(--hm-muted);
}
.media-uploader--panel {
  display: grid;
  gap: 26px;
  min-height: 446px;
  padding: 34px 30px 18px;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: #fff;
}
.media-uploader__head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}
.media-uploader__head span {
  display: block;
  margin-top: 4px;
  color: var(--hm-muted);
}
.media-uploader__type-icon {
  color: var(--hm-green);
}
.media-uploader__head strong {
  display: block;
}
.media-uploader--panel .arco-upload,
.media-uploader--panel .arco-upload-wrapper,
.media-uploader--panel .arco-upload-trigger {
  width: 100%;
}
.media-uploader--panel .arco-upload-draggable {
  width: 100%;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent;
}
.media-uploader__panel-trigger {
  display: grid;
  gap: 24px;
}
.media-uploader__dropzone {
  width: 100%;
  min-height: 214px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  padding: 32px;
  border: 1px dashed #cbd6cc;
  border-radius: 8px;
  background: #fff;
  color: var(--hm-muted);
}
.media-uploader__dropzone svg {
  color: var(--hm-green);
}
.media-uploader__dropzone strong {
  color: var(--hm-ink);
}
.media-uploader__trigger-footer {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.media-uploader__trigger-footer em {
  color: #4b5966;
  font-style: normal;
}
.media-uploader__trigger-footer .arco-btn {
  color: var(--hm-green);
  border-color: rgba(39, 116, 93, 0.36);
}
.media-preview-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.media-preview-item {
  min-height: 112px;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: var(--hm-panel-soft);
  overflow: hidden;
  position: relative;
}
.media-preview-item img,
.media-preview-item video {
  display: block;
  width: 100%;
  height: 112px;
  object-fit: cover;
  background: #111a15;
}
.media-preview-item a {
  display: block;
  padding: 14px;
  color: var(--hm-blue);
  word-break: break-all;
}
.media-preview-item span {
  position: absolute;
  left: 8px;
  top: 8px;
  padding: 2px 7px;
  border-radius: 999px;
  background: rgba(17, 26, 21, 0.72);
  color: #fff;
}
.subfield-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 10px;
}
.subfield-head span {
  display: block;
  margin-top: 4px;
}
.sku-editor,
.structured-editor,
.object-editor {
  display: grid;
  gap: 10px;
}
.structured-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr)) auto;
  gap: 10px;
  align-items: end;
  padding: 12px;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: var(--hm-panel-soft);
}
.structured-row label,
.object-editor label {
  display: grid;
  gap: 6px;
}
.structured-row label span,
.object-editor label span {
  color: var(--hm-muted);
  font-size: 12px;
}
.object-editor {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: 12px;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: var(--hm-panel-soft);
}
.object-editor label:has(.arco-textarea-wrapper) {
  grid-column: 1 / -1;
}
.rich-text-field {
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
}
.rich-text-field:focus-within {
  border-color: rgba(39, 116, 93, 0.55);
  box-shadow: 0 0 0 2px rgba(39, 116, 93, 0.12);
}
.rich-text-field__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding: 10px;
  border-bottom: 1px solid var(--hm-line);
  background: var(--hm-panel-soft);
}
.rich-text-field__toolbar .arco-btn.active {
  color: #fff;
  border-color: var(--hm-green);
  background: var(--hm-green);
}
.rich-text-field__toolbar .arco-divider-vertical {
  height: 22px;
  margin: 0 2px;
}
.rich-text-field__block-select {
  width: 104px;
}
.rich-text-field__editor {
  background: #fff;
}
.rich-text-field__content {
  min-height: 260px;
  padding: 16px 18px;
  line-height: 1.7;
  outline: none;
  color: var(--hm-ink);
}
.rich-text-field__content > *:first-child {
  margin-top: 0;
}
.rich-text-field__content > *:last-child {
  margin-bottom: 0;
}
.rich-text-field__content p {
  margin: 0 0 12px;
}
.rich-text-field__content h2,
.rich-text-field__content h3,
.rich-text-field__content h4 {
  margin: 18px 0 10px;
  line-height: 1.35;
  color: #10251d;
}
.rich-text-field__content h2 {
  font-size: 22px;
}
.rich-text-field__content h3 {
  font-size: 18px;
}
.rich-text-field__content h4 {
  font-size: 16px;
}
.rich-text-field__content ul,
.rich-text-field__content ol {
  margin: 0 0 12px;
  padding-left: 24px;
}
.rich-text-field__content li + li {
  margin-top: 4px;
}
.rich-text-field__content blockquote {
  margin: 14px 0;
  padding: 10px 14px;
  border-left: 4px solid var(--hm-green);
  background: #f4f8f1;
  color: #36443a;
}
.rich-text-field__content a {
  color: var(--hm-blue);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.rich-text-field__content p.is-editor-empty:first-child::before {
  color: var(--hm-muted);
  content: attr(data-placeholder);
  float: left;
  height: 0;
  pointer-events: none;
}
.rich-text-field__content img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  display: block;
  margin: 14px 0;
  border: 1px solid var(--hm-line);
}
.rich-text-field__content img.ProseMirror-selectednode {
  outline: 3px solid rgba(39, 116, 93, 0.24);
  outline-offset: 2px;
}
.rich-text-field__link-panel {
  width: 320px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 8px;
  align-items: center;
}
.rich-text-field__tip {
  margin: 0;
  padding: 8px 12px;
  border-top: 1px solid var(--hm-line);
  color: var(--hm-muted);
  font-size: 12px;
}
.dining-workbench-grid,
.dining-management-layout,
.ordering-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 16px;
  align-items: start;
  margin-top: 16px;
}
.dining-workbench-grid {
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
}
.area-tabs,
.status-tabs {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  margin: 14px 0;
  padding-bottom: 2px;
}
.area-tabs button,
.status-tabs button {
  border: 1px solid var(--hm-line);
  background: #fff;
  color: var(--hm-muted);
  border-radius: 8px;
  padding: 8px 14px;
  cursor: pointer;
  white-space: nowrap;
}
.area-tabs button.active,
.status-tabs button.active {
  color: var(--hm-green);
  border-color: rgba(27, 116, 75, 0.32);
  background: rgba(27, 116, 75, 0.08);
  font-weight: 700;
}
.sub-tabs {
  margin-top: -4px;
}
.table-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-bottom: 14px;
}
.table-filter-bar .arco-input-wrapper {
  width: 260px;
}
.table-filter-bar .arco-select {
  width: 180px;
}
.soft-pill {
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 8px;
  border-radius: 6px;
  background: rgba(39, 116, 93, 0.08);
  color: var(--hm-green);
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}
.qr-thumb-cell {
  width: 72px;
  height: 72px;
  border-radius: 8px;
  border: 1px solid var(--hm-line);
  background: #f7f8f5;
  display: grid;
  place-items: center;
  overflow: hidden;
}
.qr-thumb-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.qr-thumb-cell span {
  color: var(--hm-muted);
  font-size: 12px;
}
.table-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}
.dining-table-card {
  display: grid;
  gap: 9px;
  text-align: left;
  border: 1px solid var(--hm-line);
  border-left: 4px solid #b8c0bb;
  border-radius: 8px;
  background: #fff;
  padding: 14px;
  cursor: pointer;
}
.dining-table-card__head,
.dining-table-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.dining-table-card strong {
  font-size: 20px;
  color: var(--hm-ink);
}
.dining-table-card span,
.dining-table-card em,
.dining-table-card small {
  color: var(--hm-muted);
  font-style: normal;
}
.dining-table-card__qr {
  width: 112px;
  height: 112px;
  border-radius: 8px;
  border: 1px solid var(--hm-line);
  background: #f7f8f5;
  display: grid;
  place-items: center;
  overflow: hidden;
}
.dining-table-card__qr img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.dining-table-card__qr span {
  color: var(--hm-muted);
  font-size: 13px;
}
.dining-table-card.is-idle {
  border-left-color: #1b744b;
}
.dining-table-card.is-dining,
.dining-table-card.is-cleaning {
  border-left-color: #d97706;
}
.dining-table-card.is-reserved {
  border-left-color: #4f46e5;
}
.dining-table-card.is-disabled {
  opacity: 0.62;
}
.settings-panel {
  display: grid;
  gap: 16px;
  position: sticky;
  top: 84px;
}
.compact-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.compact-form label,
.switch-grid label {
  display: grid;
  gap: 6px;
}
.compact-form label span,
.switch-grid label span {
  color: var(--hm-muted);
  font-size: 12px;
}
.compact-form .span-2,
.compact-form .form-actions {
  grid-column: 1 / -1;
}
.compact-form .form-actions {
  justify-content: flex-end;
}
.area-list-card,
.settings-section {
  margin-top: 16px;
}
.qrcode-material-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 180px;
  gap: 16px;
  align-items: start;
}
.qrcode-material-editor {
  display: grid;
  gap: 12px;
}
.qrcode-material-preview {
  display: grid;
  gap: 10px;
  justify-items: center;
  color: var(--hm-muted);
  font-size: 12px;
  line-height: 1.6;
}
.qrcode-preview-ring {
  position: relative;
  width: 136px;
  height: 136px;
  border-radius: 50%;
  border: 1px solid var(--hm-line);
  background: #f3f5f7;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 4px;
  overflow: hidden;
  color: #232b27;
}
.qrcode-preview-ring img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.qrcode-preview-ring strong,
.qrcode-preview-ring span {
  position: relative;
  z-index: 1;
  max-width: 112px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: center;
}
.qrcode-preview-ring strong {
  font-size: 18px;
}
.qrcode-preview-ring span {
  font-size: 30px;
  font-weight: 800;
}
.qrcode-material-metrics {
  margin-top: 16px;
}
.qrcode-material-grid-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}
.qrcode-material-card {
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: #fff;
  overflow: hidden;
  display: grid;
}
.qrcode-material-card__preview {
  aspect-ratio: 2 / 3;
  background: #f7f8f5;
  display: grid;
  place-items: center;
  border-bottom: 1px solid var(--hm-line);
  overflow: hidden;
}
.qrcode-material-card__preview img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #f7f8f5;
}
.qrcode-material-card__preview div {
  display: grid;
  gap: 8px;
  justify-items: center;
  color: var(--hm-muted);
}
.qrcode-material-card__preview i {
  font-size: 34px;
  color: var(--hm-green);
}
.qrcode-material-card section {
  padding: 12px;
  display: grid;
  gap: 6px;
}
.qrcode-material-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.qrcode-material-card strong {
  font-size: 20px;
}
.qrcode-material-card p,
.qrcode-material-card small {
  margin: 0;
  color: var(--hm-muted);
}
.qrcode-material-card footer {
  padding: 0 12px 12px;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
.area-list {
  display: grid;
  gap: 8px;
}
.area-list button {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4px 12px;
  text-align: left;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: #fff;
  padding: 10px 12px;
  cursor: pointer;
}
.area-list span {
  color: var(--hm-muted);
  font-size: 12px;
}
.switch-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.phone-preview-shell {
  position: sticky;
  top: 84px;
}
.phone-preview {
  width: 320px;
  min-height: 620px;
  margin-inline: auto;
  border: 10px solid #17211b;
  border-radius: 32px;
  background: #f6f8f6;
  overflow: hidden;
  box-shadow: 0 18px 48px rgba(17, 26, 21, 0.16);
}
.phone-preview header {
  display: grid;
  gap: 6px;
  padding: 22px 18px;
  background: #1b744b;
  color: #fff;
}
.phone-preview header strong {
  font-size: 20px;
}
.phone-preview header span {
  color: rgba(255, 255, 255, 0.82);
  font-size: 12px;
}
.phone-search {
  margin: 12px;
  padding: 10px 12px;
  border-radius: 8px;
  color: var(--hm-muted);
  background: #fff;
}
.phone-preview nav {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 0 12px 10px;
}
.phone-preview nav button {
  border: 0;
  background: #e8f0eb;
  color: #1b744b;
  border-radius: 8px;
  padding: 7px 10px;
  white-space: nowrap;
}
.phone-dish-list {
  display: grid;
  gap: 10px;
  padding: 0 12px 16px;
}
.phone-dish-list article {
  display: grid;
  grid-template-columns: 72px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 10px;
  background: #fff;
  border-radius: 8px;
}
.phone-dish-img {
  width: 72px;
  height: 72px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  overflow: hidden;
  background: #edf2ee;
  color: var(--hm-muted);
}
.phone-dish-img img,
.dish-phone-preview__hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.phone-dish-list section {
  display: grid;
  gap: 4px;
}
.phone-dish-list em,
.phone-dish-list b {
  font-style: normal;
}
.phone-dish-list b {
  color: #b42318;
}
.phone-dish-list article > button,
.dish-phone-preview__price button {
  width: 28px;
  height: 28px;
  border: 0;
  border-radius: 50%;
  color: #fff;
  background: #1b744b;
  font-size: 18px;
}
.kitchen-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.kitchen-board section {
  min-height: 180px;
  padding: 12px;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
  background: var(--hm-panel-soft);
}
.kitchen-board h3 {
  display: flex;
  justify-content: space-between;
  margin: 0 0 10px;
  font-size: 15px;
}
.kitchen-board article {
  display: grid;
  gap: 4px;
  padding: 10px;
  border-radius: 8px;
  background: #fff;
  cursor: pointer;
}
.kitchen-board article + article {
  margin-top: 8px;
}
.kitchen-board article span,
.reservation-calendar article span {
  color: var(--hm-muted);
  font-size: 12px;
}
.order-detail {
  display: grid;
  gap: 16px;
}
.order-detail section {
  display: grid;
  gap: 8px;
}
.order-detail h3 {
  margin: 0;
  font-size: 15px;
}
.order-detail p,
.detail-line {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin: 0;
  padding: 8px 0;
  border-bottom: 1px solid var(--hm-line);
}
.order-detail p span {
  color: var(--hm-muted);
}
.detail-line em {
  color: var(--hm-muted);
  font-style: normal;
}
.drawer-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}
.reservation-calendar {
  display: grid;
  gap: 12px;
}
.reservation-calendar section {
  display: grid;
  gap: 8px;
  padding: 14px;
  border: 1px solid var(--hm-line);
  border-radius: 8px;
}
.reservation-calendar h3 {
  margin: 0;
  font-size: 15px;
}
.reservation-calendar article {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4px 10px;
  padding: 10px;
  border-radius: 8px;
  background: var(--hm-panel-soft);
  cursor: pointer;
}
.system-advice {
  padding: 12px;
  border: 1px solid rgba(217, 119, 6, 0.28);
  border-radius: 8px;
  background: rgba(217, 119, 6, 0.08);
}
.dish-phone-preview {
  overflow: hidden;
  border: 10px solid #17211b;
  border-radius: 28px;
  background: #fff;
}
.dish-phone-preview__hero {
  height: 210px;
  display: grid;
  place-items: center;
  background: #edf2ee;
  color: var(--hm-muted);
}
.dish-phone-preview__body {
  display: grid;
  gap: 8px;
  padding: 16px;
}
.dish-phone-preview__body strong {
  font-size: 20px;
}
.dish-phone-preview__body p,
.dish-phone-preview__body em {
  margin: 0;
  color: var(--hm-muted);
  font-style: normal;
}
.dish-phone-preview__tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.dish-phone-preview__tags span {
  padding: 3px 7px;
  border-radius: 6px;
  background: rgba(27, 116, 75, 0.1);
  color: #1b744b;
  font-size: 12px;
}
.dish-phone-preview__price {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.dish-phone-preview__price b {
  color: #b42318;
  font-size: 22px;
}
@media (max-width: 1280px) {
  .metric-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .media-preview-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .verification-layout {
    grid-template-columns: 1fr;
  }
  .product-media-field__grid {
    grid-template-columns: 1fr;
  }
  .hotel-workbench-grid,
  .dining-workbench-grid,
  .dining-management-layout,
  .ordering-layout,
  .price-layout,
  .resource-edit-layout,
  .order-filters,
  .rule-form {
    grid-template-columns: 1fr;
  }
  .hotel-task-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .settings-panel,
  .phone-preview-shell {
    position: static;
  }
  .switch-grid,
  .kitchen-board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 900px) {
  .admin-sider {
    position: sticky;
  }
  .brand {
    height: 64px;
    padding: 12px 14px;
  }
  .brand span,
  .user-meta {
    display: none;
  }
  .nav-scroll {
    height: calc(100vh - 64px);
    padding: 10px 8px 18px;
  }
  .admin-sider .arco-menu-item {
    padding-inline: 10px;
  }
  .admin-header {
    height: 64px;
    padding: 0 12px;
    gap: 10px;
  }
  .header-search {
    min-width: 0;
    flex: 1;
  }
  .header-search span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .header-actions {
    gap: 8px;
  }
  .admin-content {
    padding: 16px;
  }
  .page-head {
    display: grid;
  }
  .page-head__extra,
  .toolbar {
    width: 100%;
  }
  .toolbar {
    flex-wrap: wrap;
  }
  .toolbar .arco-input-wrapper,
  .toolbar .arco-select,
  .calendar-toolbar .arco-select {
    width: min(100%, 260px);
  }
  .metric-strip,
  .metric-strip--4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .calendar-card .arco-card-body {
    overflow-x: auto;
  }
  .calendar-week-head,
  .calendar-grid {
    min-width: 760px;
  }
  .detail-grid,
  .product-media-summary,
  .product-media-field__grid,
  .object-editor,
  .form-grid,
  .compact-form,
  .switch-grid,
  .kitchen-board {
    grid-template-columns: 1fr;
  }
  .product-media-summary div {
    justify-content: flex-start;
  }
  .product-media-summary div + div {
    border-top: 1px solid var(--hm-line);
    border-left: 0;
  }
  .phone-preview {
    width: min(100%, 320px);
  }
}
