:root {
  --bg: #e8e7e1;
  --ink: #1f1d1a;
  --text: var(--ink);
  --muted: #8d8676;
  --line: rgba(120, 100, 40, 0.16);

  --sticky: #fbf5a3;
  --sticky-top: #fefccb;
  --tile: rgba(255, 255, 255, 0.66);
  --tile-edge: rgba(255, 255, 255, 0.72);

  --net: #15c455;
  --net-glow: rgba(40, 255, 120, 0.85);
  --cost: #e0392f;
  --owner: #cbb98a;
  --gold: #cf9a3a;

  --blue: var(--owner);
  --green: var(--net);
  --amber: var(--gold);
  --red: var(--cost);
  --purple: var(--gold);

  --clay-dark: rgba(150, 142, 95, 0.34);
  --clay-light: #ffffff;
  --shadow: 10px 10px 22px var(--clay-dark), -9px -9px 18px var(--clay-light), inset 0 2px 3px rgba(255, 255, 255, 0.55);
  --radius: 16px;
  --radius-card: 24px;
  --mono: "SFMono-Regular", Consolas, "DejaVu Sans Mono", "Courier New", "Microsoft YaHei", monospace;
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }

body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(120% 90% at 85% -10%, rgba(251, 245, 163, 0.45), transparent 55%),
    radial-gradient(90% 70% at -10% 110%, rgba(203, 185, 138, 0.25), transparent 55%),
    var(--bg);
  color: var(--ink);
  font-family: var(--mono);
  font-size: 14px;
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}

h1, h2, h3, p { margin: 0; }
[hidden] { display: none !important; }

/* ===== Shell: 顶栏 + 居中单列 + 悬浮底部导航 ===== */
.appbar {
  position: sticky;
  top: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  padding: 9px 20px;
  background: rgba(233, 232, 226, 0.82);
  backdrop-filter: blur(16px) saturate(1.2);
  border-bottom: 1px solid var(--line);
}

.brand { display: flex; align-items: center; gap: 11px; }
.brand-mark {
  display: grid;
  width: 40px;
  height: 40px;
  place-items: center;
  border-radius: 13px;
  background: transparent;
  overflow: hidden;
  box-shadow: 4px 4px 10px var(--clay-dark), -4px -4px 10px var(--clay-light);
}
.brand-mark svg { display: block; width: 100%; height: 100%; }
.brand-mark rect { fill: var(--ink); }
.brand-mark path {
  fill: none;
  stroke: var(--sticky);
  stroke-linecap: round;
  stroke-linejoin: round;
}
.brand-mark path:nth-of-type(1),
.brand-mark path:nth-of-type(2) { stroke-width: 4.2; }
.brand-mark path:nth-of-type(3),
.brand-mark path:nth-of-type(4) { stroke-width: 3.2; }
.brand-text strong { display: block; font-size: 15px; font-weight: 700; }
.brand-text span { display: block; color: var(--muted); font-size: 12px; }

.top-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }

.shell { max-width: 1100px; margin: 0 auto; padding: 14px 22px 126px; }
.page-head { padding: 6px 4px 12px; }
.eyebrow, small { color: var(--muted); font-size: 13px; }
.page-head .eyebrow { font-size: 12px; margin: 0 0 5px; letter-spacing: 0.04em; }
.page-head h1 { font-size: 30px; font-weight: 700; letter-spacing: -0.02em; }
.page-head.hidden-head { display: none; }

.view { display: none; gap: 16px; margin-top: 2px; }
.view.active { display: grid; }

.tabbar {
  position: fixed;
  left: 50%;
  bottom: 28px;
  transform: translateX(-50%);
  z-index: 40;
  display: flex;
  gap: 2px;
  padding: 6px;
  max-width: min(620px, calc(100% - 20px));
  overflow-x: auto;
  scrollbar-width: none;
  border-radius: 999px;
  background: linear-gradient(160deg, var(--sticky-top), var(--sticky));
  box-shadow: 10px 12px 28px var(--clay-dark), -8px -8px 18px var(--clay-light);
}
.tabbar::-webkit-scrollbar { display: none; }
.tabbar a {
  flex: 1 0 auto;
  text-align: center;
  font-family: var(--mono);
  font-size: 12.5px;
  font-weight: 700;
  color: var(--ink);
  opacity: 0.62;
  text-decoration: none;
  padding: 9px 13px;
  border-radius: 999px;
  white-space: nowrap;
}
.tabbar a i { display: none; }
.tabbar a.active {
  opacity: 1;
  color: #0c7a36;
  background: var(--tile);
  box-shadow: inset 2px 2px 6px rgba(150, 142, 95, 0.2), inset -2px -2px 6px rgba(255, 255, 255, 0.7);
}

.site-footer {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 2px;
  z-index: 35;
  display: flex;
  justify-content: center;
  pointer-events: none;
}

.site-footer a {
  color: rgba(31, 29, 26, 0.52);
  font-size: 11px;
  text-decoration: none;
  pointer-events: auto;
}

.site-footer a:hover { color: var(--ink); }

.panel-head, .top-actions { display: flex; align-items: center; justify-content: space-between; gap: 16px; }

h2 { font-size: 18px; font-weight: 700; }

/* ===== 通用：黄色粘土卡片 ===== */
.metrics article,
.panel {
  background: linear-gradient(160deg, var(--sticky-top), var(--sticky));
  border-radius: var(--radius-card);
  box-shadow: var(--shadow);
}
.panel { padding: 20px; min-width: 0; }
.panel.large { min-height: 300px; }
.priority-panel { min-height: 46vh; }

/* ===== 按钮 ===== */
button {
  border: 0;
  border-radius: 13px;
  background: linear-gradient(160deg, var(--sticky-top), var(--sticky));
  color: var(--ink);
  cursor: pointer;
  font: inherit;
  font-weight: 700;
  padding: 9px 14px;
  box-shadow: 5px 5px 11px var(--clay-dark), -5px -5px 11px var(--clay-light);
}
button:active { box-shadow: inset 3px 3px 7px var(--clay-dark), inset -3px -3px 7px rgba(255, 255, 255, 0.6); }
.icon-button { display: grid; width: 38px; height: 38px; place-items: center; padding: 0; }
.secondary-action { color: var(--ink); }

.status {
  display: inline-flex; align-items: center; gap: 7px;
  border-radius: 999px;
  background: linear-gradient(160deg, var(--sticky-top), var(--sticky));
  color: var(--ink); font-size: 13px; padding: 7px 12px;
  box-shadow: 4px 4px 10px var(--clay-dark), -4px -4px 10px var(--clay-light);
}
.status.updating { color: #0c7a36; }
.status.updating::before, .spinner {
  content: ""; display: inline-block; width: 12px; height: 12px;
  border: 2px solid rgba(21, 196, 85, 0.28); border-top-color: var(--net);
  border-radius: 50%; animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.muted-status {
  background: var(--tile); box-shadow: inset 2px 2px 6px rgba(150, 142, 95, 0.16);
  color: var(--muted); max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.loading-toast {
  position: fixed; right: 16px; bottom: 86px; z-index: 50;
  display: inline-flex; align-items: center; gap: 9px;
  border-radius: 14px; background: linear-gradient(160deg, var(--sticky-top), var(--sticky));
  box-shadow: 10px 10px 24px var(--clay-dark), -8px -8px 16px var(--clay-light);
  color: #0c7a36; font-size: 13px; padding: 10px 13px;
}

/* ===== Bento 指标 ===== */
.metrics { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.metrics article { padding: 18px; }
.metrics span { color: var(--ink); opacity: 0.7; font-size: 14px; }
.metrics strong { display: block; margin: 9px 0 4px; font-size: 30px; font-weight: 700; letter-spacing: -0.02em; }
.metrics small { display: block; color: var(--ink); opacity: 0.6; }
.m-hero { grid-column: 1 / -1; padding: 24px 24px 20px; }
.m-hero strong { font-size: 48px; margin-top: 8px; }
#operatingCost { color: var(--cost); }
#netIncome { color: var(--net); text-shadow: 0 0 14px var(--net-glow), 0 0 2px var(--net-glow); }

.content-grid { display: grid; grid-template-columns: 1.45fr 1fr; gap: 16px; }

/* ===== 上线自检 ===== */
.readiness-summary { display: grid; gap: 12px; padding-top: 14px; }
.readiness-counts { display: flex; flex-wrap: wrap; gap: 8px; }
.readiness-counts span {
  border-radius: 999px; background: var(--tile);
  box-shadow: inset 1px 1px 4px rgba(150, 142, 95, 0.18);
  color: var(--ink); font-size: 13px; padding: 6px 11px;
}
.readiness-counts .ok { color: #0c7a36; }
.readiness-counts .warn { color: var(--cost); }
.readiness-list { display: grid; gap: 8px; }
.readiness-item {
  border-radius: 14px; border-left: 3px solid var(--owner);
  background: var(--tile); box-shadow: 0 1px 2px rgba(120, 100, 40, 0.08);
  padding: 11px 12px;
}
.readiness-item.required { border-left-color: var(--cost); }
.readiness-item strong { display: block; font-size: 14px; }

/* ===== 财务 ===== */
.financial-panel { min-height: 380px; }
.financial-panel .panel-head { margin-bottom: 4px; }
.financial-layout { display: grid; grid-template-columns: minmax(240px, 0.8fr) minmax(300px, 1fr); gap: 24px; align-items: start; margin-top: 22px; }
.financial-records { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; margin-top: 22px; }
.financial-records h3 { margin: 0 0 10px; font-size: 15px; }

.compact-list { display: grid; gap: 10px; }
.compact-item, .compact-empty {
  border-radius: 14px; background: var(--tile); border: 1px solid var(--tile-edge);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7), 0 1px 2px rgba(120, 100, 40, 0.08);
  padding: 11px 13px;
}
.compact-item { display: grid; gap: 4px; }
.compact-item strong { font-size: 13px; }
.compact-item span, .compact-empty { color: var(--muted); font-size: 12px; overflow-wrap: anywhere; }

/* ===== 订单表 ===== */
.booking-layout { display: grid; grid-template-columns: minmax(380px, 1fr) minmax(300px, 0.55fr); gap: 16px; margin-top: 16px; align-items: start; }
.table { margin-top: 16px; overflow: hidden; border-radius: 16px; background: var(--tile); border: 1px solid var(--tile-edge); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7); }
.table-row { display: grid; grid-template-columns: 1fr 1.2fr 1.4fr 0.8fr 0.8fr; gap: 12px; padding: 13px 14px; border-bottom: 1px solid var(--line); font-size: 14px; }
.table-row:last-child { border-bottom: 0; }
.table-head { background: rgba(255, 255, 255, 0.4); color: var(--muted); font-weight: 700; }

/* ===== 房源 ===== */
.property-grid { display: grid; gap: 12px; }
.property-card {
  display: grid; grid-template-columns: 1fr auto; gap: 12px;
  border-radius: 16px; background: var(--tile); border: 1px solid var(--tile-edge);
  box-shadow: 0 1px 2px rgba(120, 100, 40, 0.08); padding: 14px;
}
.property-card.selected { border-color: rgba(21, 196, 85, 0.45); box-shadow: 0 0 0 1px rgba(21, 196, 85, 0.35), 0 1px 2px rgba(120, 100, 40, 0.08); }
.property-card strong { display: block; margin-bottom: 6px; }
.property-actions { display: flex; align-items: flex-start; gap: 8px; }
.property-layout { display: grid; grid-template-columns: minmax(260px, 0.9fr) minmax(340px, 1.1fr); gap: 16px; margin-top: 16px; align-items: start; }

/* ===== 表单 ===== */
.property-form, .owner-form, .expense-form, .booking-form, .customer-profile-form, .human-message-form {
  display: grid; gap: 10px; border-radius: 16px; background: var(--tile); border: 1px solid var(--tile-edge);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7); padding: 16px;
}
.owner-layout { display: grid; grid-template-columns: minmax(300px, 1fr) minmax(280px, 0.58fr); gap: 16px; margin-top: 16px; align-items: start; }
.owner-list { display: grid; gap: 12px; }
.owner-card { display: grid; gap: 12px; border-radius: 16px; background: var(--tile); border: 1px solid var(--tile-edge); box-shadow: 0 1px 2px rgba(120, 100, 40, 0.08); padding: 14px; }
.owner-card strong { display: block; margin-bottom: 5px; }
.owner-rules, .owner-properties { display: flex; flex-wrap: wrap; gap: 7px; }
.owner-rules span, .owner-properties span { border-radius: 999px; background: rgba(120, 90, 20, 0.12); color: var(--ink); font-size: 12px; padding: 5px 9px; }
.owner-properties span { background: rgba(21, 196, 85, 0.16); color: #0c7a36; }

.form-title { display: grid; gap: 5px; margin-bottom: 2px; }
.form-title small { color: var(--muted); }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }

.check-list { display: flex; flex-wrap: wrap; gap: 8px; }
.check-chip {
  display: inline-flex; align-items: center; gap: 7px; cursor: pointer; user-select: none;
  border-radius: 999px; padding: 8px 13px 8px 11px; font-size: 13px; color: var(--ink);
  background: rgba(255, 255, 255, 0.6); border: 1px solid var(--tile-edge);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}
.check-chip input { width: 16px; height: 16px; margin: 0; box-shadow: none; accent-color: var(--net); }
.check-chip:has(input:checked) { background: rgba(21, 196, 85, 0.16); border-color: rgba(21, 196, 85, 0.5); color: #0c7a36; }

.form-section { margin: 12px 0 -2px; padding-top: 12px; border-top: 1px dashed var(--line); font-size: 12px; font-weight: 700; letter-spacing: 0.04em; color: var(--muted); }

.month-switcher { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-bottom: 2px; }
.month-switcher .ms-label { font-size: 13px; color: var(--muted); margin-right: 2px; }
.ms-chip { font-size: 13px; font-weight: 700; padding: 9px 16px; border-radius: 999px; }
.ms-chip.active { color: #0c7a36; box-shadow: inset 3px 3px 7px var(--clay-dark), inset -3px -3px 7px rgba(255, 255, 255, 0.6); }
.month-switcher input[type="month"] {
  border-radius: 12px; border: 1px solid var(--tile-edge); background: var(--tile); color: var(--ink);
  font: inherit; min-height: 40px; padding: 8px 10px; box-shadow: inset 1px 1px 3px rgba(150, 142, 95, 0.16);
}

.status-cell { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.detail-note { margin: 8px 0 0; color: var(--muted); font-size: 13px; overflow-wrap: anywhere; }

/* ===== AI 调教台 ===== */
.train-modes { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.train-chat { display: grid; gap: 12px; margin: 16px 0; min-height: 140px; max-height: 56vh; overflow: auto; padding-right: 2px; }
.train-turn { display: grid; gap: 6px; }
.bubble { max-width: 88%; padding: 11px 14px; border-radius: 16px; font-size: 14px; line-height: 1.5; overflow-wrap: anywhere; }
.bubble.user { justify-self: end; background: rgba(255, 255, 255, 0.72); border: 1px solid var(--tile-edge); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7); }
.bubble.ai { justify-self: start; background: linear-gradient(160deg, var(--sticky-top), var(--sticky)); box-shadow: 5px 5px 12px var(--clay-dark), -5px -5px 12px var(--clay-light); }
.bubble-text { white-space: pre-wrap; }
.bubble .meta { display: block; margin-top: 6px; color: var(--muted); font-size: 11px; }
.train-acts { display: flex; gap: 6px; margin-top: 8px; }
.train-fixbox { display: grid; gap: 8px; margin-top: 4px; justify-self: start; width: 88%; }
.train-fixbox textarea { width: 100%; border-radius: 11px; border: 1px solid var(--tile-edge); background: rgba(255, 255, 255, 0.85); color: var(--ink); font: inherit; padding: 9px 11px; box-shadow: inset 1px 1px 3px rgba(150, 142, 95, 0.16); resize: vertical; }
.train-input, .train-note { display: flex; gap: 8px; margin-top: 10px; }
.train-input input, .train-note input { flex: 1; border-radius: 12px; border: 1px solid var(--tile-edge); background: var(--tile); color: var(--ink); font: inherit; min-height: 42px; padding: 9px 12px; box-shadow: inset 1px 1px 3px rgba(150, 142, 95, 0.16); }
.train-empty { color: var(--muted); font-size: 13px; padding: 8px 2px; }

.badge { align-self: start; border-radius: 999px; background: rgba(21, 196, 85, 0.16); color: #0c7a36; font-size: 12px; padding: 5px 9px; }
.badge.warn { background: rgba(207, 154, 58, 0.18); color: #8a5a05; }

/* ===== 环形图 ===== */
.donut-wrap { display: grid; gap: 20px; place-items: center; padding: 18px 0 8px; }
.donut {
  width: 188px; height: 188px; border-radius: 50%; position: relative;
  background: conic-gradient(var(--cost) 0 18%, var(--net) 18% 100%);
  box-shadow: 0 0 30px var(--net-glow), 9px 9px 22px var(--clay-dark), -7px -7px 16px var(--clay-light);
}
.donut::after {
  content: ""; position: absolute; inset: 42px; border-radius: 50%; background: var(--sticky);
  box-shadow: inset 4px 4px 10px var(--clay-dark), inset -4px -4px 10px rgba(255, 255, 255, 0.6);
}
.legend { display: grid; gap: 10px; width: 100%; }
.legend span { display: flex; justify-content: space-between; gap: 12px; color: var(--ink); }
.legend i { display: inline-block; width: 10px; height: 10px; border-radius: 50%; margin-right: 8px; }
.blue { background: var(--owner); }
.green { background: var(--cost); }
.amber { background: var(--net); }
#legendCost { color: var(--cost); }
#legendNetIncome { color: var(--net); text-shadow: 0 0 10px var(--net-glow); }

/* ===== 待办 / 操作项 ===== */
.action-list { display: grid; gap: 12px; margin-top: 16px; }
.action-item {
  background: var(--tile); border: 1px solid var(--tile-edge); border-left: 3px solid var(--net);
  border-radius: 16px; box-shadow: 0 1px 2px rgba(120, 100, 40, 0.08); padding: 14px;
}
.action-item strong { display: block; margin-bottom: 5px; }
.action-item p { margin: 8px 0 0; color: var(--ink); font-size: 14px; line-height: 1.5; overflow-wrap: anywhere; }
.customer-action { border-left-color: var(--gold); }
.parent-action { border-left-color: var(--owner); }
.action-btn { margin-top: 10px; margin-right: 8px; color: #0c7a36; }
.action-btn.danger, .mini-action.danger { color: var(--cost); }
.row-actions { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.mini-action { min-height: 30px; font-size: 12px; font-weight: 700; padding: 6px 10px; border-radius: 11px; }

/* ===== 聊天 ===== */
.conversation-head { border-top: 1px solid var(--line); margin-top: 18px; padding-top: 16px; }
.conversation-head h3 { margin: 0; font-size: 15px; }
.conversation-list { display: grid; gap: 10px; margin-top: 14px; }
.conversation-item, .conversation-thread {
  position: relative; display: grid; gap: 8px; width: 100%; text-align: left;
  border: 1px solid var(--tile-edge); border-radius: 14px; background: var(--tile);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7); color: var(--ink);
  padding: 12px 13px 12px 16px; overflow: hidden; font: inherit;
}
.conversation-item::before, .conversation-thread::before { content: ""; position: absolute; inset: 0 auto 0 0; width: 3px; background: var(--owner); }
.conversation-thread.assistant::before, .conversation-item.assistant::before { background: var(--net); }
.conversation-thread.human_agent::before, .conversation-item.human_agent::before { background: var(--gold); }
.conversation-item.user::before { background: var(--owner); }
.conversation-thread p, .conversation-item p { margin: 0; color: var(--ink); font-size: 14px; line-height: 1.5; overflow-wrap: anywhere; }
.conversation-thread small { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.conversation-meta { display: flex; align-items: center; gap: 7px; min-width: 0; }
.conversation-meta strong { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.conversation-meta span, .conversation-meta time { color: var(--muted); font-size: 12px; white-space: nowrap; }
.conversation-meta span { border-radius: 999px; background: rgba(120, 90, 20, 0.12); padding: 2px 7px; }
.conversation-meta time { margin-left: auto; }

.customer-detail-panel { margin-top: 0; }
.customer-detail { display: grid; gap: 14px; margin-top: 14px; }
.profile-strip, .customer-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.profile-strip span { border-radius: 999px; background: rgba(120, 90, 20, 0.12); color: var(--ink); font-size: 12px; padding: 6px 10px; }
.detail-chat { display: grid; gap: 8px; max-height: 60vh; overflow: auto; padding-right: 2px; }

/* ===== 日历 ===== */
.calendar-panel { grid-column: 1 / -1; }
.calendar-controls { display: flex; align-items: center; gap: 8px; }
.calendar-controls input { border-radius: 12px; border: 1px solid var(--tile-edge); background: var(--tile); color: var(--ink); font: inherit; min-height: 40px; padding: 8px 10px; box-shadow: inset 1px 1px 3px rgba(150, 142, 95, 0.16); }
.property-legend { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 14px; }
.property-legend span { display: inline-flex; align-items: center; gap: 6px; color: var(--muted); font-size: 13px; }
.property-legend i { width: 18px; height: 8px; border-radius: 999px; }
.month-weekdays { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 0; margin-top: 16px; padding: 0 4px; }
.month-weekdays span { color: var(--muted); font-size: 12px; font-weight: 700; text-align: center; }
.month-calendar {
  display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 0; margin-top: 8px;
  border-radius: 16px; overflow: hidden; border: 1px solid var(--tile-edge);
  background: var(--tile); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}
.month-day {
  display: grid; grid-template-rows: auto minmax(80px, 1fr); gap: 6px; min-height: 120px;
  border-right: 1px solid var(--line); border-bottom: 1px solid var(--line);
  background: transparent; padding: 8px 0; overflow: visible;
}
.month-day.blank { background: repeating-linear-gradient(45deg, rgba(150, 142, 95, 0.1) 0 6px, transparent 6px 13px); }
.month-day header { display: flex; align-items: center; justify-content: space-between; gap: 8px; padding: 0 9px; }
.month-day header strong { font-size: 15px; }
.month-day header span { color: var(--muted); font-size: 11px; }
.calendar-events { position: relative; min-width: 0; min-height: 80px; }
.reservation-segment {
  --lane: 0; position: absolute; top: calc(4px + var(--lane) * 42px); left: -1px; right: -1px;
  display: flex; align-items: center; gap: 6px; min-height: 36px; color: #fff; font-size: 11px; line-height: 1.12;
  padding: 4px 9px; z-index: 2; box-shadow: 0 2px 6px rgba(0, 0, 0, 0.16); cursor: pointer; text-align: left;
  border: 0; font-family: var(--mono); appearance: none; -webkit-appearance: none;
}
.reservation-segment strong { min-width: 0; font-weight: 700; white-space: normal; overflow-wrap: anywhere; }
.reservation-segment:focus-visible { outline: 2px solid rgba(255, 255, 255, 0.96); outline-offset: -3px; }
.segment-checkin { left: 50%; border-radius: 999px 0 0 999px; padding-left: 8px; }
.segment-checkin::before {
  content: ""; flex: none; width: 15px; height: 15px; border-radius: 50%;
  background: rgba(255, 255, 255, 0.92); box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.08);
}
.segment-checkout { right: 50%; border-radius: 0 999px 999px 0; }
.segment-stay { border-radius: 0; }
.reservation-segment.pending-verify { outline: 2px solid var(--gold); outline-offset: -1px; }
.property-lilas { background: linear-gradient(180deg, #348c76, #2a6f5d); }
.property-arcueil { background: linear-gradient(180deg, #c07b46, #a9663a); }
.property-other { background: linear-gradient(180deg, #767063, #625d52); }
.empty-day { color: rgba(110, 110, 100, 0.6); font-size: 12px; }
.calendar-detail {
  margin-top: 14px; border-radius: 16px; background: var(--tile); border: 1px solid var(--tile-edge);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7), 0 2px 8px rgba(120, 100, 40, 0.1);
  padding: 14px; display: grid; gap: 10px;
}
.calendar-detail-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.calendar-detail h3 { font-size: 16px; }
.calendar-detail .profile-strip { display: flex; flex-wrap: wrap; gap: 8px; }
.calendar-detail button { padding: 7px 10px; min-height: 34px; }

/* ===== 表单输入 ===== */
.expense-form label, .property-form label, .owner-form label, .booking-form label, .customer-profile-form label, .human-message-form label { display: grid; gap: 5px; color: var(--muted); font-size: 13px; }
.expense-form input, .expense-form select,
.property-form input, .property-form select, .property-form textarea,
.owner-form input, .owner-form select,
.booking-form input, .booking-form select, .booking-form textarea,
.customer-profile-form input, .customer-profile-form textarea, .human-message-form textarea {
  width: 100%; border-radius: 11px; border: 1px solid var(--tile-edge);
  background: rgba(255, 255, 255, 0.78); color: var(--ink); font: inherit; padding: 9px 11px;
  box-shadow: inset 1px 1px 3px rgba(150, 142, 95, 0.16);
}
.owner-form select[multiple] { min-height: 116px; }
.checkbox-row { grid-template-columns: auto 1fr; align-items: center; }
.checkbox-row input { width: 18px; height: 18px; box-shadow: none; }
.property-form textarea, .booking-form textarea, .customer-profile-form textarea, .human-message-form textarea { resize: vertical; }

/* ===== 手机 / 平板 ===== */
@media (max-width: 860px) {
  .appbar {
    padding: 7px 14px 6px;
    gap: 8px;
    align-items: center;
  }
  .brand { gap: 0; }
  .brand-mark { width: 34px; height: 34px; border-radius: 11px; }
  .brand-text { display: none; }
  .shell { padding: 10px 12px 132px; }
  .page-head { padding-top: 4px; }
  .page-head h1 { font-size: 24px; line-height: 1.12; }
  .top-actions { gap: 6px; }
  .status { padding: 6px 10px; font-size: 12px; }
  .muted-status { max-width: 136px; }
  .tabbar { bottom: 34px; max-width: min(620px, calc(100% - 22px)); }
  .site-footer { bottom: 7px; }

  .metrics, .content-grid, .financial-layout, .financial-records, .booking-layout, .property-layout, .owner-layout, .form-grid {
    grid-template-columns: 1fr;
  }
  .metrics { gap: 12px; }
  .m-hero strong { font-size: 40px; }
  .metrics article:not(.m-hero) { display: grid; grid-template-columns: 1fr auto; gap: 2px 12px; align-items: center; padding: 15px 16px; }
  .metrics article:not(.m-hero) strong { grid-row: 1 / 3; grid-column: 2; align-self: center; margin: 0; font-size: 25px; }

  .table-row { grid-template-columns: 1fr; gap: 5px; padding: 12px; }
  .table-head { display: none; }
  .table-row span { overflow-wrap: anywhere; }
  .mini-action { min-height: 34px; padding: 7px 11px; }

  .property-card { grid-template-columns: 1fr; }
  .property-actions { justify-content: space-between; }
  .profile-strip, .customer-actions { display: grid; grid-template-columns: 1fr; }
  .detail-chat { max-height: none; }

  .calendar-panel .panel-head { align-items: stretch; flex-direction: column; }
  .calendar-controls { display: grid; grid-template-columns: 1fr auto; }
  .month-day { grid-template-rows: auto minmax(60px, 1fr); min-height: 96px; padding: 6px 0; }
  .month-day header { padding: 0 5px; }
  .month-day header strong { font-size: 13px; }
  .month-day header span, .empty-day { display: none; }
  .calendar-events { min-height: 82px; }
  .reservation-segment { top: calc(3px + var(--lane) * 38px); min-height: 32px; padding: 4px 6px; }
  .reservation-segment strong { font-size: 10px; }
  .segment-checkin { padding-left: 5px; }
  .segment-checkin::before { display: none; }

  button,
  .expense-form input, .expense-form select,
  .property-form input, .property-form select, .property-form textarea,
  .booking-form input, .booking-form select, .booking-form textarea,
  .customer-profile-form input, .customer-profile-form textarea, .human-message-form textarea,
  .calendar-controls input { min-height: 42px; }
  .icon-button { width: 36px; height: 36px; min-height: 36px; }
}
